/* =====================================================================
   サンプル聖書教会（LeadChat デモ）
   方向性：kita9-church.com（TCD「Cure」）の質感に寄せた、静謐で上品なトーン
   - 白基調 ＋ 薄グレー #f5f5f5 の区切り
   - アクセントは水色シアン #1bb4e7（kita9 と同系）
   - Noto Sans JP は 400/500/600 の細め中心（見出しは濃紺）／御言葉は明朝
   - 直線の罫線区切り・影ひかえめ・角丸控えめ・写真背景を主役に
   ※ 架空の無宗派プロテスタント教会・全コンテンツはオリジナルのダミーです
   ※ 変数名は sample-kids と共通（--blue-* / --orange-*）。値のみ教会向けにリカラー
   ===================================================================== */

:root{
  /* primary accent = 水色シアン（kita9 #1bb4e7 系） */
  --blue-900:#1f3148;   /* deep navy（見出し・フッター・CTA） */
  --blue-800:#26405b;
  --blue-700:#1bb4e7;   /* accent cyan（リンク・ラベル・強調） */
  --blue-600:#14a1e2;
  --blue-400:#7fd3f0;
  --blue-100:#d6eef9;
  --blue-50:#eef7fb;

  --orange-600:#0f9fce;  /* accent dark（hover） */
  --orange-500:#1bb4e7;  /* CTA fill cyan */
  --orange-100:#eef7fb;

  --ink:#4c4c4c;        /* 本文（kita9 と同じやわらかい濃灰） */
  --ink-soft:#5d6770;
  --muted:#8a939b;
  --head:#1f3148;       /* 見出しの濃紺 */
  --line:#e6e6e6;
  --bg:#ffffff;
  --bg-soft:#f5f5f5;

  --maxw:1120px;
  --radius:6px;
  --radius-sm:4px;
  --shadow-sm:0 1px 2px rgba(31,49,72,.05);
  --shadow-md:0 10px 30px rgba(31,49,72,.10);
  --ease:cubic-bezier(.4,0,.2,1);

  --font:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Segoe UI",
         "Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  --serif:"Noto Serif JP","Hiragino Mincho ProN","Yu Mincho",serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  line-height:2;font-size:15px;font-weight:400;letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px;}
.container-narrow{max-width:780px;}
.section{padding:84px 0;position:relative;}
.section.soft{background:var(--bg-soft);}
.section.blue{background:var(--blue-50);}
.center{text-align:center;}

/* ---------- Wave dividers は kita9 に合わせて廃止（直線区切りに） ---------- */
.wave{display:none;}

/* ---------- Section heading（英語ラベル＋日本語＋短いアクセント線） ---------- */
.eyebrow{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.28em;color:var(--blue-700);margin:0 0 14px;}
.eyebrow.on-orange{color:var(--orange-600);}
.section-title{font-size:clamp(21px,4.4vw,30px);line-height:1.7;font-weight:600;color:var(--head);margin:0 0 18px;letter-spacing:.06em;}
.section-title .accent{color:var(--blue-700);}
.section-lead{font-size:14.5px;line-height:2.1;color:var(--ink-soft);margin:0;}
.section-head{margin-bottom:48px;}
.section-head.center{text-align:center;}
.section-head.center .section-lead{max-width:620px;margin:0 auto;}
.section-head.center .section-title{margin-bottom:0;}
.section-head.center .section-title::after{content:"";display:block;width:42px;height:2px;background:var(--blue-700);margin:22px auto 0;}
.section-head.center .section-lead{margin-top:22px;}

/* ---------- Buttons（直線的・細め・レター間隔） ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:600;font-size:14px;letter-spacing:.08em;
  padding:15px 34px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;
  transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);}
.btn svg{width:17px;height:17px;}
.btn-primary{background:var(--blue-900);color:#fff;}
.btn-primary:hover{background:#16263a;}
.btn-orange{background:var(--orange-500);color:#fff;}
.btn-orange:hover{background:var(--orange-600);}
.btn-outline{background:transparent;border-color:#cdd5dc;color:var(--head);}
.btn-outline:hover{border-color:var(--blue-700);color:var(--blue-700);}
.btn-white{background:#fff;color:var(--head);border-color:#fff;}
.btn-white:hover{background:transparent;color:#fff;border-color:rgba(255,255,255,.7);}
.btn-lg{padding:17px 40px;font-size:15px;}
.btn-block{width:100%;}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);
  backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px;}
.brand{display:flex;align-items:center;gap:11px;font-weight:600;font-size:16px;color:var(--head);letter-spacing:.04em;}
.brand .mark{width:34px;height:34px;border-radius:50%;flex:0 0 auto;
  background:var(--blue-700);display:grid;place-items:center;color:#fff;}
.brand .mark svg{width:18px;height:18px;}
.brand .logo-img{width:38px;height:38px;flex:0 0 auto;display:block;object-fit:contain;}
.brand small{display:block;font-size:9px;font-weight:500;letter-spacing:.18em;color:var(--muted);line-height:1.2;margin-top:2px;}
.brand .brand-name{line-height:1.25;}

.nav-toggle{background:none;border:0;cursor:pointer;padding:8px;display:block;}
.nav-toggle span{display:block;width:24px;height:1.5px;background:var(--head);margin:6px 0;border-radius:2px;transition:.3s;}

.nav-links,.nav-links ul{list-style:none;margin:0;padding:0;}
.nav-actions .btn{display:none;}

/* drawer (mobile default) */
.nav-links{position:fixed;inset:64px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-md);display:none;flex-direction:column;padding:8px 0;max-height:calc(100vh - 64px);overflow:auto;}
.nav.open .nav-links{display:flex;}
.nav-links>li>a{display:block;padding:14px 22px;font-size:14.5px;font-weight:500;color:var(--head);border-bottom:1px solid var(--bg-soft);letter-spacing:.04em;}
.nav-links .submenu{background:var(--bg-soft);}
.nav-links .submenu a{display:block;padding:11px 22px 11px 36px;font-size:13px;font-weight:400;color:var(--ink-soft);border-bottom:1px solid #fff;}
.nav-links a.active{color:var(--blue-700);}
.nav-links .group-label{display:none;}

/* desktop nav */
@media (min-width:1000px){
  .nav{height:74px;}
  .nav-toggle{display:none;}
  .nav-links{position:static;display:flex;flex-direction:row;align-items:center;gap:32px;
    background:none;box-shadow:none;border:0;padding:0;max-height:none;overflow:visible;}
  .nav-links>li{position:relative;}
  .nav-links>li>a{padding:26px 0;border:0;font-size:13.5px;font-weight:500;color:var(--head);position:relative;letter-spacing:.06em;}
  .nav-links>li>a:hover,.nav-links>li>a.active{color:var(--blue-700);}
  .nav-links>li>a.active::after,.nav-links>li>a:hover::after{content:"";position:absolute;left:0;right:0;bottom:18px;height:1.5px;background:var(--blue-700);}
  .nav-links .has-sub>a{padding-right:15px;}
  .nav-links .has-sub>a::before{content:"";position:absolute;right:0;top:50%;width:5px;height:5px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:translateY(-70%) rotate(45deg);opacity:.5;}
  .nav-links .submenu{position:absolute;top:64px;left:50%;transform:translateX(-50%) translateY(6px);min-width:210px;
    background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:8px;
    opacity:0;visibility:hidden;transition:opacity .18s var(--ease),transform .18s var(--ease);}
  .nav-links .has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
  .nav-links .submenu::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px;}
  .nav-links .submenu a{display:block;padding:10px 14px;font-size:13px;font-weight:500;color:var(--ink-soft);border:0;border-radius:var(--radius-sm);white-space:nowrap;}
  .nav-links .submenu a:hover,.nav-links .submenu a.active{background:var(--blue-50);color:var(--blue-700);}
  .nav-actions .btn{display:inline-flex;}
  .brand{font-size:17px;}
}

/* ---------- Hero（全幅写真背景＋オーバーレイ） ---------- */
.hero{position:relative;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:linear-gradient(150deg,#33495f,#1f3148 70%);
  display:grid;place-items:center;}
.hero-bg::after{content:"";position:absolute;inset:0;background:rgba(20,32,48,.42);}
.hero-bg .ph-label{position:relative;z-index:1;font-size:12px;letter-spacing:.18em;color:rgba(255,255,255,.42);}
.hero-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero-overlay{position:relative;z-index:1;}
.hero-inner{min-height:clamp(440px,72vh,640px);display:flex;flex-direction:column;justify-content:center;
  text-align:center;color:#fff;padding:80px 0;}
.hero .tag{display:inline-flex;align-items:center;gap:9px;font-size:12px;font-weight:500;letter-spacing:.1em;color:#fff;
  border:1px solid rgba(255,255,255,.45);padding:7px 18px;border-radius:999px;margin:0 auto 26px;}
.hero .tag .dot{width:7px;height:7px;border-radius:50%;background:var(--blue-700);box-shadow:0 0 0 4px rgba(27,180,231,.3);}
.hero h1{font-family:var(--serif);font-size:clamp(28px,6vw,46px);line-height:1.55;font-weight:600;margin:0 0 24px;color:#fff;letter-spacing:.08em;}
.hero h1 .accent{color:var(--blue-400);}
.hero p.lead{font-size:14.5px;line-height:2.15;color:rgba(255,255,255,.9);margin:0 auto 34px;max-width:560px;}
.hero-actions{display:flex;flex-direction:column;gap:12px;align-items:center;}
.hero-actions .btn{width:100%;max-width:300px;}
@media (min-width:560px){.hero-actions{flex-direction:row;justify-content:center;}.hero-actions .btn{width:auto;}}

/* 旧2カラム hero（他ページの page-hero 用に残置・未使用） */
.hero-card{display:none;}

/* ---------- Worship / info band ---------- */
.info-band{display:grid;gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;margin-bottom:30px;}
@media (min-width:680px){.info-band{grid-template-columns:repeat(3,1fr);}}
.info-band .info-item{padding:28px 24px;text-align:center;border-bottom:1px solid var(--line);}
@media (min-width:680px){.info-band .info-item{border-bottom:0;border-right:1px solid var(--line);}.info-band .info-item:last-child{border-right:0;}}
.info-band .info-item .t{font-size:11.5px;font-weight:600;letter-spacing:.14em;color:var(--blue-700);margin-bottom:10px;}
.info-band .info-item .v{font-size:18px;font-weight:600;color:var(--head);letter-spacing:.04em;}
.info-band .info-item .v small{display:block;font-size:12px;font-weight:400;color:var(--muted);margin-top:6px;letter-spacing:.02em;}

/* ---------- Stats ---------- */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.stat{background:#fff;padding:30px 16px;text-align:center;}
.stat .label{font-size:11.5px;font-weight:600;letter-spacing:.1em;color:var(--muted);margin-bottom:10px;}
.stat .value{font-size:clamp(28px,7vw,40px);font-weight:600;color:var(--blue-700);line-height:1;}
.stat .value .unit{font-size:15px;font-weight:600;margin-left:3px;color:var(--head);}
.stat .note{font-size:11.5px;color:var(--muted);margin-top:10px;}
@media (min-width:760px){.stat-grid{grid-template-columns:repeat(3,1fr);}}

/* ---------- Cards / grid ---------- */
.grid{display:grid;gap:24px;}
.grid-2{grid-template-columns:1fr;}
.grid-3{grid-template-columns:1fr;}
@media (min-width:680px){.grid-2{grid-template-columns:1fr 1fr;}.grid-3{grid-template-columns:1fr 1fr;}}
@media (min-width:980px){.grid-3{grid-template-columns:repeat(3,1fr);}}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease);display:flex;flex-direction:column;}
.card:hover{border-color:var(--blue-400);box-shadow:var(--shadow-md);}
.card .card-media{aspect-ratio:16/10;display:grid;place-items:center;color:rgba(255,255,255,.85);position:relative;}
.card .card-media svg{width:42px;height:42px;opacity:.85;}
.card .card-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;}
.card .card-media .ph-label{position:relative;z-index:1;font-size:10.5px;letter-spacing:.14em;color:rgba(255,255,255,.55);}
.card .card-media:has(img)::after{content:"";position:absolute;inset:auto 0 0 0;height:50%;background:linear-gradient(to top,rgba(20,32,48,.5),transparent);}
.card .card-media .role-en{position:absolute;left:18px;bottom:14px;font-size:10.5px;opacity:.9;letter-spacing:.16em;z-index:1;text-shadow:0 1px 3px rgba(0,0,0,.45);}
.card-body{padding:26px 24px;display:flex;flex-direction:column;flex:1;}
.card-body h3{font-size:16.5px;font-weight:600;color:var(--head);margin:0 0 10px;letter-spacing:.04em;}
.card-body p{font-size:13.5px;color:var(--ink-soft);margin:0 0 16px;line-height:2;flex:1;}
.meta-row{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px;}
.tagchip{font-size:11px;font-weight:500;color:var(--blue-700);background:var(--blue-50);padding:4px 12px;border-radius:999px;}
.card-link{font-size:12.5px;font-weight:600;letter-spacing:.06em;color:var(--blue-700);display:inline-flex;align-items:center;gap:7px;}
.card:hover .card-link{gap:11px;}

/* 写真プレースホルダー（落ち着いたスレート系） */
.bg-b1{background:linear-gradient(135deg,#5b6b7a,#3a4856);}
.bg-b2{background:linear-gradient(135deg,#6f8794,#4a606d);}
.bg-b3{background:linear-gradient(135deg,#7d8a93,#566169);}
.bg-orange{background:linear-gradient(135deg,#3fbfe9,#1490c2);}  /* accent cyan tile */
.bg-deep{background:linear-gradient(135deg,#27384c,#1a2838);}
.bg-lilac{background:linear-gradient(135deg,#8a8fa8,#5f6584);}
.bg-yellow{background:linear-gradient(135deg,#9fb3bd,#73868f);}

/* ---------- Link cards（写真タイル風 導線） ---------- */
.nav-cards{display:grid;grid-template-columns:1fr;gap:24px;}
@media (min-width:680px){.nav-cards{grid-template-columns:repeat(2,1fr);}}
@media (min-width:980px){.nav-cards{grid-template-columns:repeat(4,1fr);}}
.nav-card{position:relative;border-radius:var(--radius);overflow:hidden;min-height:210px;display:flex;flex-direction:column;
  justify-content:flex-end;padding:24px;color:#fff;transition:transform .3s var(--ease);}
.nav-card:hover{transform:translateY(-3px);}
.nav-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.nav-card::after{content:"";position:absolute;inset:0;background:rgba(20,32,48,.42);transition:background .3s;z-index:0;}
.nav-card:hover::after{background:rgba(20,32,48,.18);}
.nav-card>*{position:relative;z-index:1;}
.nav-card .en{font-size:10.5px;letter-spacing:.2em;opacity:.85;font-weight:500;}
.nav-card .jp{font-size:17px;font-weight:600;margin-top:6px;letter-spacing:.06em;}
.nav-card .arrow{margin-top:12px;font-size:11.5px;font-weight:500;opacity:.9;}

/* ---------- Feature list ---------- */
.feature{display:flex;gap:16px;align-items:flex-start;}
.feature .ic{flex:0 0 auto;width:46px;height:46px;border-radius:50%;background:var(--blue-50);display:grid;place-items:center;color:var(--blue-700);}
.feature .ic svg{width:22px;height:22px;}
.feature h3{font-size:15.5px;font-weight:600;color:var(--head);margin:2px 0 8px;letter-spacing:.04em;}
.feature p{font-size:13.5px;color:var(--ink-soft);margin:0;line-height:2;}

/* ---------- Timeline / steps ---------- */
.timeline{position:relative;padding-left:32px;}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:1px;background:var(--blue-400);}
.timeline .ti{position:relative;padding:0 0 30px;}
.timeline .ti:last-child{padding-bottom:0;}
.timeline .ti::before{content:"";position:absolute;left:-32px;top:4px;width:17px;height:17px;border-radius:50%;
  background:#fff;border:2px solid var(--blue-700);box-shadow:0 0 0 4px var(--blue-50);}
.timeline .ti .t-time{font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--blue-700);}
.timeline .ti h4{margin:4px 0 5px;font-size:15px;font-weight:600;color:var(--head);}
.timeline .ti p{margin:0;font-size:13.5px;color:var(--ink-soft);}

.steps{display:grid;gap:16px;}
.step{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:flex-start;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;}
.step .step-no{width:46px;height:46px;border-radius:50%;flex:0 0 auto;background:var(--blue-700);
  color:#fff;display:grid;place-items:center;font-weight:600;font-size:10px;line-height:1.1;text-align:center;}
.step .step-no::before{content:"STEP";display:block;font-size:7.5px;letter-spacing:.1em;opacity:.85;}
.step .step-no .n{font-size:18px;}
.step h4{margin:0 0 6px;font-size:15.5px;font-weight:600;color:var(--head);}
.step p{margin:0;font-size:13.5px;color:var(--ink-soft);}

/* ---------- Person（教会員の声・牧師紹介） ---------- */
.person{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease);}
.person:hover{border-color:var(--blue-400);box-shadow:var(--shadow-md);}
.person .pp{aspect-ratio:4/3;display:grid;place-items:center;position:relative;color:#fff;}
.person .avatar{width:70px;height:70px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center;
  font-size:26px;font-weight:600;border:2px solid rgba(255,255,255,.55);}
.person .pp .role{position:absolute;left:0;bottom:0;background:var(--blue-700);color:#fff;font-size:10.5px;font-weight:600;padding:5px 13px;border-top-right-radius:var(--radius);z-index:2;letter-spacing:.08em;}
.person .pp img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;}
.person .p-body{padding:22px;}
.person .p-dept{font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--blue-700);}
.person .p-name{font-size:17px;font-weight:600;color:var(--head);margin:5px 0 2px;}
.person .p-name span{font-size:11.5px;font-weight:400;color:var(--muted);margin-left:7px;}
.person .p-quote{font-size:13.5px;color:var(--ink-soft);line-height:2;margin:12px 0 0;}

/* ---------- Spec table ---------- */
.spec-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.spec-table th,.spec-table td{text-align:left;padding:16px 18px;border-bottom:1px solid var(--line);vertical-align:top;font-size:14px;line-height:2;}
.spec-table tr:last-child th,.spec-table tr:last-child td{border-bottom:0;}
.spec-table th{background:var(--bg-soft);font-weight:600;color:var(--head);width:120px;letter-spacing:.04em;}
.spec-table td{color:var(--ink-soft);}
.spec-table ul{margin:0;padding-left:1.1em;}
@media (min-width:680px){.spec-table th{width:210px;}.spec-table th,.spec-table td{padding:18px 24px;}}

/* ---------- FAQ ---------- */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 22px;display:flex;align-items:center;gap:15px;font-weight:600;font-size:14.5px;color:var(--head);letter-spacing:.04em;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary .q{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:var(--blue-50);color:var(--blue-700);display:grid;place-items:center;font-weight:600;font-size:13px;}
.faq-item summary .chev{margin-left:auto;flex:0 0 auto;width:18px;height:18px;transition:transform .25s var(--ease);color:var(--muted);}
.faq-item[open] summary .chev{transform:rotate(180deg);}
.faq-item .faq-a{padding:0 22px 22px 63px;color:var(--ink-soft);font-size:13.5px;line-height:2.05;}

/* ---------- Message（牧師メッセージ） ---------- */
.message-wrap{display:grid;gap:32px;}
.message-photo{border-radius:var(--radius);aspect-ratio:4/3;background:linear-gradient(150deg,#33495f,#1f3148);
  display:grid;place-items:center;color:#fff;position:relative;overflow:hidden;}
.message-photo .av{width:90px;height:90px;border-radius:50%;background:rgba(255,255,255,.16);border:2px solid rgba(255,255,255,.45);display:grid;place-items:center;}
.message-photo .av svg{width:42px;height:42px;}
.message-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 18%;}
.message-photo::after{content:"";position:absolute;inset:auto 0 0 0;height:46%;background:linear-gradient(to top,rgba(15,24,48,.7),transparent);z-index:1;}
.message-photo .cap{position:absolute;bottom:16px;font-size:11.5px;color:#fff;font-weight:500;z-index:2;text-shadow:0 1px 3px rgba(0,0,0,.4);letter-spacing:.04em;}
.message-body .big-quote{font-family:var(--serif);font-size:clamp(19px,4.4vw,26px);font-weight:600;line-height:1.85;color:var(--head);margin:0 0 22px;letter-spacing:.06em;}
.message-body p{font-size:14px;color:var(--ink-soft);line-height:2.15;margin:0 0 15px;}
.message-body .sign{margin-top:20px;font-weight:600;color:var(--head);letter-spacing:.04em;}
.message-body .sign small{display:block;font-weight:400;color:var(--muted);font-size:12.5px;margin-top:3px;}
@media (min-width:880px){.message-wrap{grid-template-columns:.8fr 1.2fr;align-items:center;gap:52px;}.message-photo{aspect-ratio:3/4;}}

/* ---------- CTA ---------- */
.cta{background:linear-gradient(150deg,var(--blue-800),var(--blue-900));color:#fff;border-radius:var(--radius);padding:56px 28px;text-align:center;position:relative;overflow:hidden;}
.cta h2{font-family:var(--serif);font-size:clamp(21px,4.6vw,30px);font-weight:600;margin:0 0 16px;letter-spacing:.06em;line-height:1.7;position:relative;}
.cta p{color:rgba(255,255,255,.88);font-size:14px;margin:0 auto 28px;max-width:560px;line-height:2.1;position:relative;}
.cta .cta-actions{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;position:relative;}
.cta .chat-hint{margin-top:24px;font-size:12px;color:rgba(255,255,255,.8);display:inline-flex;align-items:center;gap:9px;letter-spacing:.04em;position:relative;}
.cta .chat-hint svg{width:16px;height:16px;}

/* ---------- News ---------- */
.news-list{list-style:none;margin:0;padding:0;}
.news-list li{display:flex;gap:16px;align-items:baseline;padding:20px 4px;border-bottom:1px solid var(--line);flex-wrap:wrap;transition:background .2s;}
.news-list li:first-child{border-top:1px solid var(--line);}
.news-list .date{font-size:12.5px;color:var(--muted);font-weight:500;letter-spacing:.04em;}
.news-list .cat{font-size:10.5px;font-weight:600;color:#fff;background:var(--blue-700);padding:3px 11px;border-radius:3px;letter-spacing:.04em;}
.news-list .ttl{font-size:13.5px;color:var(--ink);width:100%;line-height:1.8;}
@media (min-width:680px){.news-list .ttl{width:auto;flex:1;}}

/* ---------- Badges ---------- */
.badges{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center;}
.badge-item{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:13px 20px;font-size:12.5px;font-weight:500;color:var(--ink-soft);}
.badge-item .bdg{width:32px;height:32px;border-radius:50%;background:var(--blue-50);color:var(--blue-700);display:grid;place-items:center;}
.badge-item .bdg svg{width:19px;height:19px;}

/* ---------- Footer ---------- */
.site-footer{background:var(--blue-900);color:rgba(255,255,255,.74);padding:64px 0 28px;font-size:13px;}
.footer-top{display:grid;grid-template-columns:1fr;gap:34px;padding-bottom:38px;border-bottom:1px solid rgba(255,255,255,.12);}
@media (min-width:760px){.footer-top{grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;}}
.footer-brand .brand{color:#fff;margin-bottom:16px;}
.footer-brand .brand .mark{background:var(--blue-700);}
.footer-brand p{font-size:12.5px;color:rgba(255,255,255,.58);line-height:2.05;margin:0;}
.footer-col h4{font-size:12px;font-weight:600;color:#fff;letter-spacing:.1em;margin:0 0 16px;}
.footer-col ul{list-style:none;margin:0;padding:0;}
.footer-col li{margin:0 0 12px;}
.footer-col a{font-size:12.5px;color:rgba(255,255,255,.68);}
.footer-col a:hover{color:var(--blue-400);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;padding-top:24px;font-size:11px;color:rgba(255,255,255,.45);letter-spacing:.03em;}

/* ---------- Page hero（下層ページ見出し） ---------- */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(150deg,#33495f,#1f3148);color:#fff;padding:64px 0 58px;text-align:center;}
.page-hero::after{content:"";position:absolute;inset:0;background:rgba(20,32,48,.3);}
.page-hero>*{position:relative;z-index:1;}
.page-hero .eyebrow{color:var(--blue-400);}
.page-hero h1{font-family:var(--serif);font-size:clamp(24px,5.4vw,36px);font-weight:600;margin:0 0 10px;letter-spacing:.08em;}
.page-hero p{margin:0;color:rgba(255,255,255,.85);font-size:14px;letter-spacing:.04em;}
.crumb{font-size:12px;color:var(--muted);padding:16px 0;letter-spacing:.03em;}
.crumb a:hover{color:var(--blue-700);}
.crumb span{margin:0 8px;opacity:.5;}

/* ---------- Demo notice ---------- */
.demo-notice{background:#1f3148;color:rgba(255,255,255,.82);font-size:11.5px;line-height:1.9;text-align:center;padding:11px 20px;letter-spacing:.03em;}
.demo-notice strong{color:#fff;font-weight:600;}

/* ---------- Misc ---------- */
.value-list{list-style:none;margin:0;padding:0;display:grid;gap:14px;}
.value-list li{display:flex;gap:13px;align-items:flex-start;font-size:14px;color:var(--ink-soft);line-height:1.9;}
.value-list li::before{content:"";flex:0 0 auto;width:20px;height:20px;border-radius:50%;margin-top:5px;
  background:var(--blue-50) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231bb4e7' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat;}
.divider{height:1px;background:var(--line);margin:0;border:0;}

.section-title .accent,.accent{color:var(--blue-700);}
.hero-copy{min-width:0;}

/* ---------- Form ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 24px;}
@media (min-width:680px){.form-card{padding:40px 38px;}}
.form-row{margin-bottom:22px;}
.form-row label{display:block;font-size:13px;font-weight:600;color:var(--head);margin-bottom:9px;letter-spacing:.04em;}
.form-row label .req{font-size:10px;font-weight:600;color:#fff;background:var(--blue-700);border-radius:3px;padding:2px 8px;margin-left:9px;vertical-align:2px;}
.form-row label .opt{font-size:10px;font-weight:500;color:var(--muted);background:var(--bg-soft);border-radius:3px;padding:2px 8px;margin-left:9px;vertical-align:2px;}
.form-row input,.form-row select,.form-row textarea{width:100%;font-family:inherit;font-size:15px;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px 15px;transition:border-color .2s var(--ease);}
.form-row textarea{min-height:130px;resize:vertical;line-height:1.8;}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--blue-700);}
.form-grid2{display:grid;grid-template-columns:1fr;gap:0 20px;}
@media (min-width:560px){.form-grid2{grid-template-columns:1fr 1fr;}}
.form-note{font-size:12px;color:var(--muted);line-height:1.95;margin:4px 0 20px;}
.form-submit{margin-top:8px;}
.prose{font-size:14px;line-height:2.15;color:var(--ink-soft);}
.prose h3{font-size:16px;font-weight:600;color:var(--head);margin:30px 0 12px;letter-spacing:.04em;}
.prose p{margin:0 0 14px;}
.prose ul{margin:0 0 14px;padding-left:1.2em;}
.prose li{margin:0 0 7px;}

/* ---------- Sermon list（説教アーカイブ） ---------- */
.sermon-list{display:grid;gap:0;border-top:1px solid var(--line);}
.sermon{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;
  padding:22px 6px;border-bottom:1px solid var(--line);transition:background .2s;}
.sermon:hover{background:var(--bg-soft);}
.sermon .s-date{flex:0 0 auto;width:58px;height:58px;border-radius:50%;background:var(--blue-50);color:var(--blue-700);
  display:grid;place-items:center;text-align:center;line-height:1.05;}
.sermon .s-date .d{font-size:20px;font-weight:600;}
.sermon .s-date .m{font-size:10px;font-weight:500;letter-spacing:.06em;}
.sermon .s-body .s-scripture{font-size:11.5px;font-weight:600;letter-spacing:.06em;color:var(--blue-700);}
.sermon .s-body h3{font-size:15.5px;font-weight:600;color:var(--head);margin:4px 0 5px;letter-spacing:.03em;}
.sermon .s-body p{font-size:12.5px;color:var(--muted);margin:0;}
.sermon .s-arrow{color:var(--muted);}
@media (max-width:560px){.sermon{grid-template-columns:auto 1fr;}.sermon .s-arrow{display:none;}}

/* ---------- Scripture pull quote（御言葉・明朝） ---------- */
.scripture{text-align:center;padding:8px 0;margin:0;}
.scripture p{font-family:var(--serif);font-size:clamp(17px,3.8vw,22px);font-weight:500;line-height:2.1;color:var(--head);margin:0 0 14px;letter-spacing:.08em;}
.scripture .ref{font-size:12.5px;font-weight:600;color:var(--blue-700);font-style:normal;letter-spacing:.1em;}
