/* ================================================
   夜凪舎 - Home Page Styles
   トップページ固有のスタイル
   ================================================ */

/* === Main === */
.main {
  padding-top: 80px; /* ヘッダーの高さ分 */
}

/* === Hero Section === */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-24) 0;
}

.hero__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-8);
  text-align: center;
}

.hero__logo {
  width: 400px;
  height: auto;
  opacity: 0.95;
  mix-blend-mode: screen; /* 暗い背景を透過 */
  filter: brightness(1.1) contrast(1.1); /* 明瞭度を上げる */
  animation: fadeIn var(--duration-slower) var(--ease-out-expo) forwards;
}

.hero__title {
  font-family: var(--font-ja-display);
  font-size: var(--text-6xl);
  font-weight: 300;
  letter-spacing: var(--tracking-wider);
  color: var(--color-cream);
  line-height: 1.2;
  animation: fadeIn var(--duration-slower) var(--ease-out-expo) 0.2s forwards;
  opacity: 0;
}

.hero__tagline {
  font-family: var(--font-ja-body);
  font-size: var(--text-xl);
  font-weight: 300;
  letter-spacing: var(--tracking-wide);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
  animation: fadeIn var(--duration-slower) var(--ease-out-expo) 0.4s forwards;
  opacity: 0;
}

/* === Wave Separator === */
.wave-separator-wrapper {
  margin: var(--space-24) 0;
}

/* === About Section === */
.about {
  padding: var(--space-32) 0;
  background: linear-gradient(
    to bottom,
    var(--color-navy-deep) 0%,
    var(--color-navy) 100%
  );
}

.about__content {
  max-width: var(--container-md);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.about__text {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: var(--color-text-primary);
  margin-bottom: 0;
}

.about__text--emphasis {
  font-size: var(--text-2xl);
  font-weight: 400;
  color: var(--color-cream);
  letter-spacing: var(--tracking-wide);
  line-height: var(--leading-loose);
  padding-left: var(--space-6);
  border-left: 2px solid var(--color-gold-dim);
}

/* === Apps Section === */
.apps {
  padding: var(--space-48) 0;
  background-color: var(--color-navy-deep);
}

.apps__header {
  text-align: center;
  margin-bottom: var(--space-24);
}

.apps__title {
  font-size: var(--text-4xl);
  margin-bottom: var(--space-4);
  color: var(--color-cream);
}

.apps__subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  letter-spacing: var(--tracking-wide);
}

/* === App Card === */
.app-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
  max-width: var(--container-lg);
  margin: 0 auto;
  padding: var(--space-16);
  background-color: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--color-border);
  border-radius: 4px;
  transition:
    background-color var(--duration-normal) var(--ease-out-quart),
    border-color var(--duration-normal) var(--ease-out-quart),
    transform var(--duration-normal) var(--ease-out-quart);
}

.app-card:hover {
  background-color: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.2);
  transform: translateY(-4px);
}

.app-card__image {
  display: flex;
  justify-content: center;
  align-items: center;
}

.app-card__image img {
  width: 100%;
  max-width: 256px;
  height: auto;
  border-radius: 24px;
  filter: drop-shadow(0 8px 24px rgba(0, 0, 0, 0.3));
}

.app-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.app-card__title {
  font-size: var(--text-3xl);
  font-weight: 400;
  color: var(--color-cream);
  letter-spacing: var(--tracking-wide);
}

.app-card__tagline {
  font-size: var(--text-xl);
  font-weight: 300;
  color: var(--color-gold);
  letter-spacing: var(--tracking-wide);
  margin-bottom: var(--space-2);
}

.app-card__description {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-4);
}

.app-card__actions {
  margin-top: var(--space-4);
}

/* === Responsive Design === */
@media (min-width: 768px) {
  /* Hero */
  .hero__logo {
    width: 500px;
  }

  .hero__title {
    font-size: var(--text-6xl);
  }

  .hero__tagline {
    font-size: var(--text-2xl);
  }

  /* About */
  .about {
    padding: var(--space-48) 0;
  }

  .about__text--emphasis {
    font-size: var(--text-3xl);
    padding-left: var(--space-12);
  }

  /* App Card - 横並びレイアウト（非対称） */
  .app-card {
    grid-template-columns: 280px 1fr;
    gap: var(--space-16);
    padding: var(--space-24);
  }

  .app-card__image img {
    max-width: 280px;
  }
}

@media (min-width: 1024px) {
  /* Hero */
  .hero {
    min-height: 85vh;
  }

  .hero__logo {
    width: 600px;
  }

  /* Apps */
  .apps {
    padding: var(--space-48) 0 var(--space-32);
  }

  /* App Card - より大胆な非対称レイアウト */
  .app-card {
    grid-template-columns: 320px 1fr;
    gap: var(--space-24);
  }

  .app-card__image img {
    max-width: 320px;
  }

  .app-card__title {
    font-size: var(--text-4xl);
  }

  .app-card__tagline {
    font-size: var(--text-2xl);
  }

  .app-card__description {
    font-size: var(--text-lg);
  }
}

/* === モバイル調整 === */
@media (max-width: 767px) {
  .main {
    padding-top: 64px;
  }

  .hero {
    min-height: 100vh;
    padding: var(--space-16) 0;
  }

  .hero__logo {
    width: 280px;
    max-width: 90vw;
  }

  .hero__title {
    font-size: var(--text-4xl);
  }

  .hero__tagline {
    font-size: var(--text-base);
  }

  .about {
    padding: var(--space-24) 0;
  }

  .about__text--emphasis {
    font-size: var(--text-xl);
    padding-left: var(--space-4);
  }

  .apps {
    padding: var(--space-24) 0;
  }

  .apps__header {
    margin-bottom: var(--space-16);
  }

  .apps__title {
    font-size: var(--text-3xl);
  }

  .apps__subtitle {
    font-size: var(--text-base);
  }

  .app-card {
    padding: var(--space-8);
    gap: var(--space-8);
  }

  .app-card__image img {
    max-width: 200px;
  }

  .app-card__title {
    font-size: var(--text-2xl);
  }

  .app-card__tagline {
    font-size: var(--text-lg);
  }

  .app-card__description {
    font-size: var(--text-sm);
  }
}
