/* ==========================================================================
   Utility Classes
   ========================================================================== */

/* Screen reader only */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* Container */
.container {
  width: 100%;
  max-width: var(--container-sm);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

@media (min-width: 840px) {
  .container {
    max-width: var(--container-md);
  }
}

/* Section spacing */
.section {
  padding-top: var(--space-16);
  padding-bottom: var(--space-16);
}

@media (min-width: 840px) {
  .section {
    padding-top: var(--space-20);
    padding-bottom: var(--space-20);
  }
}

@media (min-width: 1280px) {
  .section {
    padding-top: var(--space-24);
    padding-bottom: var(--space-24);
  }

  .container {
    padding-left: var(--space-8);
    padding-right: var(--space-8);
  }
}

/* Section with alternate background */
.section--alt {
  background-color: var(--color-bg-section);
}

.section--alt2 {
  background-color: var(--color-bg-section-alt);
}

/* Flex utilities */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-2 { gap: var(--space-2); }
.gap-4 { gap: var(--space-4); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }

/* Spacing */
.mt-4 { margin-top: var(--space-4); }
.mt-8 { margin-top: var(--space-8); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-8 { margin-bottom: var(--space-8); }

/* ==========================================================================
   モバイル描画パフォーマンス最適化
   - スマホは backdrop-filter / 巨大 blur で描画スレッドが詰まりやすい
   - GPU 合成負荷を下げ、スクロール時の「引っかかり」を抑える
   ========================================================================== */
@media (max-width: 840px) {
  /* backdrop-filter は iOS Safari でも特に重い。背景不透明度を上げて視覚的に近似 */
  .reason-event-hero__caption {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background: rgba(0, 0, 0, 0.7) !important;
  }
  /* 大きな blur 半径(60-80px)は GPU メモリを食う。スマホでは縮小し、ふわふわアニメも停止 */
  .streams__orb,
  .stream-orb,
  .abt-cta-section__orb {
    filter: blur(30px) !important;
    animation: none !important;
  }
  /* スマホでは hover transition を簡素化（タッチでも :hover が暴発するため） */
  .reason-card:hover,
  .reason-event-hero:hover {
    transform: none !important;
  }
}

@media (max-width: 480px) {
  /* 極小機ではオーブごと非表示 */
  .streams__orb,
  .stream-orb,
  .abt-cta-section__orb {
    display: none !important;
  }
}

/* iOS で `position: fixed` + アニメ要素がスクロール時にチラつくのを防ぐ */
.bubbles-wrap {
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
