/* ============================================================
   みんなの里山キャンプ場 ── 安心型（B案）
   アートディレクション：「里山の手帖 / フィールドガイド」
   観察手帖・注釈つき・手描き感のエディトリアル。
   明るく温かい紙の上で、大胆な和文タイポと引き出し線で構成。
   外部ライブラリ・CDN 不使用。CSS のみ（HTML 側に少量の vanilla JS）。
   ── 世界観型（夜・シネマ）とは別アイデンティティ ──
   ============================================================ */

:root{
  /* 紙とインク（明るく温かい） */
  --paper:#f4efe1;          /* 生成りの紙 */
  --paper-2:#efe8d6;        /* 一段沈んだ紙（帯・余白） */
  --card:#fbf8f0;           /* 手帖のページ面（最も明るい） */
  --ink:#27302a;            /* 本文インク（紙上で 4.5:1 以上） */
  --ink-soft:#46503f;       /* 補助テキスト（紙上 4.5:1 以上を確保） */
  --forest:#2c4a32;         /* 森緑インク（見出し・タブ） */
  --forest-deep:#1f3525;    /* 最暗の森緑 */
  --sage:#7a8b6a;           /* セージ（罫・装飾線） */
  --sage-soft:#aeb89c;      /* 淡セージ（手描き下線・装飾のみ・文字色禁止） */
  --rust:#9c4a23;           /* 山栗色（差し色・章番号） */
  --rust-ink:#7e3a1a;       /* 差し色の濃版（文字に使える） */
  --honey:#caa44a;          /* 蜜色（インデックスタブの差し） */
  --rule:rgba(39,48,42,.16);/* 細罫 */
  --rule-strong:rgba(39,48,42,.30);
  --serif:"Hiragino Mincho ProN","Yu Mincho","YuMincho","HGS明朝E",serif;
  --sans:"Hiragino Kaku Gothic ProN","Yu Gothic","Noto Sans JP","Helvetica Neue",Arial,sans-serif;
  --maxw:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  font-family:var(--sans);
  line-height:1.85;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  /* 紙の質感：かすかな繊維ノイズ＋方眼の手帖罫（薄く） */
  background-color:var(--paper);
  background-image:
    radial-gradient(rgba(122,139,106,.05) 1px,transparent 1.4px),
    linear-gradient(rgba(39,48,42,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(39,48,42,.035) 1px,transparent 1px);
  background-size:6px 6px,28px 28px,28px 28px;
  background-position:0 0,0 0,0 0;
}
img{display:block;max-width:100%}
a{color:inherit}

.wrap{width:min(var(--maxw),calc(100% - 40px));margin:0 auto}

/* ============================================================
   デモ帯（最上部・全案共通文言）
   ============================================================ */
.demo-banner{
  background:var(--forest-deep);
  color:#f1ecdc;
  font-size:12.5px;line-height:1.7;letter-spacing:.01em;
  padding:9px 18px;text-align:center;
}

/* ============================================================
   他案ナビ（提案一覧／世界観型／安心型／実用型）
   手帖の小口に貼った付箋のトーン
   ============================================================ */
.proposal-nav{ background:var(--paper-2); border-bottom:1px solid var(--rule) }
.proposal-nav-inner{
  width:min(var(--maxw),calc(100% - 40px));margin:0 auto;
  display:flex;flex-wrap:wrap;align-items:center;gap:14px 22px;
  padding:10px 0;
}
.proposal-nav-inner > strong{
  font-family:var(--serif);font-weight:700;color:var(--forest);
  font-size:14px;letter-spacing:.06em;
}
.proposal-nav-links{display:flex;flex-wrap:wrap;gap:8px;margin-left:auto}
.proposal-nav-links a{
  text-decoration:none;color:var(--ink-soft);
  font-size:13px;font-weight:700;letter-spacing:.04em;
  padding:5px 12px;border:1px solid var(--rule-strong);border-radius:999px;
  background:var(--card);
  transition:background .2s ease,color .2s ease,border-color .2s ease;
}
.proposal-nav-links a:hover,.proposal-nav-links a:focus-visible{
  color:#fff;background:var(--forest);border-color:var(--forest);
}
.proposal-nav-links a.current{
  color:#fff;background:var(--rust-ink);border-color:var(--rust-ink);
}

/* ============================================================
   インデックスタブ（手帖の小口・固定）— 原創的なナビ装置
   右端に章のラベルを縦に立てる。スクロールで該当タブが点灯。
   ============================================================ */
.indextabs{
  position:fixed;top:50%;right:0;transform:translateY(-50%);
  z-index:40;display:flex;flex-direction:column;gap:7px;
  padding:6px 0;
}
.indextabs a{
  display:flex;align-items:center;justify-content:center;
  writing-mode:vertical-rl;text-orientation:upright;
  text-decoration:none;font-family:var(--serif);font-weight:700;
  font-size:12px;letter-spacing:.28em;
  color:var(--forest);background:var(--card);
  border:1px solid var(--rule-strong);border-right:none;
  border-radius:8px 0 0 8px;
  padding:13px 7px;
  box-shadow:-2px 2px 8px rgba(39,48,42,.10);
  transition:background .25s ease,color .25s ease,padding-right .25s ease;
}
.indextabs a:hover,.indextabs a:focus-visible{
  background:var(--honey);color:var(--forest-deep);padding-right:11px;
}
.indextabs a.active{
  background:var(--forest);color:#fff;padding-right:13px;
}
@media (max-width:1080px){ .indextabs{display:none} }

/* ============================================================
   手帖の表紙＝マストヘッド
   観察手帖の表紙ラベル風。ルール罫・整理番号・採取地。
   ============================================================ */
.cover{
  position:relative;
  padding:30px 0 8px;
}
.cover-inner{
  position:relative;
  border:2px solid var(--forest);
  border-radius:4px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.5),rgba(255,255,255,0) 120px),
    var(--card);
  padding:22px 26px 24px;
  box-shadow:0 18px 44px rgba(39,48,42,.12);
}
/* 二重罫の内側ライン（手帖の額装罫） */
.cover-inner::before{
  content:"";position:absolute;inset:6px;border:1px solid var(--rule-strong);
  border-radius:2px;pointer-events:none;
}
.cover-top{
  display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 16px;
  font-family:var(--serif);color:var(--forest);
  border-bottom:1px solid var(--rule);padding-bottom:12px;margin-bottom:16px;
}
.cover-top .brandmark{display:flex;align-items:center;gap:11px;margin-right:auto}
.cover-top .brandmark img{width:128px;height:auto}
.cover-top .filed{
  font-size:12px;letter-spacing:.12em;color:var(--ink-soft);
}
.cover-top .filed b{color:var(--forest);font-weight:700}
.cover-head{
  display:grid;grid-template-columns:1.55fr .95fr;gap:26px;align-items:center;
}
.cover-lede .kicker{
  display:inline-block;font-family:var(--serif);font-weight:700;
  color:#fff;background:var(--rust-ink);
  font-size:13px;letter-spacing:.14em;
  padding:3px 12px;border-radius:3px;margin:0 0 16px;
}
.cover-lede h1{
  margin:0;font-family:var(--serif);font-weight:700;color:var(--forest-deep);
  font-size:clamp(2rem,5.6vw,4.1rem);line-height:1.18;letter-spacing:.01em;
}
/* 手書き風の下線（章見出しにも再利用） */
.u-mark{
  position:relative;white-space:nowrap;
}
.u-mark::after{
  content:"";position:absolute;left:-.06em;right:-.06em;bottom:-.1em;height:.4em;
  background:linear-gradient(transparent 60%,rgba(202,164,74,.55) 60%);
  background-repeat:no-repeat;
  border-radius:0 0 45% 55%/0 0 100% 100%;
  z-index:-1;pointer-events:none;
}
.cover-lede p.sub{
  margin:18px 0 0;color:var(--ink-soft);font-size:clamp(15px,1.4vw,17px);
  max-width:46ch;line-height:1.95;
}
.cover-lede .ctas{margin-top:22px;display:flex;flex-wrap:wrap;gap:12px}

/* 表紙の標本写真（角を留めたインスタント写真風） */
.cover-plate{position:relative}
.cover-plate figure{
  margin:0;background:#fff;padding:9px 9px 14px;
  border:1px solid var(--rule);border-radius:3px;
  box-shadow:0 14px 30px rgba(39,48,42,.18);
  transform:rotate(1.4deg);
}
.cover-plate figure img{
  width:100%;height:230px;object-fit:cover;border-radius:2px;
  filter:saturate(1.03);
}
.cover-plate figcaption{
  font-family:var(--serif);font-size:12.5px;color:var(--ink-soft);
  letter-spacing:.04em;padding:8px 2px 0;line-height:1.5;
}
.cover-plate figcaption b{color:var(--forest);font-weight:700;display:block}
/* マスキングテープ（装飾） */
.cover-plate .tape{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(-2deg);
  width:96px;height:24px;background:rgba(202,164,74,.42);
  border-left:1px dashed rgba(255,255,255,.6);border-right:1px dashed rgba(255,255,255,.6);
  box-shadow:0 2px 4px rgba(39,48,42,.12);
}

/* 採取メモ（表紙下の基本情報・観察手帖のチェック欄） */
.fieldnotes{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  margin-top:18px;border:1px solid var(--rule);border-radius:4px;
  overflow:hidden;background:var(--paper-2);
}
.fieldnotes div{padding:12px 16px;border-right:1px solid var(--rule)}
.fieldnotes div:last-child{border-right:none}
.fieldnotes span{display:block;font-size:11.5px;letter-spacing:.14em;color:var(--ink-soft)}
.fieldnotes strong{
  display:block;margin-top:3px;font-family:var(--serif);font-weight:700;
  color:var(--forest);font-size:15px;letter-spacing:.02em;
}

/* ============================================================
   ボタン
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-size:14.5px;font-weight:800;letter-spacing:.03em;text-decoration:none;
  padding:.85em 1.5em;border-radius:6px;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
}
.btn--solid{ background:var(--forest);color:#fff;box-shadow:0 10px 24px rgba(44,74,50,.26) }
.btn--solid:hover,.btn--solid:focus-visible{ transform:translateY(-2px);background:var(--forest-deep);box-shadow:0 16px 32px rgba(44,74,50,.32) }
.btn--ghost{ background:var(--card);color:var(--forest);border:1.5px solid var(--forest) }
.btn--ghost:hover,.btn--ghost:focus-visible{ background:var(--forest);color:#fff }
.btn small{font-weight:600;font-size:11px;opacity:.85;letter-spacing:.01em}
.is-disabled{
  display:inline-flex;align-items:center;
  font-size:13.5px;font-weight:700;color:var(--ink-soft);
  background:repeating-linear-gradient(135deg,rgba(39,48,42,.05) 0 7px,rgba(39,48,42,.02) 7px 14px);
  border:1.5px dashed var(--rule-strong);
  padding:.8em 1.4em;border-radius:6px;cursor:default;
}

/* ============================================================
   章の共通：見出し（手帖の章扉）
   巨大な算用数字の章番号＋大きな和文見出し＋引き出しリード
   ============================================================ */
.chapter{padding:64px 0 8px;position:relative}
.chapter-head{position:relative;max-width:760px}
.ch-no{
  display:flex;align-items:center;gap:14px;
  font-family:var(--serif);color:var(--rust);font-weight:700;
  font-size:14px;letter-spacing:.2em;margin:0 0 6px;
}
.ch-no .num{
  font-size:clamp(2.2rem,6vw,3.6rem);line-height:.8;color:var(--rust);
}
.ch-no .rule{flex:1;height:1px;background:var(--rule-strong);min-width:40px}
.chapter-head h2{
  margin:.1em 0 0;font-family:var(--serif);font-weight:700;color:var(--forest-deep);
  font-size:clamp(1.7rem,4.4vw,3rem);line-height:1.25;letter-spacing:.01em;
}
.chapter-head .lede{
  margin:16px 0 0;color:var(--ink-soft);font-size:clamp(15px,1.3vw,16.5px);
  line-height:1.95;max-width:60ch;
}

/* ============================================================
   §1 安心ポイント＝チェックリスト（観察手帖の確認欄）
   写真の脇に「引き出し線」で注釈を当てる原創レイアウト
   ============================================================ */
.assure{position:relative}
.assure-list{
  margin-top:30px;display:grid;gap:20px;
}
.assure-item{
  display:grid;grid-template-columns:300px 1fr;gap:0;
  background:var(--card);border:1px solid var(--rule);border-radius:8px;
  overflow:hidden;box-shadow:0 12px 30px rgba(39,48,42,.08);
}
.assure-item:nth-child(even){grid-template-columns:1fr 300px}
.assure-item:nth-child(even) .assure-photo{order:2}
.assure-photo{position:relative;min-height:220px;background:var(--paper-2)}
.assure-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* 標本番号の角ラベル */
.assure-photo .plate-no{
  position:absolute;left:10px;top:10px;z-index:2;
  font-family:var(--serif);font-size:12px;font-weight:700;letter-spacing:.1em;
  color:var(--forest-deep);background:rgba(251,248,240,.94);
  padding:3px 9px;border-radius:3px;border:1px solid var(--rule);
}
.assure-text{padding:24px 26px;position:relative}
/* チェックマーク（手描き風の丸） */
.assure-text .check{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--serif);font-weight:700;color:var(--forest);
  font-size:13px;letter-spacing:.1em;margin:0 0 6px;
}
.assure-text .check .box{
  width:22px;height:22px;flex:none;border:2px solid var(--forest);border-radius:5px;
  position:relative;background:rgba(202,164,74,.16);
}
.assure-text .check .box::after{
  content:"";position:absolute;left:4px;top:8px;width:6px;height:11px;
  border-right:3px solid var(--forest);border-bottom:3px solid var(--forest);
  transform:rotate(42deg);
}
.assure-text h3{
  margin:0;font-family:var(--serif);font-weight:700;color:var(--forest-deep);
  font-size:clamp(1.4rem,2.6vw,1.9rem);line-height:1.3;
}
.assure-text p{margin:11px 0 0;color:var(--ink);font-size:15px;line-height:1.9}
/* 引き出し線つきの手書き注釈 */
.annot{
  position:relative;margin-top:16px;padding-left:26px;
  font-family:var(--serif);font-size:13.5px;color:var(--rust-ink);
  line-height:1.7;
}
.annot::before{
  content:"";position:absolute;left:6px;top:2px;bottom:2px;width:0;
  border-left:2px dashed var(--rust);opacity:.6;
}
.annot::after{
  content:"";position:absolute;left:2px;top:-2px;width:9px;height:9px;
  border-radius:50%;border:2px solid var(--rust);background:var(--card);
}

/* ============================================================
   §2 設備＝標本図鑑（フィールドガイドの見開き）
   ============================================================ */
.facility{background:var(--paper-2);margin-top:56px;padding-bottom:8px;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.spec-grid{margin-top:30px;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.spec{
  background:var(--card);border:1px solid var(--rule);border-radius:8px;overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 12px 28px rgba(39,48,42,.08);
}
.spec-figure{position:relative;height:200px;background:var(--paper-2)}
.spec-figure img{width:100%;height:100%;object-fit:cover}
.spec-figure .lab{
  position:absolute;left:0;bottom:0;
  font-family:var(--serif);font-size:12px;font-weight:700;letter-spacing:.08em;
  color:#fff;background:rgba(31,53,37,.88);padding:5px 12px;border-radius:0 6px 0 0;
}
.spec-body{padding:18px 20px 22px;display:flex;flex-direction:column;flex:1}
.spec-body .stamp{
  align-self:flex-start;font-size:11.5px;font-weight:800;letter-spacing:.04em;
  color:var(--rust-ink);border:1.5px solid var(--rust);border-radius:4px;
  padding:3px 9px;margin:0 0 10px;
  transform:rotate(-1.2deg);
}
.spec-body h3{margin:0;font-family:var(--serif);font-weight:700;color:var(--forest-deep);font-size:1.4rem}
.spec-body p{margin:10px 0 0;color:var(--ink);font-size:14.5px;line-height:1.85;flex:1}

/* ============================================================
   §3 はじめての方へ＝順路（観察ルートの地図風）
   縦の道線に沿って番号入りの停留所が並ぶ
   ============================================================ */
.first{position:relative}
.route{
  margin-top:34px;position:relative;
  padding-left:8px;
}
/* 縦に走る点線の小道 */
.route::before{
  content:"";position:absolute;left:25px;top:8px;bottom:30px;width:0;
  border-left:3px dotted var(--sage);
}
.stop{
  position:relative;display:grid;grid-template-columns:52px 1fr;gap:18px;align-items:start;
  padding:0 0 26px;
}
.stop .pin{
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:700;font-size:20px;color:#fff;
  background:var(--forest);box-shadow:0 0 0 6px var(--paper),0 8px 18px rgba(44,74,50,.28);
  z-index:1;
}
.stop:nth-child(2) .pin{background:var(--rust-ink);box-shadow:0 0 0 6px var(--paper),0 8px 18px rgba(126,58,26,.28)}
.stop-card{
  background:var(--card);border:1px solid var(--rule);border-radius:8px;
  padding:16px 20px;box-shadow:0 8px 20px rgba(39,48,42,.06);
}
.stop-card h3{margin:0;font-family:var(--serif);font-weight:700;color:var(--forest-deep);font-size:1.2rem}
.stop-card p{margin:8px 0 0;color:var(--ink);font-size:14.5px;line-height:1.85}
.first-note{
  margin:6px 0 0 70px;font-family:var(--serif);font-size:14px;color:var(--rust-ink);
  position:relative;padding-left:22px;line-height:1.7;max-width:54ch;
}
.first-note::before{content:"✎";position:absolute;left:0;top:0;color:var(--rust)}

/* ============================================================
   §4 よくあるご質問＝Q&A の問答カード（表ではなくカード）
   ============================================================ */
.faq{background:var(--paper-2);margin-top:56px;padding-bottom:8px;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.qa-grid{margin-top:30px;display:grid;grid-template-columns:1fr 1fr;gap:18px}
.qa{
  background:var(--card);border:1px solid var(--rule);border-radius:8px;
  padding:20px 22px;position:relative;box-shadow:0 8px 20px rgba(39,48,42,.06);
}
.qa .q{
  display:grid;grid-template-columns:30px 1fr;gap:12px;align-items:start;
  font-family:var(--serif);font-weight:700;color:var(--forest-deep);
  font-size:16.5px;line-height:1.6;
}
.qa .a{
  display:grid;grid-template-columns:30px 1fr;gap:12px;align-items:start;
  margin-top:12px;padding-top:12px;border-top:1px dashed var(--rule-strong);
  color:var(--ink);font-size:14.5px;line-height:1.85;
}
.qa .mark{
  width:30px;height:30px;flex:none;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:700;font-size:16px;
}
.qa .q .mark{background:var(--forest);color:#fff}
.qa .a .mark{background:var(--rust-ink);color:#fff}
.qa--wide{grid-column:1 / -1}

/* ============================================================
   §5 料金＝罫線ノートの料金表（表ではなく行レイアウト）
   ============================================================ */
.price-sheet{
  margin-top:30px;background:var(--card);border:1px solid var(--rule);border-radius:8px;
  overflow:hidden;box-shadow:0 12px 30px rgba(39,48,42,.08);
}
.price-sheet .row{
  display:grid;grid-template-columns:200px auto 1fr;gap:20px;align-items:baseline;
  padding:18px 24px;border-bottom:1px solid var(--rule);
}
.price-sheet .row:last-child{border-bottom:none}
.price-sheet .name{font-family:var(--serif);font-weight:700;color:var(--forest-deep);font-size:1.15rem}
.price-sheet .amt{
  font-family:var(--serif);font-weight:700;color:var(--rust-ink);
  font-size:clamp(1.5rem,3vw,2rem);line-height:1;white-space:nowrap;
}
.price-sheet .desc{color:var(--ink-soft);font-size:14px;line-height:1.7}

/* ============================================================
   §6 アクセス
   ============================================================ */
.access-grid{margin-top:30px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.acc-card{
  background:var(--card);border:1px solid var(--rule);border-radius:8px;
  padding:22px 24px;box-shadow:0 8px 20px rgba(39,48,42,.06);
}
.acc-card .label{
  display:inline-block;font-family:var(--serif);font-weight:700;color:var(--forest);
  font-size:14px;letter-spacing:.06em;margin:0 0 10px;
  border-bottom:2px solid var(--honey);padding-bottom:3px;
}
.acc-card p,.acc-card address{margin:0;color:var(--ink);font-size:14.5px;line-height:1.85;font-style:normal}

/* 共通の仮置き注記 */
.notice{
  margin:18px 0 0;font-size:13px;color:var(--ink-soft);line-height:1.7;
  border-left:3px solid var(--sage);padding-left:12px;
}

/* ============================================================
   §7 予約・お問い合わせ（最終CTA）
   手帖の裏表紙＝森緑の地に、明るい文字（コントラスト確保）
   ============================================================ */
.reserve{margin-top:64px}
.reserve-inner{
  position:relative;background:var(--forest-deep);color:#f3eedd;border-radius:12px;
  padding:48px 40px;overflow:hidden;
  box-shadow:0 22px 50px rgba(31,53,37,.30);
}
/* 裏表紙の罫装飾 */
.reserve-inner::before{
  content:"";position:absolute;inset:14px;border:1px solid rgba(243,238,221,.22);border-radius:6px;pointer-events:none;
}
.reserve-inner .eyebrow{
  display:inline-block;font-family:var(--serif);font-weight:700;
  color:var(--forest-deep);background:var(--honey);
  font-size:13px;letter-spacing:.12em;padding:3px 12px;border-radius:3px;margin:0 0 16px;
}
.reserve-inner h2{
  margin:0;font-family:var(--serif);font-weight:700;color:#fbf8f0;
  font-size:clamp(1.7rem,4.2vw,2.8rem);line-height:1.3;
}
.reserve-inner p{
  margin:16px 0 0;color:#ece6d5;font-size:15.5px;line-height:1.95;max-width:60ch;
}
.reserve-inner .ctas{margin-top:26px;display:flex;flex-wrap:wrap;gap:14px}
.reserve-inner .btn--ghost{
  background:transparent;color:#fbf8f0;border-color:#cfc8b2;
}
.reserve-inner .btn--ghost:hover,.reserve-inner .btn--ghost:focus-visible{
  background:#fbf8f0;color:var(--forest-deep);
}
.reserve-inner .is-disabled{
  color:#ece6d5;border-color:rgba(243,238,221,.5);
  background:repeating-linear-gradient(135deg,rgba(243,238,221,.12) 0 7px,rgba(243,238,221,.04) 7px 14px);
}

/* ============================================================
   フッター
   ============================================================ */
.footer{margin-top:56px;background:var(--paper-2);border-top:1px solid var(--rule)}
.footer-inner{
  width:min(var(--maxw),calc(100% - 40px));margin:0 auto;padding:34px 0 44px;
  display:grid;grid-template-columns:auto 1fr;gap:8px 26px;align-items:start;
}
.footer-inner .fbrand{display:flex;align-items:center;gap:12px}
.footer-inner .fbrand img{width:128px;height:auto}
.footer-inner .fmeta{font-size:13px;color:var(--ink-soft);line-height:1.8}
.footer-inner .fmeta strong{display:block;font-family:var(--serif);color:var(--forest);font-size:15px;margin-bottom:2px}
.footer-inner address{font-style:normal;margin:4px 0}
.footer-inner .legal{margin-top:10px;font-size:11.5px;color:var(--ink-soft);line-height:1.8}

/* ============================================================
   REVEAL（控えめに立ち上がる）— JS が .seen を付与
   ※ 初期の非表示は JS 有効時（html.js）のみ。
     JS が無い・失敗した場合は全コンテンツを最初から可視に保つ。
   ============================================================ */
.js .reveal{opacity:0;transform:translateY(24px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}
.reveal.seen{opacity:1;transform:none}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width:900px){
  .cover-head{grid-template-columns:1fr;gap:22px}
  .cover-plate figure{transform:none}
  .fieldnotes{grid-template-columns:1fr 1fr}
  .fieldnotes div:nth-child(2){border-right:none}
  .spec-grid{grid-template-columns:1fr 1fr}
  .qa-grid{grid-template-columns:1fr}
  .qa--wide{grid-column:auto}
  .access-grid{grid-template-columns:1fr}
}
@media (max-width:620px){
  body{background-size:6px 6px,24px 24px,24px 24px}
  .cover-inner{padding:18px 16px 20px}
  .cover-top .brandmark img{width:108px}
  .fieldnotes{grid-template-columns:1fr 1fr}
  .assure-item,.assure-item:nth-child(even){grid-template-columns:1fr}
  .assure-item:nth-child(even) .assure-photo{order:0}
  .assure-photo{min-height:200px}
  .spec-grid{grid-template-columns:1fr}
  .price-sheet .row{grid-template-columns:1fr;gap:6px}
  .reserve-inner{padding:34px 22px}
}

/* ============================================================
   prefers-reduced-motion：全モーション無効＋静止で全表示
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal,.js .reveal{opacity:1 !important;transform:none !important}
}
