/* ===== Reset（最小限） ===== */
*,
*::before,
*::after {
  box-sizing: border-box
}

html:focus-within {
  scroll-behavior: smooth
}

body {
  margin: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility
}

img,
video,
svg {
  display: block;
  max-width: 100%;
  height: auto
}

/* ===== Tokens ===== */
:root {
  --c-bg: #ffffff;
  --c-fg: #000000;
  --c-muted: #666666;
  --c-border: #e0e0e0;
  --c-gray: #d0d0d0;

  --space-1: 8px;
  --space-2: 12px;
  --space-3: 16px;
  --space-4: 24px;
  --space-5: 32px;
  --space-6: 48px;
  --space-7: 64px;
  --space-8: 96px;
  --space-9: 120px;

  --radius-min: 0px;
  --radius-pill: 9999px;

  --max-w: 1400px;
  --gutter: clamp(24px, 5vw, 80px);

  --h1: clamp(3rem, 8vw, 6rem);
  --h2: clamp(1.5rem, 3vw, 2rem);
  --h3: clamp(1.25rem, 2.5vw, 1.75rem);
  --body: clamp(16px, 1.6vw, 18px);
  --cap: clamp(12px, 1.2vw, 14px);

  --r-marubi: clamp(28px, 3.5vw, 48px);
  --r-marubi-inner: calc(var(--r-marubi) - 6px);
  --bg-band: #fafafa;
  --bg-card: #ffffff;
  --line-soft: rgba(0, 0, 0, 0.08);
  --ink-muted: #666666;
}

/* ===== Base ===== */
body {
  background: var(--c-bg);
  color: var(--c-fg);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif;
  font-size: var(--body);
  line-height: 1.8;
  letter-spacing: 0.02em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: inherit;
  text-decoration: none
}

a:hover {
  opacity: .85
}

/* 集中線（フォーカスリング） */
:focus-visible {
  outline: 2px solid #000;
  outline-offset: 3px
}

/* コンテナ */
.container {
  max-width: var(--max-w);
  padding-inline: var(--gutter);
  margin-inline: auto;
}

/* セクション余白（TOPは広め） */
.section-pad {
  padding-block: var(--space-7);
}

.section-pad-tight {
  padding-block: var(--space-5);
}

/* グリッド（12col相当のシンプル版） */
.grid {
  display: grid;
  gap: var(--space-5);
}

.grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

@media (max-width:1024px) {
  .grid-3 {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media (max-width:640px) {
  .grid-3 {
    grid-template-columns: 1fr
  }
}

/* 見出し */
.h1 {
  font-size: var(--h1);
  line-height: 1.1;
  margin: 0;
  font-weight: 400;
  letter-spacing: -0.02em;
}

.h2 {
  font-size: var(--h2);
  line-height: 1.2;
  margin: 0;
  font-weight: 400;
  letter-spacing: 0.05em;
}

.section-label {
  font-size: var(--h2);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 400;
  opacity: 0.8;
}

/* モーション軽減 */
@media (prefers-reduced-motion:reduce) {
  * {
    animation: none !important;
    transition: none !important
  }
}

/* 細線 */
.hr {
  border: 0;
  border-top: 1px solid var(--c-border);
  margin: var(--space-6) 0
}