/* ============================================================
   PROOF. Global Styles — Mobile First（修正版）
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
  background: var(--c-bg); color: var(--c-ink);
  font-family: var(--font-body); font-size: var(--text-base);
  line-height: var(--leading-normal);
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
img, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }
main { padding-top: var(--nav-h); }

/* ----------------------------------------------------------
   NAV
   ---------------------------------------------------------- */
nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: var(--z-nav); height: var(--nav-h);
  padding: 0 var(--pad-x);
  display: flex; justify-content: space-between; align-items: center;
  background: var(--c-nav-bg);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: var(--border);
}

.nav-logo {
  font-family: var(--font-display);
  font-size: clamp(18px, 3vw, 22px);
  letter-spacing: var(--tracking-snug);
  color: var(--c-ink); text-decoration: none;
}
.nav-logo .dot { color: var(--c-accent); }

/* PC リンク */
.nav-links { display: flex; gap: var(--sp-6); align-items: center; }
.nav-link {
  display: none; /* モバイルでは非表示 */
  font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: var(--c-mute); text-decoration: none;
  position: relative; padding-bottom: 2px;
  transition: color var(--ease);
}
/* アンダーラインなし・ホバーアニメーション（色変化のみ） */
.nav-link::after { display: none; }
.nav-link:hover { color: var(--c-ink); }
.nav-link.nav-active { color: var(--c-accent); }

.nav-cta {
  font-family: var(--font-mono); font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  font-weight: var(--weight-bold);
  background: var(--c-accent); color: var(--c-bg) !important;
  padding: var(--sp-2) var(--sp-4); text-decoration: none;
  transition: transform var(--ease); white-space: nowrap;
}
.nav-cta:hover { transform: translateX(4px); }

/* タブレット以上でリンクを表示 */
@media (min-width: 720px) {
  .nav-links { gap: var(--sp-8); }
  .nav-link { display: block; }
  .nav-cta { font-size: var(--text-xs); }
}

/* ----------------------------------------------------------
   ハンバーガーボタン（モバイル専用）
   ---------------------------------------------------------- */
.nav-hamburger {
  display: flex; flex-direction: column; gap: 5px;
  cursor: pointer; padding: var(--sp-2); background: none; border: none;
  z-index: calc(var(--z-nav) + 1);
}
.nav-hamburger span {
  display: block; width: 22px; height: 1.5px;
  background: var(--c-ink); border-radius: 1px;
  transition: all .3s var(--ease-out);
  transform-origin: center;
}
.nav-hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

@media (max-width: 719px) {
  nav { justify-content: flex-start; gap: var(--sp-3); }
  .nav-links { margin-left: auto; }
  .page-hero-sub br { display: none; }
}
@media (min-width: 720px) { .nav-hamburger { display: none; } }

/* ----------------------------------------------------------
   モバイルオーバーレイメニュー
   ---------------------------------------------------------- */
.nav-overlay {
  position: fixed;
  top: var(--nav-h); left: 0; right: 0; bottom: 0;
  background: rgba(10,10,10,0.97);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  z-index: calc(var(--z-nav) - 1);
  display: flex; flex-direction: column;
  padding: var(--sp-10) var(--pad-x) var(--sp-10);
  gap: 0;
  transform: translateX(100%);
  transition: transform .4s var(--ease-out);
  pointer-events: none;
  overflow-y: auto;
}
.nav-overlay.open { transform: translateX(0); pointer-events: all; }

.nav-overlay a {
  font-family: var(--font-display);
  font-size: clamp(28px, 7vw, 40px);
  letter-spacing: var(--tracking-tight);
  color: var(--c-mute); text-decoration: none;
  padding: var(--sp-5) 0;
  border-bottom: 0.5px solid var(--c-line);
  transition: color var(--ease);
  display: block;
}
.nav-overlay a:hover,
.nav-overlay a.nav-active { color: var(--c-ink); }
.nav-overlay a:last-child { border-bottom: none; }

.nav-overlay-cta {
  margin-top: var(--sp-8);
  background: var(--c-accent) !important;
  color: var(--c-bg) !important;
  font-family: var(--font-mono) !important;
  font-size: var(--text-base) !important;
  letter-spacing: var(--tracking-wide) !important;
  text-transform: uppercase; font-weight: var(--weight-bold) !important;
  padding: var(--sp-5) var(--sp-8) !important;
  border-bottom: none !important;
  display: inline-block !important;
}

@media (min-width: 720px) { .nav-overlay { display: none; } }

/* ----------------------------------------------------------
   PAGE HERO
   ---------------------------------------------------------- */
.page-hero {
  padding: calc(var(--hero-py) + var(--nav-h)) var(--pad-x) var(--sp-20);
  position: relative; border-bottom: var(--border); overflow: hidden;
}
.page-hero::before {
  content: ''; position: absolute; top: 0; right: 0;
  width: 60%; height: 100%; background: var(--glow-hero); pointer-events: none;
}
.page-hero-inner { max-width: var(--max-w); margin: 0 auto; position: relative; z-index: var(--z-base); }
.page-hero-label {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--c-accent);
  letter-spacing: var(--tracking-widest); text-transform: uppercase; font-weight: var(--weight-bold);
  margin-bottom: var(--sp-6); display: flex; align-items: center; gap: var(--sp-3);
}
.page-hero-label::before { content: ''; width: 24px; height: 1px; background: var(--c-accent); flex-shrink: 0; }
.page-hero h1 {
  font-family: var(--font-display); font-size: var(--text-h1);
  letter-spacing: var(--tracking-tight); line-height: 1.1;
  color: var(--c-ink); margin-bottom: var(--sp-8);
}
.page-hero h1 .dot { color: var(--c-accent); }
.page-hero-sub {
  font-size: var(--text-hero-sub); font-weight: var(--weight-medium);
  color: var(--c-mute); max-width: 60ch; line-height: var(--leading-relaxed);
}
.page-hero-sub strong { color: var(--c-ink); font-weight: var(--weight-medium); }

/* ----------------------------------------------------------
   SECTION 共通
   ---------------------------------------------------------- */
.section { padding: var(--section-py) var(--pad-x); border-bottom: var(--border); position: relative; }
.section:last-of-type { border-bottom: none; }
.section-inner { max-width: var(--max-w); margin: 0 auto; }

.section-label {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--c-mute);
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  margin-bottom: var(--sp-6); display: flex; align-items: center; gap: var(--sp-3);
}
.section-label::before { content: ''; width: 24px; height: 1px; background: var(--c-accent); flex-shrink: 0; }

.section-head { margin-bottom: var(--sp-16); }
.section-head h2 {
  font-family: var(--font-body); font-weight: var(--weight-heavy);
  font-size: var(--text-h2-lg); letter-spacing: var(--tracking-snug);
  line-height: 1.25; /* 修正: 1.1→1.25 */
  margin-bottom: var(--sp-6); max-width: 24ch;
}
.section-head h2 .dot, .section-head h2 b { color: var(--c-accent); }
.section-head p { font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--c-mute); max-width: 75ch; }
.section-head p strong { color: var(--c-ink); font-weight: var(--weight-medium); }

/* ----------------------------------------------------------
   1px LINE GRID
   ---------------------------------------------------------- */
.grid-line { display: grid; gap: var(--grid-gap); background: var(--c-line); border: var(--border); }
.grid-line > * { background: var(--c-bg); }

/* ----------------------------------------------------------
   BUTTONS — 余白修正
   ---------------------------------------------------------- */
.btn {
  font-family: var(--font-mono); font-size: var(--text-sm);
  letter-spacing: var(--tracking-wide); text-transform: uppercase; font-weight: var(--weight-bold);
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-3);
  text-decoration: none; cursor: pointer; transition: all var(--ease); border: none;
  line-height: 1; white-space: nowrap;
  padding: var(--sp-5) var(--sp-8); /* モバイルでも余白を確保 */
}
.btn-primary {
  background: var(--c-accent); color: var(--c-bg);
  border: 1px solid var(--c-accent);
  padding: var(--sp-5) var(--sp-8); /* 明示的に指定 */
}
.btn-primary:hover { background: transparent; color: var(--c-accent); }

.btn-secondary {
  background: transparent; color: var(--c-ink);
  border: 1px solid var(--c-line2);
  padding: var(--sp-5) var(--sp-8); /* 明示的に指定 */
}
.btn-secondary:hover { border-color: var(--c-ink); }

/* モバイルでは縦並び */
.btn-group { display: flex; flex-direction: column; gap: var(--sp-3); }
@media (min-width: 480px) { .btn-group { flex-direction: row; flex-wrap: wrap; } }

/* ----------------------------------------------------------
   TAG / CHIP
   ---------------------------------------------------------- */
.tag {
  font-family: var(--font-mono); font-size: var(--text-2xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; border: var(--border2); padding: var(--sp-1) var(--sp-2);
  color: var(--c-mute); display: inline-block; line-height: 1.6;
}
.filter-chip {
  font-family: var(--font-mono); font-size: var(--text-2xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--c-mute); background: transparent;
  border: var(--border2); padding: var(--sp-2) var(--sp-3); cursor: pointer;
  transition: all var(--ease); font-weight: var(--weight-medium);
}
.filter-chip:hover { color: var(--c-ink); border-color: var(--c-mute); }
.filter-chip.active { color: var(--c-bg); background: var(--c-accent); border-color: var(--c-accent); font-weight: var(--weight-bold); }
@media (min-width: 720px) { .filter-chip { font-size: var(--text-xs); padding: var(--sp-2) var(--sp-4); } }

/* ----------------------------------------------------------
   FAQ
   ---------------------------------------------------------- */
.faq-list { margin-top: var(--sp-12); display: grid; gap: var(--grid-gap); background: var(--c-line); border-top: var(--border); border-bottom: var(--border); }
.faq-item { background: var(--c-bg); padding: var(--sp-6); cursor: pointer; transition: background var(--ease); }
.faq-item:hover { background: var(--c-surface-1); }
.faq-q {
  font-family: var(--font-body); font-weight: var(--weight-bold); font-size: var(--text-base);
  letter-spacing: -0.01em; display: flex; justify-content: space-between; align-items: center;
  gap: var(--sp-6); line-height: 1.5;
}
.faq-q::after {
  content: '+'; font-family: var(--font-display); font-size: var(--text-xl);
  color: var(--c-accent); transition: transform var(--ease); flex-shrink: 0;
}
.faq-item.open .faq-q::after { transform: rotate(45deg); }
.faq-a { font-size: var(--text-sm); color: var(--c-mute); line-height: var(--leading-relaxed); margin-top: var(--sp-4); display: none; }
.faq-item.open .faq-a { display: block; }
@media (min-width: 720px) { .faq-item { padding: var(--sp-8); } .faq-q { font-size: var(--text-md); } }

/* ----------------------------------------------------------
   CTA SECTION
   ---------------------------------------------------------- */
.cta-section {
  padding: var(--section-py) var(--pad-x); text-align: center;
  background: var(--glow-center); border-top: var(--border);
}
.cta-section .section-inner { display: flex; flex-direction: column; align-items: center; }
.cta-section h2 {
  font-family: var(--font-display); font-size: var(--text-h1);
  letter-spacing: var(--tracking-tight); line-height: 1.05; /* 修正: 0.9→1.05 */
  margin-bottom: var(--sp-6);
}
.cta-section h2 .dot { color: var(--c-accent); }
.cta-section p {
  font-size: var(--text-base); color: var(--c-mute); max-width: 60ch;
  margin: 0 auto var(--sp-10); line-height: var(--leading-relaxed);
}

/* ----------------------------------------------------------
   FOOTER
   ---------------------------------------------------------- */
footer { padding: var(--sp-20) var(--pad-x) var(--sp-10); border-top: var(--border); background: var(--c-surface-3); }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-10); margin-bottom: var(--sp-16); max-width: var(--max-w); margin-left: auto; margin-right: auto; }
@media (min-width: 560px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 960px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; margin-bottom: var(--sp-16); } }
.footer-brand .logo { font-family: var(--font-display); font-size: clamp(24px,4vw,32px); letter-spacing: -0.04em; margin-bottom: var(--sp-4); }
.footer-brand .logo .dot { color: var(--c-accent); }
.footer-brand p { font-size: var(--text-sm); color: var(--c-mute); line-height: var(--leading-relaxed); max-width: 32ch; }
.footer-col h4 { font-family: var(--font-mono); font-size: var(--text-2xs); color: var(--c-ink); letter-spacing: var(--tracking-wider); text-transform: uppercase; margin-bottom: var(--sp-5); font-weight: var(--weight-bold); }
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: var(--sp-3); }
.footer-col a { font-size: var(--text-sm); color: var(--c-mute); text-decoration: none; transition: color var(--ease); }
.footer-col a:hover { color: var(--c-ink); }
.footer-bottom { padding-top: var(--sp-8); border-top: var(--border); display: flex; flex-direction: column; gap: var(--sp-2); font-family: var(--font-mono); font-size: var(--text-2xs); color: var(--c-mute); letter-spacing: var(--tracking-wide); text-transform: uppercase; max-width: var(--max-w); margin: 0 auto; }
@media (min-width: 720px) { .footer-bottom { flex-direction: row; justify-content: space-between; } }
.footer-legal-link { color: inherit; text-decoration: none; transition: color var(--ease); }
.footer-legal-link:hover { color: var(--c-accent); }

/* ----------------------------------------------------------
   SKIP LINK
   ---------------------------------------------------------- */
.skip-link { position: absolute; top: -100%; left: var(--sp-4); background: var(--c-accent); color: var(--c-bg); padding: var(--sp-2) var(--sp-4); font-family: var(--font-mono); font-size: var(--text-xs); font-weight: var(--weight-bold); z-index: calc(var(--z-nav) + 1); text-decoration: none; }
.skip-link:focus { top: var(--sp-4); }

/* ----------------------------------------------------------
   SCROLL REVEAL
   ---------------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.6s var(--ease-out), transform 0.6s var(--ease-out); }
.reveal.visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ----------------------------------------------------------
   ARTICLE DROP CAP
   ---------------------------------------------------------- */
.article-drop-cap p:first-of-type::first-letter {
  font-family: var(--font-display); font-size: clamp(40px,6vw,64px);
  color: var(--c-accent); float: left; line-height: 0.85;
  padding-right: var(--sp-3); padding-top: var(--sp-1);
}

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

/* ----------------------------------------------------------
   Footer Social Links — アイコン付きリンク
   ---------------------------------------------------------- */
.footer-social-link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
}
.footer-social-link svg {
  flex-shrink: 0;
  color: var(--c-mute);
  transition: color var(--ease);
}
.footer-social-link:hover svg { color: var(--c-ink); }