/* =============================================================
   すこやか ひだまり家族 — LP 固有スタイル (v2)
   v2: PC横幅拡大 / シニア可読の大型化 / タブレット最適化 / コントラスト是正
   前提: brand/tokens.css を先に読み込む
   ============================================================= */

/* レスポンシブな見出し（スマホで大きすぎないようにclamp） */
.section-title { font-size: clamp(1.75rem, 4.6vw, var(--fs-2xl)); }
.eyebrow { font-size: var(--fs-md); }
@media (max-width: 520px){ .btn--lg { font-size: var(--fs-md); } .container { padding-inline: 1.15rem; } }

/* ---------- Header ---------- */
.site-header { position: sticky; top: 0; z-index: 55; background: rgba(255,251,244,.94); backdrop-filter: blur(8px); border-bottom: 1px solid var(--c-border); }
.site-header .container { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-block: .6rem; }
.brand-mark { display: flex; align-items: center; gap: .6rem; font-family: var(--font-heading); font-weight: 900; font-size: 1.4rem; color: var(--c-ink); text-decoration: none; }
.brand-mark .sun { width: 1.5em; height: 1.5em; border-radius: 50%; background: radial-gradient(circle at 50% 42%, var(--c-sun) 0%, var(--c-primary) 78%); box-shadow: 0 0 0 4px var(--c-sun-soft); flex: 0 0 auto; }
.brand-mark small { display:block; font-size: .58em; font-weight: 700; color: var(--c-ink-soft); letter-spacing: .02em; }
.header-cta { display: none; }
@media (min-width: 820px) { .header-cta { display: inline-flex; min-height: 48px; padding: .55rem 1.4rem; font-size: var(--fs-base); } }

/* ---------- Hero ---------- */
.hero { background: linear-gradient(158deg, var(--c-sun-soft) 0%, #FFF3E3 42%, var(--c-bg) 100%); overflow: hidden; }
.hero .container { display: grid; gap: 2rem; padding-block: var(--sp-7); }
@media (min-width: 940px) { .hero .container { grid-template-columns: 1.02fr .98fr; align-items: center; gap: 3.2rem; padding-block: var(--sp-9); } }
.hero-eyebrow { display:inline-block; background: var(--c-surface); border:1px solid var(--c-primary-100); color: var(--c-primary-ink); font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-base); padding: .4em 1.1em; border-radius: var(--r-pill); margin-bottom: 1.1rem; }
.hero h1 { font-size: var(--fs-hero); font-weight: 900; color: var(--c-ink); letter-spacing: .01em; overflow-wrap: anywhere; margin-bottom: .5em; }
.hero h1 .accent { color: var(--c-primary-ink); }
.hero .lead { font-size: var(--fs-md); color: var(--c-ink); max-width: 30em; }
.hero-figure { position: relative; }
.hero-figure img { border-radius: var(--r-lg); box-shadow: var(--shadow-card); width: 100%; object-fit: cover; }
.hero-figure .img-note { position:absolute; right:.6rem; bottom:.6rem; }

/* Badges row */
.hero-badges { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1.5rem 0; padding: 0; list-style: none; }
.hero-badges li { display:flex; align-items:center; gap:.4em; background: var(--c-surface); border:1px solid var(--c-border); border-radius: var(--r-pill); padding: .55em 1.1em; font-size: var(--fs-sm); font-weight: 700; color: var(--c-ink); }
.hero-badges li .ico { font-size: 1.15em; }
.hero-badges li.is-free { background: var(--c-alert); border-color: var(--c-alert); color:#fff; }

/* CTA cluster */
.cta-cluster { display: flex; flex-wrap: wrap; gap: .9rem; }
.cta-cluster .btn-line { flex: 1 1 100%; }
@media (min-width: 560px) { .cta-cluster .btn-line { flex: 0 0 auto; min-width: 21rem; } .cta-cluster .btn-tel { flex: 0 0 auto; } }
.cta-sub { margin-top: .7rem; }
.hero-host { margin-top: 1.2rem; font-size: var(--fs-sm); color: var(--c-ink-soft); }

/* ---------- 共感 チェックリスト ---------- */
.checklist { max-width: 46em; margin: 1.6rem auto 0; padding: 0; display: grid; gap: .9rem; }
.checklist li { list-style: none; display: flex; gap: 1rem; align-items: flex-start; background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-md); padding: 1.15rem 1.4rem; font-size: var(--fs-md); box-shadow: var(--shadow-soft); }
.checklist li::before { content: "✓"; flex: 0 0 auto; display: grid; place-items: center; width: 1.7em; height: 1.7em; border-radius: 50%; background: var(--c-green-ink); color: #fff; font-weight: 900; font-size: .95em; }

/* ---------- とは（3特徴） ---------- */
.lead-center { max-width: 44em; margin-inline: auto; text-align: center; font-size: var(--fs-md); }
.feature-grid { display: grid; gap: 1.5rem; margin-top: 2.4rem; }
@media (min-width: 760px) { .feature-grid { grid-template-columns: repeat(3, 1fr); } }
.feature-card { text-align: center; }
.feature-card .ico { font-size: 3rem; line-height: 1; display:block; margin-bottom: .6rem; }
.feature-card h3 { font-size: var(--fs-lg); }
.feature-card p { font-size: var(--fs-base); }
.banner-img { width: 100%; border-radius: var(--r-lg); box-shadow: var(--shadow-card); margin-top: 2.4rem; object-fit: cover; max-height: 440px; }

/* ---------- 主催者ストーリー ---------- */
.story { display: grid; gap: 2rem; align-items: start; max-width: var(--container-narrow); margin-inline:auto; }
@media (min-width: 820px) { .story { grid-template-columns: 320px 1fr; gap: 2.8rem; max-width: 1040px; } }
.story-figure { position: relative; }
.story-figure img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: var(--r-lg); box-shadow: var(--shadow-card); }
.img-note { background: rgba(59,46,39,.74); color: #fff; font-size: .82rem; font-weight: 700; padding: .22em .8em; border-radius: var(--r-pill); }
.story-figure .img-note { position: absolute; left: .6rem; bottom: .6rem; }
.story-body .eyebrow { margin-bottom: .2em; }
.story-quote { font-family: var(--font-serif); font-size: var(--fs-md); line-height: 2.05; color: var(--c-ink); }
.story-quote p { margin-bottom: 1.1em; }
.story-sign { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-lg); margin-top: 1.2rem; color: var(--c-ink); }
.story-sign small { display:block; font-size: .62em; font-weight: 500; color: var(--c-ink-soft); }

/* ---------- イベント概要 ---------- */
.info-card { max-width: var(--container-narrow); margin-inline: auto; padding: 0; overflow: hidden; }
.info-table { width: 100%; border-collapse: collapse; }
.info-table th, .info-table td { text-align: left; padding: 1.1rem 1.5rem; border-bottom: 1px solid var(--c-border); font-size: var(--fs-base); vertical-align: top; }
.info-table tr:last-child th, .info-table tr:last-child td { border-bottom: none; }
.info-table th { white-space: nowrap; color: var(--c-primary-ink); font-family: var(--font-heading); font-weight: 700; width: 6.5em; background: var(--c-primary-050); }
.info-table .em { font-weight: 700; color: var(--c-alert); }
.map-link { display:inline-flex; align-items:center; gap:.4em; margin-top:.5rem; font-weight:700; }

/* ---------- 講師＆プログラム ---------- */
.theme-band { max-width: var(--container-narrow); margin: 0 auto 2rem; text-align: center; background: var(--c-surface); border: 2px solid var(--c-green); border-radius: var(--r-lg); padding: 1.4rem 1.6rem; }
.theme-band .label { display:inline-block; background: var(--c-green-ink); color:#fff; font-family:var(--font-heading); font-weight:700; font-size: var(--fs-sm); padding:.25em 1em; border-radius: var(--r-pill); margin-bottom:.6rem; }
.theme-band .theme { font-family: var(--font-heading); font-weight: 900; font-size: var(--fs-lg); color: var(--c-ink); margin:0; }
.program-grid { display: grid; gap: 1.5rem; }
@media (min-width: 760px) { .program-grid { grid-template-columns: 1fr 1fr; } }
.program-card img { width:100%; height: 220px; object-fit: cover; border-radius: var(--r-md); margin-bottom: 1.1rem; }
.program-card .part { display:inline-block; background: var(--c-primary-050); color: var(--c-primary-ink); font-family:var(--font-heading); font-weight:700; font-size: var(--fs-sm); padding:.25em .9em; border-radius: var(--r-pill); margin-bottom:.5rem; }
.program-card h3 { font-size: var(--fs-lg); }
.doctor-card { display: grid; gap: 1.5rem; align-items: center; margin-top: 2rem; }
@media (min-width: 620px) { .doctor-card { grid-template-columns: 200px 1fr; } }
.doctor-card .doc-figure { position: relative; max-width: 200px; }
.doctor-card img { width:100%; aspect-ratio: 3 / 4; object-fit: cover; border-radius: var(--r-lg); box-shadow: var(--shadow-card); }
.doctor-card .name { font-family: var(--font-heading); font-weight: 900; font-size: var(--fs-lg); }
.doctor-card .name small { font-size: .6em; font-weight: 700; color: var(--c-ink-soft); }

/* ---------- こんな方へ ---------- */
.persona-grid { display: grid; gap: 2.4rem; align-items: center; max-width: 1100px; margin-inline:auto; }
@media (min-width: 860px) { .persona-grid { grid-template-columns: 1.05fr .95fr; } }
.persona-list { padding: 0; display: grid; gap: 1rem; }
.persona-list li { list-style: none; display:flex; gap:.9rem; align-items:flex-start; font-size: var(--fs-md); }
.persona-list li::before { content:"🌱"; flex:0 0 auto; font-size:1.2em; }
.persona-grid img { width:100%; border-radius: var(--r-lg); box-shadow: var(--shadow-card); }

/* ---------- 参加特典 ---------- */
.gift-grid { display: grid; gap: 1.5rem; max-width: 1040px; margin-inline:auto; }
@media (min-width: 760px) { .gift-grid { grid-template-columns: 1fr 1fr; } }
.gift-card { display:flex; flex-direction:column; }
.gift-card img { width:100%; height: 220px; object-fit: cover; border-radius: var(--r-md); margin-bottom: 1.1rem; }
.gift-card h3 { font-size: var(--fs-lg); }
.gift-card .tag { display:inline-block; background: var(--c-sun); color: var(--c-ink); font-family:var(--font-heading); font-weight:700; font-size: var(--fs-sm); padding:.25em .9em; border-radius: var(--r-pill); margin-bottom:.7rem; width:max-content; }

/* ---------- FAQ ---------- */
.faq-list { max-width: var(--container-narrow); margin-inline: auto; display: grid; gap: 1.1rem; }
.faq-item { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-md); padding: 1.4rem 1.6rem; box-shadow: var(--shadow-soft); }
.faq-q { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-md); color: var(--c-ink); display: flex; gap: .6rem; align-items:flex-start; margin:0; }
.faq-q .mark { color: var(--c-primary-ink); font-weight: 900; flex:0 0 auto; }
.faq-a { margin: .7rem 0 0; padding-left: 1.9rem; color: var(--c-ink); }
.faq-a .mark { color: var(--c-green-ink); font-weight: 900; }

/* ---------- 申込 3導線 ---------- */
.apply { background: linear-gradient(180deg, var(--c-primary-050), var(--c-bg)); }
.apply-grid { display: grid; gap: 1.6rem; margin-top: 2.2rem; align-items: stretch; max-width: 1080px; margin-inline:auto; }
@media (min-width: 880px) { .apply-grid { grid-template-columns: 1fr 1.3fr 1fr; align-items: stretch; } }
.apply-card { position: relative; display: flex; flex-direction: column; align-items: center; text-align: center; gap: 1rem; }
.apply-card h3 { font-size: var(--fs-lg); margin: 0; }
.apply-card--line { border: 3px solid var(--c-line-btn); box-shadow: 0 12px 34px rgba(10,122,56,.18); }
.apply-badge { position: absolute; top: -1rem; left: 50%; transform: translateX(-50%); background: var(--c-alert); color:#fff; font-family:var(--font-heading); font-weight:700; font-size: var(--fs-sm); padding:.3em 1.1em; border-radius: var(--r-pill); white-space:nowrap; }
.qr-ph { width: 190px; height: 190px; margin: 0 auto; border: 3px dashed var(--c-primary); border-radius: var(--r-md); display: grid; place-items: center; gap:.3rem; text-align: center; color: var(--c-primary-ink); background: var(--c-primary-050); font-size: .9rem; font-weight:700; padding: .6rem; line-height:1.5; }
.qr-ph .qr-ico { font-size: 2.2rem; }
.line-id { font-family: var(--font-heading); font-weight: 700; color: var(--c-green-ink); font-size: var(--fs-base); }
.tel-big { font-family: var(--font-heading); font-weight: 900; font-size: clamp(1.8rem, 6vw, 2.3rem); color: var(--c-green-ink); text-decoration: none; letter-spacing: .01em; }
.tel-big .ico { font-size: .8em; }
.apply-note { font-size: var(--fs-sm); color: var(--c-ink-soft); }
.capacity-reminder { max-width: 680px; margin: 2.2rem auto 0; text-align:center; background: var(--c-surface); border:2px dashed var(--c-alert); border-radius: var(--r-md); padding: 1.2rem 1.4rem; font-weight: 700; font-size: var(--fs-md); color: var(--c-ink); }

/* ---------- Footer ---------- */
.site-footer { background: var(--c-ink); color: #F0E4D8; padding-block: var(--sp-7); }
.site-footer .container { display: grid; gap: 1.6rem; max-width: 1100px; }
@media (min-width: 760px) { .site-footer .container { grid-template-columns: 1.2fr 1fr; } }
.site-footer h2 { color: #fff; font-size: var(--fs-lg); display:flex; align-items:center; gap:.5rem; }
.site-footer .sun { width:1.3em; height:1.3em; border-radius:50%; background: radial-gradient(circle at 50% 42%, var(--c-sun), var(--c-primary)); display:inline-block; }
.site-footer a { color: #FBD9B6; }
.site-footer dl { display:grid; grid-template-columns: 6.5em 1fr; gap:.5rem 1rem; margin:0; font-size: var(--fs-sm); }
.site-footer dt { color:#C9B7A8; white-space:nowrap; }
.site-footer .disclaimer { grid-column: 1 / -1; margin-top: .8rem; padding: 1.1rem 1.3rem; background: rgba(255,255,255,.06); border-radius: var(--r-md); font-size: .88rem; line-height:1.8; color:#E7D9CC; }
.site-footer .copyright { grid-column: 1 / -1; margin-top: 1rem; font-size: .82rem; color:#B7A597; }

/* ---------- Floating CTA ---------- */
.floating-cta { display: flex; }
.floating-cta .container { padding-inline: var(--sp-4); }
.floating-cta .btn-line { flex: 1 1 auto; }
.floating-cta .fc-tel { flex: 0 0 auto; display: grid; place-items: center; width: 58px; height: 58px; border-radius: 50%; background: var(--c-surface); border: 2px solid var(--c-green); color: var(--c-green-ink); text-decoration:none; font-size: 1.6rem; }
@media (min-width: 960px) {
  .floating-cta .container { display:block; padding:0; }
  .floating-cta .fc-tel { display: none; }
  .floating-cta .btn-line { box-shadow: 0 12px 30px rgba(10,122,56,.4); }
}

/* ページ末尾に固定CTA分の余白（スマホ・タブレット縦） */
@media (max-width: 959px) { body { padding-bottom: 96px; } }

/* =========================================================
   Hero（パターンC改：背景大判写真＋白アルファ）本採用
   ========================================================= */
.hero-c {
  position: relative;
  min-height: clamp(560px, 84vh, 800px);
  display: flex; align-items: center; justify-content: center; text-align: center;
  padding: clamp(3rem, 7vw, 6.5rem) 1.2rem;
  background:
    linear-gradient(rgba(255,255,255,.74), rgba(255,255,255,.80)),
    url("../images/hero-seniors-tea.png") center/cover no-repeat;
  overflow: hidden;
}
.hc-inner { position: relative; width: 100%; max-width: 1300px; margin: 0 auto; }
.hc-eyebrow { display:inline-block; margin:0 0 1.2rem; font-family:var(--font-heading); font-weight:900; font-size:clamp(1.05rem, 3vw, 2rem); color:var(--c-primary-ink); background:rgba(255,255,255,.85); border:2px solid var(--c-primary-100); padding:.45em 1.4em; border-radius:999px; box-shadow:var(--shadow-soft); letter-spacing:.02em; }
.hc-title { font-family:var(--font-heading); font-weight:900; color:var(--c-ink); font-size:clamp(1.05rem, 4.7vw, 3.1rem); line-height:1.45; margin:0 0 1.1rem; letter-spacing:.01em; }
.hc-title .l2 { display:inline-block; white-space:nowrap; }
.hc-title .accent { color:var(--c-primary-ink); }
.hc-lead { font-size:clamp(1.05rem, 2vw, 1.35rem); line-height:1.9; color:var(--c-ink); max-width:50em; margin:0 auto 1.5rem; font-weight:500; }
.hc-badges { display:flex; flex-wrap:nowrap; justify-content:center; gap:.7rem; padding:0; margin:1.6rem auto; list-style:none; }
.hc-badges li { display:flex; align-items:center; justify-content:center; gap:.4em; white-space:nowrap; background:rgba(255,255,255,.94); border:1.5px solid var(--c-border); border-radius:999px; padding:.6em 1.2em; font-size:clamp(.9rem, 1.45vw, 1.18rem); font-weight:700; color:var(--c-ink); box-shadow:0 3px 12px rgba(120,80,40,.10); }
.hc-badges li .ico { font-size:1.15em; }
.hc-badges li.free { background:var(--c-alert); border-color:var(--c-alert); color:#fff; }
.hc-cta { display:flex; flex-wrap:wrap; justify-content:center; gap:1rem; }
.hc-sub { margin-top:.8rem; font-size:var(--fs-sm); color:var(--c-ink-soft); }
.hc-host { margin-top:1rem; font-size:var(--fs-sm); color:var(--c-ink-soft); }
/* タブレット：バッジを2×2の等幅グリッドで統一 */
@media (max-width: 900px){
  .hc-badges { display:grid; grid-template-columns:1fr 1fr; gap:.7rem; max-width:640px; }
  .hc-badges li { width:100%; }
}
/* スマホ：バッジを全幅で幅を統一 */
@media (max-width: 680px){
  .hc-badges { grid-template-columns:1fr; max-width:440px; }
}
@media (max-width: 600px){
  .hc-cta { flex-direction:column; align-items:stretch; }
  .hc-cta .btn { width:100%; }
  .hero-c .btn--lg { font-size:var(--fs-md); padding:1rem 1.3rem; }
}
