/* shared/base.css — 共通の土台 */
body {
  font-family: var(--font-base);
  font-size: var(--fs-base);
  color: var(--color-text);
  background: var(--color-bg);
}

/* レイアウトの器 */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--sp-4);
}

/* セクションの上下余白 */
.section { padding-block: var(--sp-12); }

/* 見出し */
h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); margin-bottom: var(--sp-6); }
h3 { font-size: var(--fs-xl); margin-bottom: var(--sp-4); }
p + p { margin-top: var(--sp-4); }

/* リンク */
a { color: var(--color-link); transition: color .15s ease; }
a:hover { color: var(--color-link-hover); }
a:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ボタン */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-3) var(--sp-6);
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: var(--fs-base);
  transition: background .15s ease, transform .05s ease;
}
.btn-primary {
  background: var(--color-primary);
  color: #fff;
}
.btn-primary:hover {
  background: var(--color-primary-dark);
  color: #fff;
}
.btn-outline {
  background: transparent;
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
}
.btn-outline:hover {
  background: var(--color-primary);
  color: #fff;
}

/* ヘッダー */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,0.95);
  backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--color-border);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}
.site-header__logo {
  font-weight: 700;
  font-size: var(--fs-lg);
}
.site-nav__list {
  display: none;
  gap: var(--sp-6);
}
.site-nav__list a { font-size: var(--fs-sm); }

/* モバイルナビトリガー */
.nav-toggle {
  display: inline-flex;
  width: 40px; height: 40px;
  align-items: center; justify-content: center;
  border-radius: var(--radius-sm);
}
.nav-toggle:hover { background: var(--color-surface); }

/* フッター */
.site-footer {
  background: var(--color-surface);
  padding-block: var(--sp-12);
  margin-top: var(--sp-16);
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}
.site-footer a:hover { text-decoration: underline; }

/* ヒーロー */
.hero {
  padding-block: var(--sp-16);
}
.hero__title {
  font-size: var(--fs-3xl);
  margin-bottom: var(--sp-4);
}
.hero__lead {
  font-size: var(--fs-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--sp-8);
}

/* カード */
.card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--sp-6);
}

/* 定義リスト (会社情報・特商法用) */
.dl-info dt {
  font-weight: 600;
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  margin-top: var(--sp-4);
}
.dl-info dd { font-size: var(--fs-base); }
.dl-info dd + dt { margin-top: var(--sp-6); }

/* ユーティリティ */
.text-center { text-align: center; }
.muted { color: var(--color-text-muted); }
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
