/* ========================================
   layout.css — 構造とレスポンシブ
   ======================================== */

/* --- コンテナ ----------------------------- */
.section__inner,
.site-header__inner,
.site-footer__inner,
.term-wrap {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--sp-md);
}
.section__inner--narrow,
.term-wrap--narrow { max-width: var(--container-narrow); }

@media (min-width: 768px) {
  .section__inner,
  .site-header__inner,
  .site-footer__inner,
  .term-wrap { padding-inline: var(--sp-lg); }
}

/* --- ヘッダー ----------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-nav);
}
.site-header__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--sp-md);
  min-height: 56px;
}
.site-header__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-sm);
}

.site-nav { display: none; }
.site-nav__list {
  display: flex;
  gap: clamp(0.75rem, 2vw, 1.5rem);
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 768px) {
  .site-nav { display: block; justify-self: center; }
}

.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
}

/* --- ヒーロー ----------------------------- */
.hero {
  position: relative;
  min-height: clamp(440px, 70vh, 640px);
  display: grid;
  place-items: center;
  overflow: hidden;
  isolation: isolate;
}

.hero__inner {
  position: relative;
  z-index: var(--z-content);
  text-align: center;
  padding: var(--sp-xl) var(--sp-md);
  max-width: 880px;
}
.hero__lead {
  font-size: clamp(0.95rem, 1.3vw, 1.1rem);
  margin-bottom: var(--sp-lg);
}
.hero__cta {
  display: inline-flex;
  align-items: center;
}

/* --- セクション --------------------------- */
.section { padding: var(--sp-xl) 0; }

/* --- エントリ（ターミナルでは fslist に置換するが、念のため残置） --- */
.entry-list { list-style: none; padding: 0; margin: 0; }

/* --- フッター ----------------------------- */
.site-footer__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-md);
  text-align: center;
}

/* --- スクロールフェード（base 値） ------- */
.fade-in {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity var(--t-slow) var(--easing), transform var(--t-slow) var(--easing);
}
.fade-in.is-visible { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .fade-in { opacity: 1; transform: none; transition: none; }
}
