/* =========================================================
   まいける LP — 観察ログ / 標本箱
   配色はアプリ本体(Theme.swift)準拠: 白 + クールグレー + スチールブルー
   フォントはアプリ世界観テキストと同じ DotGothic16(見出し/ラベル/数値)
   ========================================================= */

@font-face {
  font-family: "DotGothic16";
  src: url("assets/DotGothic16-Regular.ttf") format("truetype");
  font-weight: 400;
  font-display: swap;
}

:root {
  --bg:        #f6f7f8;
  --paper:     #ffffff;
  --surface:   #eef0f2;
  --ink:       #24282c;
  --ink-2:     #5d646b;
  --ink-3:     #969da4;
  --line:      #d4d8dc;
  --line-2:    #e3e6e9;
  --accent:    #5f6e7d;   /* スチールブルー */
  --accent-d:  #47535f;
  --gold:      #cf9a36;
  --grid:      rgba(95,110,125,0.06);
  --shadow:    rgba(36,40,44,0.10);

  --pix: "DotGothic16", "Hiragino Sans", system-ui, sans-serif;
  --sans: "Hiragino Sans", "Helvetica Neue", system-ui, sans-serif;

  --maxw: 1080px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--sans);
  color: var(--ink);
  background-color: var(--bg);
  /* 方眼紙(観察ノート)背景 */
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size: 26px 26px;
  line-height: 1.85;
  letter-spacing: 0.01em;
  -webkit-font-smoothing: antialiased;
}

.pix { font-family: var(--pix); letter-spacing: 0.02em; }

a { color: var(--accent-d); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }

img { display: block; image-rendering: pixelated; image-rendering: -moz-crisp-edges; }

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

/* ============ モノスペース風ラベル(観察ログの注釈) ============ */
.tag {
  font-family: var(--pix);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--accent);
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.tag::before {
  content: "";
  width: 18px; height: 1px;
  background: var(--accent);
  display: inline-block;
}

/* ============ トップバー ============ */
.topbar {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: saturate(150%) blur(8px);
  background: rgba(246,247,248,0.82);
  border-bottom: 1px solid var(--line);
}
.topbar .wrap {
  display: flex; align-items: center; justify-content: space-between;
  height: 58px;
}
.brand {
  font-family: var(--pix);
  font-size: 17px; letter-spacing: 0.06em; color: var(--ink);
  display: flex; align-items: center; gap: 10px;
}
.brand .dot {
  width: 11px; height: 11px; background: var(--ink);
  box-shadow: 13px 0 0 var(--accent), 0 13px 0 var(--line);
}
.topnav { display: flex; gap: 22px; font-family: var(--pix); font-size: 12px; letter-spacing: 0.08em; }
.topnav a { color: var(--ink-2); }
.topnav a:hover { color: var(--ink); text-decoration: none; }
@media (max-width: 720px){ .topnav { display: none; } }

/* ============ ヒーロー(被験体カード) ============ */
.hero { padding: 64px 0 40px; }
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 40px; align-items: center;
}
@media (max-width: 860px){ .hero-grid { grid-template-columns: 1fr; gap: 28px; } }

.hero h1 {
  font-family: var(--pix);
  font-size: clamp(34px, 6vw, 62px);
  line-height: 1.15;
  margin: 18px 0 18px;
  letter-spacing: 0.01em;
}
.hero h1 .small { display:block; font-size: 0.42em; color: var(--ink-2); letter-spacing:0.1em; margin-top:14px; }
.hero p.lead { font-size: 16px; color: var(--ink-2); max-width: 30em; margin: 0 0 28px; }

.cta-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.btn {
  font-family: var(--pix);
  font-size: 13px; letter-spacing: 0.06em;
  padding: 13px 22px;
  border: 1.5px solid var(--ink);
  background: var(--ink); color: #fff;
  display: inline-flex; align-items: center; gap: 9px;
  transition: transform .12s ease, background .2s ease;
}
.btn:hover { text-decoration: none; transform: translateY(-2px); background: var(--accent-d); border-color: var(--accent-d); }
.btn.ghost { background: transparent; color: var(--ink); }
.btn.ghost:hover { background: var(--surface); color: var(--ink); }
.btn .badge { font-size: 10px; opacity: .7; }

/* 被験体ファイル(標本カード) */
.specimen {
  position: relative;
  background: var(--paper);
  border: 1.5px solid var(--ink);
  box-shadow: 10px 10px 0 var(--surface);
  padding: 20px;
}
.specimen .corner { position:absolute; width:9px; height:9px; border:1.5px solid var(--ink); background:var(--paper); }
.specimen .corner.tl{ top:-5px; left:-5px;} .specimen .corner.tr{ top:-5px; right:-5px;}
.specimen .corner.bl{ bottom:-5px; left:-5px;} .specimen .corner.br{ bottom:-5px; right:-5px;}

.specimen .hdr {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--pix); font-size: 11px; letter-spacing: 0.12em; color: var(--ink-2);
  border-bottom: 1px dashed var(--line); padding-bottom: 10px; margin-bottom: 4px;
}
.specimen .stage {
  background:
    radial-gradient(120% 80% at 50% 38%, #ffffff 0%, #eef0f2 100%);
  border: 1px solid var(--line-2);
  display: grid; place-items: center;
  padding: 18px 0 6px;
  position: relative;
}
.specimen .stage img { width: 58%; max-width: 220px; animation: breathe 3.4s ease-in-out infinite; }
@keyframes breathe { 0%,100%{ transform: translateY(0);} 50%{ transform: translateY(-6px);} }
.specimen .readout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border-top: 1px dashed var(--line); margin-top: 8px; font-family: var(--pix);
}
.specimen .readout div { padding: 11px 4px; font-size: 12px; color: var(--ink-2); }
.specimen .readout div b { display:block; font-size: 19px; color: var(--ink); letter-spacing: 0.02em; }
.specimen .readout div:nth-child(1){ border-right: 1px dashed var(--line); }
.specimen .note {
  font-family: var(--pix); font-size: 12.5px; color: var(--ink);
  background: var(--surface); border-left: 3px solid var(--accent);
  padding: 9px 12px; margin-top: 10px;
}

/* ============ セクション共通 ============ */
section.block { padding: 66px 0; border-top: 1px solid var(--line); }
.sec-head { margin-bottom: 40px; max-width: 40em; }
.sec-head h2 {
  font-family: var(--pix);
  font-size: clamp(24px, 3.4vw, 36px); margin: 12px 0 14px; line-height: 1.25;
}
.sec-head p { color: var(--ink-2); margin: 0; font-size: 15px; }

/* ============ コンセプト(大きな引用) ============ */
.manifesto {
  font-family: var(--pix);
  font-size: clamp(22px, 3.8vw, 40px);
  line-height: 1.55; letter-spacing: 0.01em;
}
.manifesto .muted { color: var(--ink-3); }
.manifesto .hl { color: var(--accent-d); }
.manifesto-foot { margin-top: 26px; color: var(--ink-2); font-size: 15px; max-width: 36em; }

/* ============ 体型変化 観察タイムライン ============ */
.timeline { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
@media (max-width: 900px){ .timeline { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 520px){ .timeline { grid-template-columns: repeat(2, 1fr); } }

.tl-card {
  background: var(--paper); border: 1px solid var(--line);
  display: flex; flex-direction: column; transition: transform .15s ease, box-shadow .15s ease;
}
.tl-card:hover { transform: translateY(-4px); box-shadow: 0 10px 24px var(--shadow); }
.tl-card .lvl {
  font-family: var(--pix); font-size: 11px; letter-spacing: 0.1em;
  color: var(--ink-2); padding: 8px 10px 0; display: flex; justify-content: space-between;
}
.tl-card .lvl .n { color: var(--accent); }
.tl-card .pic {
  background: radial-gradient(110% 80% at 50% 35%, #fff 0%, #eef0f2 100%);
  aspect-ratio: 1/1; display: grid; place-items: center; margin: 6px 0;
}
.tl-card .pic img { width: 78%; }
.tl-card .name { font-family: var(--pix); font-size: 14px; text-align: center; }
.tl-card .steps { font-family: var(--pix); font-size: 11px; color: var(--ink-2); text-align:center; margin-top: 2px; }
.tl-card .cap {
  font-size: 12px; color: var(--ink-2); padding: 9px 11px 12px; border-top: 1px dashed var(--line);
  margin-top: 8px; min-height: 3.2em;
}

/* ============ 着せ替え 標本グリッド ============ */
.closet {
  display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 34px; align-items: center;
}
@media (max-width: 820px){ .closet { grid-template-columns: 1fr; } }
.closet-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.swatch {
  background: var(--paper); border: 1px solid var(--ink);
  position: relative; padding: 14px;
}
.swatch .pic { background: radial-gradient(110% 80% at 50% 40%, #fff, #eef0f2); display:grid; place-items:center; padding: 10px 0; }
.swatch .pic img { width: 64%; max-width: 150px; }
.swatch .meta { display: flex; justify-content: space-between; align-items: baseline; margin-top: 10px; font-family: var(--pix); }
.swatch .meta .nm { font-size: 13px; }
.swatch .meta .pr { font-size: 11px; color: var(--accent); }
.closet-copy h3 { font-family: var(--pix); font-size: 20px; margin: 0 0 10px; }
.closet-copy p { color: var(--ink-2); font-size: 14px; }
.chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.chip { font-family: var(--pix); font-size: 11px; letter-spacing: 0.04em; padding: 6px 11px; border: 1px solid var(--line); background: var(--paper); color: var(--ink-2); }

/* ============ 機能カード(観察項目) ============ */
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 820px){ .features { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px){ .features { grid-template-columns: 1fr; } }
.feat {
  background: var(--paper); border: 1px solid var(--line); padding: 22px 20px;
  position: relative;
}
.feat .idx { font-family: var(--pix); font-size: 11px; color: var(--accent); letter-spacing: 0.14em; }
.feat h3 { font-family: var(--pix); font-size: 16px; margin: 10px 0 8px; }
.feat p { font-size: 13.5px; color: var(--ink-2); margin: 0; }
.feat .pending { font-family: var(--pix); font-size: 10px; color: var(--gold); border:1px solid var(--gold); padding: 2px 7px; position:absolute; top:16px; right:16px; letter-spacing:0.08em; }

/* ============ フッター ============ */
footer.site {
  border-top: 1px solid var(--line); background: var(--paper);
  padding: 48px 0 40px; margin-top: 8px;
}
.foot-grid { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 28px; }
.foot-brand .b { font-family: var(--pix); font-size: 18px; letter-spacing: 0.05em; }
.foot-brand p { color: var(--ink-2); font-size: 13px; max-width: 24em; margin: 10px 0 0; }
.foot-links { display: flex; gap: 56px; flex-wrap: wrap; }
.foot-col h4 { font-family: var(--pix); font-size: 12px; letter-spacing: 0.1em; color: var(--ink-2); margin: 0 0 12px; }
.foot-col a, .foot-col span { display: block; font-size: 13.5px; color: var(--ink); margin-bottom: 9px; }
.foot-col span { color: var(--ink-2); }
.foot-legal {
  margin-top: 38px; padding-top: 20px; border-top: 1px dashed var(--line);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px;
  font-family: var(--pix); font-size: 11px; color: var(--ink-2); letter-spacing: 0.06em;
}

/* ============ 法務ページ ============ */
.legal-head { padding: 56px 0 26px; border-bottom: 1px solid var(--line); }
.legal-head h1 { font-family: var(--pix); font-size: clamp(26px, 4vw, 40px); margin: 14px 0 8px; }
.legal-head .updated { font-family: var(--pix); font-size: 12px; color: var(--ink-2); }
.legal-body { padding: 40px 0 70px; max-width: 780px; }
.legal-body h2 {
  font-family: var(--pix); font-size: 18px; margin: 38px 0 12px;
  padding-bottom: 8px; border-bottom: 1px dashed var(--line);
}
.legal-body h2:first-of-type { margin-top: 6px; }
.legal-body p, .legal-body li { font-size: 14.5px; color: var(--ink); line-height: 1.95; }
.legal-body ul { padding-left: 1.2em; }
.legal-body li { margin-bottom: 6px; }
.legal-body .muted { color: var(--ink-2); font-size: 13px; }

/* 特商法テーブル */
.spec-table { width: 100%; border-collapse: collapse; margin: 8px 0 4px; background: var(--paper); border: 1px solid var(--ink); }
.spec-table th, .spec-table td { text-align: left; padding: 13px 16px; border-bottom: 1px solid var(--line); font-size: 14px; vertical-align: top; }
.spec-table th {
  font-family: var(--pix); font-size: 12px; letter-spacing: 0.04em; color: var(--ink-2);
  width: 38%; background: var(--surface); border-right: 1px solid var(--line);
}
.spec-table tr:last-child th, .spec-table tr:last-child td { border-bottom: none; }
@media (max-width: 560px){
  .spec-table, .spec-table tbody, .spec-table tr, .spec-table th, .spec-table td { display: block; width: 100%; }
  .spec-table th { border-right: none; }
}

.backlink { font-family: var(--pix); font-size: 12px; color: var(--ink-2); display:inline-flex; gap:7px; align-items:center; }

/* JS が動く時だけ初期状態を隠す。JS 無効/失敗時は常に表示(コンテンツが消えない) */
.js .reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.js .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){
  .js .reveal { opacity:1; transform:none; transition:none; }
  .specimen .stage img { animation: none; }
}
