/* _shared.css — 結木町観光協会（sample42）固定ページ共通CSS
   index.html の設計システム（トークン・ヘッダー・フッター）を継承 */

:root{
  --ai:#1F5FA6;      /* メイン（地図机の藍鼠） */
  --ai2:#143B6B;     /* 深藍（ダーク帯・フッター） */
  --ai3:#2A6FB5;     /* ギャラリー地 */
  --kami:#FFFDF7;    /* 地図紙（明部背景） */
  --kami2:#F2F5FA;   /* ソフト背景 */
  --paper:#FFFFFF;   /* カード紙面 */
  --shu:#E5392B;     /* アクセント（ピン朱） */
  --yama:#F2B100;    /* 補助（山吹） */
  --yama2:#FFD45E;   /* 淡い山吹（暗部の強調） */
  --ink:#16263B;     /* 見出し */
  --body:#3A4250;    /* 本文 */
  --muted:#7C8595;   /* 注釈 */
  --line:#E2E8F0;    /* 罫線 */
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; background:var(--kami); color:var(--body); font-family:'Zen Kaku Gothic New',sans-serif; font-size:16px; line-height:1.9; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
img{ max-width:100%; display:block; }
a{ color:inherit; }
.mincho{ font-family:'Shippori Mincho',serif; }
.mono{ font-family:'Space Grotesk',monospace; letter-spacing:.05em; }
.wrap{ width:min(1120px,calc(100% - 48px)); margin:0 auto; }
.sec-eyebrow{ font-family:'Space Grotesk',monospace; font-size:11.5px; letter-spacing:.3em; text-transform:uppercase; color:var(--shu); display:inline-flex; align-items:center; gap:10px; }
.sec-eyebrow::before{ content:""; width:10px; height:14px; background:var(--shu); clip-path:polygon(50% 100%, 8% 38%, 18% 12%, 50% 0, 82% 12%, 92% 38%); }
.sec-h2{ font-family:'Shippori Mincho',serif; font-weight:700; font-size:clamp(26px,3.8vw,44px); line-height:1.5; color:var(--ink); margin:14px 0 0; word-break:auto-phrase; text-wrap:balance; }
.sec-lead{ font-size:15px; color:var(--muted); margin:16px 0 0; max-width:36em; word-break:auto-phrase; }
.route-rule{ height:14px; background-image:linear-gradient(90deg, var(--shu) 0 6px, transparent 6px 100%), repeating-linear-gradient(90deg, var(--muted) 0 10px, transparent 10px 22px); background-size:6px 6px, 100% 2px; background-position:left center, left center; background-repeat:no-repeat, repeat-x; opacity:.45; }
h1,h2,h3,.btn,summary{ word-break:auto-phrase; text-wrap:balance; }

/* ============ header（header-10 告知マーキー＋megamenu-05 を統合再実装） ============ */
.c-notice{ background:var(--shu); color:#FBF3E8; overflow:hidden; position:relative; }
.c-notice__belt{ display:flex; width:max-content; animation:c-notice-run 26s linear infinite; }
.c-notice:hover .c-notice__belt{ animation-play-state:paused; }
.c-notice__item{ display:inline-flex; align-items:center; gap:10px; padding:8px 26px; font-size:12.5px; letter-spacing:.12em; white-space:nowrap; }
.c-notice__item b{ font-weight:700; }
.c-notice__dot{ width:5px; height:5px; border-radius:50%; background:rgba(251,243,232,.7); }
@keyframes c-notice-run{ to{ transform:translateX(-50%); } }
.c-header{ position:sticky; top:0; z-index:60; background:rgba(248,243,230,.95); backdrop-filter:blur(8px); border-bottom:1px solid var(--line); }
.c-header__in{ max-width:1240px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:22px; padding:13px 26px; }
.c-header__logo{ display:inline-flex; align-items:center; text-decoration:none; }
.c-header__logo img{ height:44px; width:auto; }
.c-header__nav{ display:flex; gap:24px; }
.c-header__nav a{ color:var(--ink); text-decoration:none; font-size:14px; font-weight:700; white-space:nowrap; position:relative; padding:6px 0; }
.c-header__nav a::after{ content:""; position:absolute; left:50%; bottom:-4px; width:4px; height:4px; border-radius:50%; background:var(--shu); transform:translateX(-50%) scale(0); transition:transform .22s; }
.c-header__nav a:hover::after, .c-header__nav a[aria-expanded="true"]::after{ transform:translateX(-50%) scale(1); }
.c-header__cta{ display:inline-flex; align-items:center; gap:8px; background:var(--ai); color:var(--kami); font-weight:700; font-size:13.5px; padding:12px 22px; border-radius:999px; text-decoration:none; transition:background .25s; }
.c-header__cta:hover{ background:var(--shu); }
.c-header__cta .b{ font-family:'Space Grotesk',monospace; font-size:10px; letter-spacing:.14em; background:var(--shu); border-radius:999px; padding:2px 9px; }
.c-header__menu{ display:none; width:44px; height:44px; border:1px solid var(--line); border-radius:10px; background:transparent; cursor:pointer; flex-direction:column; align-items:center; justify-content:center; gap:6px; }
.c-header__menu span{ display:block; width:20px; height:2px; background:var(--ink); transition:.25s; }
/* メガメニュー（写真カード4枚＋全リンク帯） */
.c-mega{ position:absolute; left:0; top:100%; width:100%; background:var(--paper); border-top:1px solid var(--line); box-shadow:0 34px 56px -32px rgba(34,48,74,.4); display:none; }
.c-mega.is-open{ display:block; }
.c-mega__in{ max-width:1240px; margin:0 auto; padding:24px 26px 0; }
.c-mega__cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.c-mega__card{ position:relative; display:block; aspect-ratio:4/3.1; overflow:hidden; border-radius:10px; text-decoration:none; }
.c-mega__ph{ position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .8s cubic-bezier(.22,1,.36,1); }
.c-mega__card:hover .c-mega__ph{ transform:scale(1.06); }
.c-mega__card::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,26,38,0) 36%,rgba(20,26,38,.74) 100%); }
.c-mega__tx{ position:absolute; left:14px; right:14px; bottom:12px; color:#fff; z-index:2; }
.c-mega__tx .no{ font-family:'Space Grotesk',monospace; font-size:9px; letter-spacing:.24em; color:var(--yama2); display:block; margin-bottom:4px; }
.c-mega__tx b{ font-family:'Shippori Mincho',serif; font-size:17px; letter-spacing:.08em; display:block; font-weight:700; }
.c-mega__tx small{ font-size:10.5px; opacity:.85; }
.c-mega__allrow{ display:flex; align-items:center; gap:6px 22px; flex-wrap:wrap; border-top:1px solid var(--line); margin-top:20px; padding:13px 0 15px; }
.c-mega__lb{ font-family:'Space Grotesk',monospace; font-size:9.5px; letter-spacing:.22em; color:var(--muted); }
.c-mega__allrow a{ color:var(--ink); text-decoration:none; font-size:12.5px; font-weight:700; }
.c-mega__allrow a:hover{ color:var(--shu); text-decoration:underline; }
/* SPフルスクリーンメニュー */
.c-spnav{ position:fixed; inset:0; z-index:80; background:rgba(20,59,107,.97); color:var(--kami); display:none; flex-direction:column; justify-content:center; padding:60px 34px; }
.c-spnav.is-open{ display:flex; }
.c-spnav a{ color:var(--kami); text-decoration:none; font-family:'Shippori Mincho',serif; font-size:24px; font-weight:600; padding:13px 0; border-bottom:1px solid rgba(245,239,223,.16); display:flex; align-items:baseline; gap:14px; }
.c-spnav a .no{ font-family:'Space Grotesk',monospace; font-size:11px; color:var(--yama2); letter-spacing:.2em; }
.c-spnav__tel{ margin-top:26px; font-family:'Space Grotesk',monospace; font-size:13px; letter-spacing:.12em; color:rgba(245,239,223,.75); }
.c-spnav__close{ position:absolute; top:18px; right:18px; width:44px; height:44px; border:1px solid rgba(245,239,223,.4); border-radius:50%; background:transparent; color:var(--kami); font-size:18px; cursor:pointer; }
body.is-locked{ overflow:hidden; }
@media(max-width:1080px){ .c-header__nav, .c-header__cta{ display:none; } .c-header__menu{ display:flex; } }

/* ============ footer（footer-01 大型ダーク・c-footer） ============ */
.c-footer{ background:var(--ai2); color:#ECEEF2; position:relative; overflow:hidden; }
.c-footer::before{ content:""; position:absolute; inset:0; pointer-events:none; opacity:.5; background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px); background-size:26px 26px; -webkit-mask-image:linear-gradient(180deg,#000,transparent 60%); mask-image:linear-gradient(180deg,#000,transparent 60%); }
.c-footer__top{ position:relative; max-width:1200px; margin:0 auto; display:grid; grid-template-columns:1.3fr 2fr; gap:50px; padding:80px 32px 50px; }
.c-footer__nm{ font-family:'Shippori Mincho',serif; font-weight:700; font-size:26px; letter-spacing:.08em; }
.c-footer__nm small{ display:block; font-family:'Space Grotesk',monospace; font-size:10px; letter-spacing:.26em; color:rgba(236,238,242,.55); margin-top:8px; }
.c-footer__brand p{ color:#9AA4B2; font-size:13.5px; max-width:24em; margin:18px 0 24px; line-height:1.9; }
.c-footer__sns{ display:flex; gap:12px; }
.c-footer__sns a{ width:40px; height:40px; border:1px solid rgba(255,255,255,.16); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#ECEEF2; text-decoration:none; transition:.2s; }
.c-footer__sns a:hover{ background:var(--yama); color:var(--ai2); border-color:var(--yama); }
.c-footer__sns svg{ width:18px; height:18px; fill:currentColor; }
.c-footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.c-footer__col h4{ font-family:'Space Grotesk',monospace; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--yama2); margin:0 0 16px; }
.c-footer__col a{ display:block; color:#ECEEF2; text-decoration:none; font-size:14px; padding:7px 0; opacity:.85; transition:.2s; }
.c-footer__col a:hover{ opacity:1; padding-left:6px; color:var(--yama2); }
.c-footer__col .nap{ font-size:13px; color:#9AA4B2; line-height:2; }
.c-footer__bottom{ position:relative; border-top:1px solid rgba(255,255,255,.12); }
.c-footer__bin{ max-width:1200px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; padding:22px 32px; flex-wrap:wrap; gap:12px; }
.c-footer__cp{ font-family:'Space Grotesk',monospace; font-size:12px; color:#9AA4B2; letter-spacing:.04em; }
.c-footer__legal{ display:flex; gap:22px; }
.c-footer__legal a{ color:#9AA4B2; text-decoration:none; font-size:12px; }
.c-footer__legal a:hover{ color:#ECEEF2; }
@media(max-width:820px){ .c-footer__top{ grid-template-columns:1fr; gap:36px; } .c-footer__cols{ grid-template-columns:1fr 1fr; } }
@media (prefers-reduced-motion: reduce){ .c-notice__belt{ animation:none; } .c-cta__sheen{ display:none; } }

/* ============ 固定ページ共通コンポーネント ============ */
.page-hero{ position:relative; background:linear-gradient(160deg,#2A6FB5,var(--ai2)); color:#F1F4EF; padding:84px 0 66px; overflow:hidden; }
.page-hero::before{ content:""; position:absolute; inset:0; pointer-events:none; opacity:.35;
  background-image:repeating-linear-gradient(90deg, rgba(245,239,223,.07) 0 1px, transparent 1px 90px), repeating-linear-gradient(0deg, rgba(245,239,223,.07) 0 1px, transparent 1px 90px); }
.page-hero::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:5px; background:linear-gradient(90deg,var(--shu),var(--yama)); }
.page-hero .wrap{ position:relative; z-index:3; }
.page-hero::before{ z-index:2; }
/* 固定ページ見出しヘッダー：右→左に流れる背景ギャラリー＋カラーオーバーレイ */
.page-hero__bg{ position:absolute; inset:0; z-index:0; overflow:hidden; display:flex; align-items:center; }
.page-hero__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(105deg, rgba(20,59,107,.90) 0%, rgba(31,95,166,.78) 50%, rgba(20,59,107,.90) 100%); }
.page-hero__mq{ display:flex; width:max-content; height:100%; will-change:transform; animation:page-hero-mq 64s linear infinite; }
.page-hero__mq img{ height:100%; width:auto; aspect-ratio:4/3; object-fit:cover; display:block; flex:0 0 auto; }
@keyframes page-hero-mq{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .page-hero__mq{ animation:none; } }

/* ============ 投稿（single）ページ ============ */
.post-hero{ position:relative; overflow:hidden; color:#F1F4EF; padding:104px 0 70px; }
.post-hero__bg{ position:absolute; inset:0; z-index:0; }
.post-hero__bg img{ width:100%; height:100%; object-fit:cover; display:block; }
.post-hero__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(160deg, rgba(20,59,107,.74) 0%, rgba(15,40,80,.92) 100%); }
.post-hero::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:5px; background:linear-gradient(90deg,var(--shu),var(--yama)); z-index:2; }
.post-hero .wrap{ position:relative; z-index:1; max-width:860px; }
.post-hero__meta{ display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.post-hero__date{ font-family:'Space Grotesk',monospace; font-size:13px; letter-spacing:.06em; color:rgba(241,244,239,.82); }
.post-hero__cat{ font-size:11px; font-weight:700; letter-spacing:.08em; padding:4px 12px; border-radius:999px; color:#fff; }
.post-hero__cat.is-event{ background:var(--shu); }
.post-hero__cat.is-guide{ background:var(--ai); }
.post-hero__cat.is-trail{ background:#5f8a5a; }
.post-hero__cat.is-map{ background:var(--yama); color:var(--ai2); }
.post-hero__cat.is-info{ background:#7c7464; }
.post-hero h1{ font-family:'Shippori Mincho',serif; font-weight:800; font-size:clamp(25px,3.8vw,40px); line-height:1.55; letter-spacing:.04em; margin:0; color:#F6F8F4; }
.post-hero .crumb{ font-family:'Space Grotesk',monospace; font-size:10.5px; letter-spacing:.18em; color:rgba(241,244,239,.6); margin:24px 0 0; }
.post-hero .crumb a{ color:rgba(241,244,239,.82); text-decoration:none; }
/* 投稿レイアウト：本文 + サイドバー（ウィジェット） */
.post-wrap{ display:grid; grid-template-columns:minmax(0,1fr) 312px; gap:52px; max-width:1140px; margin:0 auto; padding:56px 24px 96px; align-items:start; }
.post-main{ min-width:0; }
.post-figure{ margin:0 0 36px; }
.post-figure img{ width:100%; border-radius:14px; box-shadow:0 24px 50px -28px rgba(20,30,46,.5); display:block; }
.post-body p{ font-size:15.5px; line-height:2.05; color:var(--body); margin:0 0 1.7em; }
.post-body h2{ font-family:'Shippori Mincho',serif; font-size:clamp(19px,2.6vw,26px); font-weight:700; color:var(--ink); line-height:1.6; margin:2.4em 0 .9em; padding-left:16px; border-left:4px solid var(--yama); }
.post-body a{ color:var(--shu); font-weight:700; }
.post-body .post-lead{ font-size:16.5px; color:var(--ink); line-height:2; margin-bottom:1.9em; }
.post-foot{ margin:44px 0 0; }
.post-foot__bar{ border-top:1px solid var(--line); padding-top:28px; display:flex; gap:16px; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.post-foot__back{ display:inline-flex; align-items:center; gap:8px; text-decoration:none; font-weight:700; font-size:14px; color:var(--ink); }
.post-foot__back:hover{ color:var(--shu); }
.post-foot__cta{ display:inline-block; background:var(--ai); color:var(--kami); font-weight:700; font-size:13.5px; padding:12px 26px; border-radius:999px; text-decoration:none; transition:background .25s; }
.post-foot__cta:hover{ background:var(--shu); }
/* サイドバー・ウィジェット */
.post-side{ position:sticky; top:88px; display:flex; flex-direction:column; gap:26px; }
.widget{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:22px 22px 24px; }
.widget__ttl{ font-family:'Shippori Mincho',serif; font-size:16px; font-weight:700; color:var(--ink); margin:0 0 16px; padding-left:12px; border-left:4px solid var(--yama); letter-spacing:.04em; }
.w-search{ display:flex; gap:8px; }
.w-search input{ flex:1; min-width:0; border:1px solid var(--line); border-radius:8px; padding:10px 12px; font-size:13.5px; font-family:inherit; background:var(--kami2); }
.w-search button{ border:none; background:var(--ai); color:#fff; border-radius:8px; padding:0 16px; font-weight:700; cursor:pointer; }
.w-recent{ display:flex; flex-direction:column; gap:14px; }
.w-recent a{ display:grid; grid-template-columns:70px 1fr; gap:12px; align-items:center; text-decoration:none; color:inherit; }
.w-recent img{ width:70px; height:48px; object-fit:cover; border-radius:7px; display:block; }
.w-recent div{ min-width:0; }
.w-recent b{ font-family:'Shippori Mincho',serif; font-weight:700; font-size:13px; line-height:1.5; color:var(--ink); display:block; }
.w-recent span{ font-family:'Space Grotesk',monospace; font-size:10.5px; color:var(--muted); letter-spacing:.06em; }
.w-recent a:hover b{ color:var(--shu); }
.w-list{ list-style:none; margin:0; padding:0; }
.w-list li{ border-bottom:1px dashed var(--line); }
.w-list li:last-child{ border-bottom:none; }
.w-list a{ display:flex; justify-content:space-between; align-items:center; gap:10px; padding:10px 2px; text-decoration:none; color:var(--ink); font-size:13.5px; font-weight:500; }
.w-list a:hover{ color:var(--shu); }
.w-list .n{ font-family:'Space Grotesk',monospace; font-size:11px; color:var(--muted); background:var(--kami2); border-radius:999px; padding:2px 9px; }
.w-cta{ background:linear-gradient(160deg,#2A6FB5,var(--ai2)); border:none; color:#F1F4EF; }
.w-cta .widget__ttl{ color:#fff; border-color:var(--yama2); }
.w-cta p{ font-size:13px; line-height:1.85; color:rgba(241,244,239,.82); margin:0 0 16px; }
.w-cta a{ display:inline-block; background:var(--yama2); color:var(--ai2); font-weight:700; font-size:13.5px; padding:12px 28px; border-radius:999px; text-decoration:none; }
.w-cta a:hover{ background:#fff; }
@media(max-width:900px){ .post-wrap{ grid-template-columns:1fr; gap:40px; padding:44px 22px 72px; } .post-side{ position:static; } }
@media(max-width:680px){ .post-hero{ padding:84px 0 52px; } }
.page-hero .sec-eyebrow{ color:var(--yama2); } .page-hero .sec-eyebrow::before{ background:var(--yama2); }
.page-hero h1{ font-family:'Shippori Mincho',serif; font-size:clamp(28px,4.4vw,44px); font-weight:700; color:#F1F4EF; margin:14px 0 0; letter-spacing:.06em; line-height:1.5; word-break:auto-phrase; text-wrap:balance; }
.page-hero p{ color:rgba(241,244,239,.78); font-size:14.5px; margin:16px 0 0; max-width:38em; }
.page-hero .crumb{ font-family:'Space Grotesk',monospace; font-size:10.5px; letter-spacing:.18em; color:rgba(241,244,239,.55); margin:22px 0 0; }
.page-hero .crumb a{ color:rgba(241,244,239,.8); text-decoration:none; }
@media(max-width:680px){ .page-hero{ padding:60px 0 48px; } }

.page-sec{ padding:92px 0; }
.page-sec--soft{ background:var(--kami2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.page-sec--paper{ background:rgba(255,255,255,.5); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.page-sec .lead{ font-size:15px; color:var(--body); max-width:42em; margin:18px 0 0; }
@media(max-width:680px){ .page-sec{ padding:64px 0; } }

/* コースカード */
.p-course{ display:grid; grid-template-columns:minmax(0,460px) 1fr; gap:40px; align-items:start; margin-top:52px; padding-top:52px; border-top:1px dashed var(--line); }
.p-course:first-of-type{ border-top:none; padding-top:0; }
.p-course__ph{ position:relative; }
.p-course__ph img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:12px; box-shadow:0 24px 44px -26px rgba(34,48,74,.5); }
.p-course__tag{ position:absolute; left:14px; top:14px; background:var(--shu); color:#FBF3E8; font-family:'Space Grotesk',monospace; font-size:10px; letter-spacing:.2em; padding:6px 12px; border-radius:4px; }
.p-course h3{ font-family:'Shippori Mincho',serif; font-size:clamp(20px,2.4vw,26px); color:var(--ink); margin:0 0 6px; line-height:1.6; }
.p-course__meta{ font-family:'Space Grotesk',monospace; font-size:11px; letter-spacing:.16em; color:var(--shu); margin:0 0 16px; }
.p-course__stops{ list-style:none; margin:18px 0 0; padding:0; }
.p-course__stops li{ position:relative; padding:10px 0 10px 30px; font-size:14px; border-bottom:1px solid var(--line); }
.p-course__stops li::before{ content:""; position:absolute; left:8px; top:18px; width:9px; height:9px; border-radius:50% 50% 50% 0; background:var(--shu); transform:rotate(-45deg); }
.p-course__stops li b{ color:var(--ink); }
.p-course__stops li small{ color:var(--muted); display:block; font-size:12px; }
@media(max-width:880px){ .p-course{ grid-template-columns:1fr; gap:24px; } }

/* 2カラム（写真＋テキスト） */
.p-duo{ display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center; margin-top:52px; }
.p-duo img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:12px; box-shadow:0 24px 44px -26px rgba(34,48,74,.5); }
.p-duo h3{ font-family:'Shippori Mincho',serif; font-size:clamp(19px,2.2vw,24px); color:var(--ink); margin:0 0 14px; line-height:1.7; }
.p-duo p{ font-size:14.5px; margin:0 0 14px; }
@media(max-width:880px){ .p-duo{ grid-template-columns:1fr; gap:26px; } }

/* 概要テーブル */
.p-table{ width:100%; border-collapse:collapse; margin-top:40px; background:var(--paper); border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.p-table th,.p-table td{ text-align:left; padding:18px 22px; border-bottom:1px solid var(--line); font-size:14.5px; vertical-align:top; }
.p-table tr:last-child th,.p-table tr:last-child td{ border-bottom:none; }
.p-table th{ width:200px; background:var(--kami2); font-family:'Shippori Mincho',serif; font-weight:600; color:var(--ink); white-space:nowrap; }
@media(max-width:680px){ .p-table th{ width:110px; padding:14px; } .p-table td{ padding:14px; } }

/* FAQ（一覧ページ） */
.p-faqcat{ font-family:'Shippori Mincho',serif; font-size:clamp(19px,2.2vw,24px); color:var(--ink); margin:64px 0 8px; padding-left:16px; border-left:4px solid var(--shu); }
.p-faqcat:first-of-type{ margin-top:44px; }
.p-qa{ border-bottom:1px solid var(--line); padding:26px 0; }
.p-qa .q{ display:flex; gap:14px; align-items:baseline; }
.p-qa .q .qn{ font-family:'Shippori Mincho',serif; font-size:26px; color:var(--shu); line-height:1; flex:0 0 auto; }
.p-qa .q p{ font-family:'Shippori Mincho',serif; font-size:clamp(16px,1.9vw,19px); font-weight:600; margin:0; color:var(--ink); word-break:auto-phrase; }
.p-qa .a{ margin:12px 0 0 40px; font-size:14.5px; color:var(--body); word-break:auto-phrase; }
.p-qa .a a{ color:var(--ai); font-weight:700; }

/* お問い合わせ */
.p-contact{ display:grid; grid-template-columns:1fr 1.2fr; gap:52px; align-items:start; margin-top:48px; }
@media(max-width:880px){ .p-contact{ grid-template-columns:1fr; } }
.p-info{ background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:32px; }
.p-info h3{ font-family:'Shippori Mincho',serif; font-size:19px; color:var(--ink); margin:0 0 16px; }
.p-info p{ font-size:14px; margin:0 0 12px; }
.p-info .tel{ font-family:'Space Grotesk',monospace; font-size:26px; font-weight:700; color:var(--ai); letter-spacing:.04em; display:block; text-decoration:none; margin:6px 0; }
.p-info .map{ margin-top:20px; aspect-ratio:4/3; border-radius:10px; overflow:hidden; position:relative; }
.p-info .map img{ width:100%; height:100%; object-fit:cover; }
.p-info .map span{ position:absolute; left:12px; bottom:12px; background:rgba(20,59,107,.85); color:#F1F4EF; font-size:11px; padding:6px 12px; border-radius:5px; }
.p-form{ background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:36px; }
.p-form h3{ font-family:'Shippori Mincho',serif; font-size:19px; color:var(--ink); margin:0 0 8px; }
.p-form .note{ font-size:12.5px; color:var(--muted); margin:0 0 24px; }
.p-form label{ display:block; font-weight:700; font-size:13.5px; color:var(--ink); margin:20px 0 8px; }
.p-form label small{ font-weight:400; color:var(--shu); margin-left:8px; font-size:11px; }
.p-form input,.p-form select,.p-form textarea{ width:100%; box-sizing:border-box; padding:13px 14px; border:1px solid var(--line); border-radius:8px; background:#fff; font-family:inherit; font-size:15px; color:var(--body); }
.p-form input:focus,.p-form select:focus,.p-form textarea:focus{ outline:2px solid var(--ai); outline-offset:1px; }
.p-form button{ margin-top:28px; width:100%; padding:16px; background:var(--ai); color:var(--kami); font-family:inherit; font-weight:700; font-size:15.5px; border:none; border-radius:10px; cursor:pointer; transition:background .25s; }
.p-form button:hover{ background:var(--shu); }
.p-form .privacy-note{ font-size:12px; color:var(--muted); margin-top:14px; }
.p-form .privacy-note a{ color:var(--ai); }

/* プライバシー */
.p-legal h2{ font-family:'Shippori Mincho',serif; font-size:clamp(18px,2vw,22px); color:var(--ink); margin:48px 0 14px; padding-bottom:10px; border-bottom:1px solid var(--line); }
.p-legal p,.p-legal li{ font-size:14.5px; color:var(--body); }
.p-legal ul{ padding-left:22px; }
.p-legal .date{ color:var(--muted); font-size:13px; margin-top:48px; }

/* ページ下CTA帯 */
.p-cta{ background:linear-gradient(160deg,#2A6FB5,var(--ai2)); color:#F1F4EF; padding:74px 0; text-align:center; }
.p-cta h2{ font-family:'Shippori Mincho',serif; font-size:clamp(22px,3vw,32px); font-weight:700; margin:0 0 12px; line-height:1.6; }
.p-cta p{ color:rgba(241,244,239,.78); font-size:14px; margin:0 0 28px; }
.p-cta .btns{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.p-cta a{ display:inline-block; padding:15px 40px; border-radius:999px; text-decoration:none; font-weight:700; font-size:14.5px; }
.p-cta a.main{ background:var(--yama2); color:var(--ai2); }
.p-cta a.main:hover{ background:#fff; }
.p-cta a.sub{ border:1.5px solid rgba(241,244,239,.6); color:#F1F4EF; }
.p-cta a.sub:hover{ background:rgba(255,255,255,.12); }
