/* ==========================================================================
   Kanade 行政書士事務所 — SWELL子テーマ 追加CSS
   --------------------------------------------------------------------------
   このファイルには index.html の <style> 内容をベースにした「デザイン寄せ」の
   CSSをまとめる。SWELL本体の構造は変えず、ブロックに追加CSSクラスを付与
   して当てていく想定。
   ========================================================================== */

/* ==========================================================================
   1. ルート変数（配色・タイポ）
   ========================================================================== */
:root{
  /* SWELL変数の上書き */
  --color_main: #2a3b32 !important;       /* 深緑 */
  --color_link: #2a3b32 !important;
  --color_accent: #d67a5e !important;
  /* 本文はゴシック（可読性）、見出しは明朝（品格）の2フォント体制 */
  --ffamily_base: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'Yu Gothic', 'Meiryo', sans-serif !important;
  --ffamily_heading: 'Noto Serif JP', 'Yu Mincho', 'Hiragino Mincho ProN', serif;
  --fz_body: 17px !important;

  /* Kanade 独自変数 */
  --bg:        #fbf9f4;   /* 生成り */
  --paper:     #f4ecd8;   /* 和紙 */
  --ink:       #1f2e26;
  --ink-soft:  #3a4a42;
  --ink-mute:  #657068;
  --line:      #e8e2d4;
  --line-soft: #ece7da;
  --green-dd:  #1f2e26;
  --green-d:   #2a3b32;
  --green:     #3c5245;
  --green-l:   #a9b9ad;
  --green-bg:  #e3ead9;
  --salmon:    #d67a5e;
  --salmon-d:  #c3664a;
  --gold:      #b9935d;
  --vermilion: #c0573d;
  --shadow-soft: 0 10px 30px rgba(0,0,0,.06);
  --shadow-card: 0 4px 18px rgba(31,46,38,.08);
}

body{
  background: var(--bg);
  color: var(--ink);
  font-family: var(--ffamily_base);
  font-size: var(--fz_body);
  line-height: 1.9;
  letter-spacing: .02em;
}

/* 見出しは明朝、本文はゴシック（全サイト適用） */
h1, h2, h3, h4, h5, h6,
.p-postList__title,
.c-postTitle,
.c-pageTitle,
.p-articleThumb__title,
.swell-block-faq__q,
.swell-block-step__title,
.p-priceBox__title,
.kn-section-title,
[role="heading"]{
  font-family: var(--ffamily_heading) !important;
  font-weight: 500;
  letter-spacing: .05em;
}

/* 投稿本文内も同じ扱い */
.post_content,
.post_content p,
.post_content li,
.post_content td,
.post_content th,
.post_content dd,
.post_content dt{
  font-family: var(--ffamily_base) !important;
}
.post_content h1,
.post_content h2,
.post_content h3,
.post_content h4,
.post_content h5,
.post_content h6{
  font-family: var(--ffamily_heading) !important;
}


/* ==========================================================================
   2. ヘッダー（SWELLヘッダーのトーン合わせ）
   ========================================================================== */
.l-header{
  border-bottom: 1px solid var(--line-soft);
  background: rgba(255,255,255,.92) !important;
  backdrop-filter: blur(6px);
}
.l-header .c-headLogo img{ max-height: 44px; width: auto; }
.l-header .c-gnav a{
  font-family: 'Noto Sans JP', sans-serif;
  color: var(--ink);
  letter-spacing: .06em;
}


/* ==========================================================================
   3. ヒーロー（.kn-hero-wrap）
   --------------------------------------------------------------------------
   フルワイドブロックに追加CSSクラス「kn-hero-wrap」を付けた想定。
   左：縦書き h1 ／ 右：画像。
   ========================================================================== */
.kn-hero-wrap{
  background:
    radial-gradient(circle at 20% 0%, rgba(185,147,93,.08), transparent 40%),
    radial-gradient(circle at 90% 100%, rgba(214,122,94,.06), transparent 45%),
    var(--paper);
  padding-block: clamp(40px, 6vw, 96px) !important;
  position: relative;
}
.kn-hero-wrap::after{
  content:"";
  position:absolute; inset:auto 0 0 0;
  height: 40px;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.03));
}
.kn-hero-wrap .hero-title{
  writing-mode: vertical-rl;
  font-family: 'Noto Serif JP', serif;
  font-weight: 500;
  font-size: clamp(32px, 5vw, 58px);
  line-height: 1.5;
  letter-spacing: .12em;
  color: var(--green-dd);
  min-height: 440px;
  margin: 0;
}
.kn-hero-wrap .hero-title .accent{
  color: var(--salmon);
  font-size: 1.15em;
  letter-spacing: .18em;
}
.kn-hero-wrap .hero-sub{
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px;
  color: var(--ink-soft);
  letter-spacing: .08em;
  margin-top: 28px;
  line-height: 2;
}
.kn-hero-wrap .hero-photo{
  border-radius: 2px;
  box-shadow: var(--shadow-soft);
  aspect-ratio: 4 / 5;
  object-fit: cover;
  width: 100%;
}

/* 装飾：縦書きの英字リード */
.kn-hero-wrap .hero-lead-en{
  writing-mode: vertical-rl;
  font-family: 'Noto Serif JP', serif;
  font-weight: 400;
  font-size: 12px;
  letter-spacing: .4em;
  color: var(--green-l);
  text-transform: uppercase;
}


/* ==========================================================================
   4. 代表メッセージ帯（.kn-msg-band）
   ========================================================================== */
.kn-msg-band{
  background: var(--paper);
  padding-block: clamp(36px, 5vw, 64px);
  border-top: 1px solid rgba(185,147,93,.25);
  border-bottom: 1px solid rgba(185,147,93,.25);
  text-align: center;
}
.kn-msg-band .msg-mark{
  font-family: 'Noto Serif JP', serif;
  font-size: 56px;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 12px;
}
.kn-msg-band h2{
  font-family: 'Noto Serif JP', serif;
  font-size: clamp(22px, 3vw, 32px);
  line-height: 1.7;
  color: var(--green-dd);
  margin: 0 0 14px;
}
.kn-msg-band .cite{
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 14px;
  color: var(--ink-mute);
  letter-spacing: .1em;
}


/* ==========================================================================
   5. お悩みカード（.kn-worry-card）
   ========================================================================== */
.kn-worry-card{
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 2px;
  padding: 24px 20px;
  position: relative;
  box-shadow: var(--shadow-card);
}
.kn-worry-card .q-mark{
  position: absolute; top: 14px; right: 16px;
  font-family: 'Noto Serif JP', serif;
  color: var(--gold);
  font-size: 26px;
  letter-spacing: 0;
}
.kn-worry-card .worry-icon{
  font-size: 32px;
  margin-bottom: 10px;
}
.kn-worry-card h3{
  font-family: 'Noto Serif JP', serif;
  color: var(--green-dd);
  font-size: 18px;
  line-height: 1.7;
  margin: 0;
}


/* ==========================================================================
   6. ABOUT US（.kn-about — フルワイド、深緑）
   ========================================================================== */
.kn-about{
  background: var(--green-dd) !important;
  color: var(--paper);
  padding-block: clamp(60px, 8vw, 120px) !important;
}
.kn-about h2{
  font-family: 'Noto Serif JP', serif;
  font-size: clamp(26px, 4vw, 40px);
  line-height: 1.5;
  color: #fff;
  margin-bottom: 24px;
}
.kn-about p{ color: rgba(255,255,255,.86); line-height: 2; }
.kn-about .rep-photo{
  aspect-ratio: 3/4;
  object-fit: cover;
  border: 4px solid var(--paper);
  box-shadow: 0 18px 40px rgba(0,0,0,.3);
}


/* ==========================================================================
   7. サービスカード（.kn-service-card）
   ========================================================================== */
.kn-service-card{
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 2px;
  padding: 28px 22px;
  position: relative;
  height: 100%;
}
.kn-service-card .svc-num{
  font-family: 'Noto Serif JP', serif;
  color: var(--gold);
  font-size: 13px;
  letter-spacing: .3em;
  margin-bottom: 8px;
}
.kn-service-card h3{
  font-family: 'Noto Serif JP', serif;
  color: var(--green-dd);
  font-size: 20px;
  margin: 0 0 12px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
}
.kn-service-card p{ color: var(--ink-soft); line-height: 1.9; font-size: 15px; }


/* ==========================================================================
   8. 姉妹サイトバナー（.kn-sister-band）
   ========================================================================== */
.kn-sister-band{
  background: linear-gradient(135deg, #34433a, #1f2e26);
  color: var(--paper);
  padding: 28px 24px;
  border-radius: 2px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  text-decoration: none;
}
.kn-sister-band .tag{
  font-family: 'Noto Serif JP', serif;
  font-size: 12px;
  letter-spacing: .3em;
  color: var(--gold);
  border: 1px solid var(--gold);
  padding: 6px 12px;
  border-radius: 2px;
}
.kn-sister-band h3{
  font-family: 'Noto Serif JP', serif;
  font-size: 22px;
  color: #fff;
  margin: 0;
}
.kn-sister-band .arrow{ color: var(--salmon); font-size: 22px; }


/* ==========================================================================
   9. 料金表（SWELL 価格表ブロックの上書き）
   ========================================================================== */
.kn-pricing .p-priceBox{
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 2px;
  padding: 28px 22px;
}
.kn-pricing .p-priceBox__title{
  font-family: 'Noto Serif JP', serif;
  color: var(--green-dd);
  font-size: 20px;
}
.kn-pricing .p-priceBox__price{
  color: var(--salmon);
  font-family: 'Noto Serif JP', serif;
  font-weight: 600;
}


/* ==========================================================================
   10. 選ばれる理由（.kn-reason-card）
   ========================================================================== */
.kn-reason-card{
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 2px;
  padding: 28px 22px;
  position: relative;
  height: 100%;
}
.kn-reason-card .num{
  position: absolute; top: 18px; right: 18px;
  font-family: 'Noto Serif JP', serif;
  font-size: 38px;
  color: var(--green-l);
  line-height: 1;
}
.kn-reason-card h3{
  font-family: 'Noto Serif JP', serif;
  color: var(--green-dd);
  font-size: 19px;
  margin: 0 0 10px;
  padding-right: 48px;
}


/* ==========================================================================
   11. ご相談の流れ（SWELL ステップブロック）
   ========================================================================== */
.kn-process .swell-block-step__number{
  background: var(--green-d) !important;
  color: var(--paper) !important;
  font-family: 'Noto Serif JP', serif;
}
.kn-process .swell-block-step__title{
  font-family: 'Noto Serif JP', serif;
  color: var(--green-dd);
}


/* ==========================================================================
   12. FAQミニ（SWELL FAQブロック）
   ========================================================================== */
.kn-faq-mini .swell-block-faq__q{
  color: var(--green-dd);
  font-family: 'Noto Serif JP', serif;
}
.kn-faq-mini .swell-block-faq__q::before{
  color: var(--gold);
}
.kn-faq-mini .swell-block-faq__a{
  color: var(--ink-soft);
  line-height: 2;
}


/* ==========================================================================
   13. お客様の声（.kn-voices）
   ========================================================================== */
.kn-voices .voice-card{
  background: var(--paper);
  padding: 28px 24px;
  border-radius: 2px;
  position: relative;
}
.kn-voices .voice-card::before{
  content: "“";
  position: absolute; top: -8px; left: 18px;
  font-family: 'Noto Serif JP', serif;
  color: var(--gold);
  font-size: 72px;
  line-height: 1;
}
.kn-voices .voice-card p{ color: var(--ink); line-height: 2; }
.kn-voices .voice-meta{
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  color: var(--ink-mute);
  letter-spacing: .08em;
  margin-top: 14px;
}


/* ==========================================================================
   14. コンタクト（.kn-contact — フルワイド、深緑）
   ========================================================================== */
.kn-contact{
  background: var(--green-dd) !important;
  color: var(--paper) !important;
  padding-block: clamp(56px, 7vw, 96px) !important;
}
.kn-contact h2{
  font-family: 'Noto Serif JP', serif;
  color: #fff;
  font-size: clamp(26px, 4vw, 38px);
  text-align: center;
  margin-bottom: 10px;
}
.kn-contact .lead{ color: rgba(255,255,255,.8); text-align: center; margin-bottom: 36px; }
.kn-contact .tel-big{
  font-family: 'Noto Serif JP', serif;
  font-size: clamp(32px, 4vw, 48px);
  color: #fff;
  text-decoration: none;
  display: block;
  text-align: center;
}
.kn-contact .tel-hours{
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 14px;
  color: rgba(255,255,255,.65);
  text-align: center;
  margin-top: 8px;
}


/* ==========================================================================
   15. Contact Form 7（.kn-input / .kn-submit）
   ========================================================================== */
.kn-input{
  width: 100%;
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px;
  border-radius: 2px;
  box-sizing: border-box;
}
.kn-input::placeholder{ color: rgba(255,255,255,.45); }
.kn-input:focus{ outline: 2px solid var(--gold); outline-offset: 2px; }

.kn-submit{
  width: 100%;
  background: var(--salmon);
  color: #fff;
  border: 0;
  padding: 16px 20px;
  font-family: 'Noto Serif JP', serif;
  font-size: 18px;
  letter-spacing: .1em;
  cursor: pointer;
  border-radius: 2px;
  transition: background .2s;
}
.kn-submit:hover{ background: var(--salmon-d); }


/* ==========================================================================
   16. フッター（SWELLフッターのトーン合わせ）
   ========================================================================== */
.l-footer{
  background: var(--green-dd) !important;
  color: var(--paper) !important;
}
.l-footer a{ color: rgba(255,255,255,.78); }
.l-footer a:hover{ color: #fff; }


/* ==========================================================================
   17. SNSアイコン（LINE を緑で表示する例）
   ========================================================================== */
.c-footBtm .c-snsList__line a{ background: #06c755 !important; }


/* ==========================================================================
   18. セクション共通ラベル（— LABEL —）
   --------------------------------------------------------------------------
   VOICES / CONTACT / ACCESS などのセクション上部に入る英字ラベル。
   左右に短い朱色の線が入るタイプ。
   ========================================================================== */
.kn-section-label{
  display:flex; align-items:center; justify-content:center; gap:14px;
  font-family:'Noto Serif JP', serif;
  font-size: 13px;
  letter-spacing: .45em;
  color: var(--salmon);
  margin: 0 0 14px;
  text-transform: uppercase;
}
.kn-section-label::before,
.kn-section-label::after{
  content:"";
  display:block;
  width: 28px;
  height: 1px;
  background: var(--salmon);
  opacity: .75;
}
.kn-section-title{
  font-family:'Noto Serif JP', serif !important;
  font-weight: 500 !important;
  font-size: clamp(24px, 3.2vw, 36px) !important;
  line-height: 1.6 !important;
  letter-spacing: .14em !important;
  color: var(--green-dd) !important;
  text-align: center !important;
  margin: 0 0 40px !important;
  /* ==== SWELLの見出しデフォルト装飾を完全リセット ==== */
  background: none !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
  border-left: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  -webkit-text-fill-color: currentColor !important;
}
.kn-section-title::before,
.kn-section-title::after{
  content: none !important;
  display: none !important;
}
.kn-section-title-light,
.kn-section-title.kn-section-title-light{
  color: #fff !important;
}

/* メッセージ帯の h2 も同様にリセット */
.kn-msg-band h2,
.kn-msg-band h2.wp-block-heading{
  background: none !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  -webkit-text-fill-color: currentColor !important;
  color: var(--green-dd) !important;
}
.kn-msg-band h2::before,
.kn-msg-band h2::after{
  content: none !important;
  display: none !important;
}

/* ABOUT US / CONTACT の h2 リセット（深緑背景内の白見出し） */
.kn-about h2,
.kn-about h2.wp-block-heading,
.kn-contact h2,
.kn-contact h2.wp-block-heading{
  background: none !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  -webkit-text-fill-color: currentColor !important;
  color: #fff !important;
}
.kn-about h2::before, .kn-about h2::after,
.kn-contact h2::before, .kn-contact h2::after{
  content: none !important;
  display: none !important;
}


/* ==========================================================================
   19. お客様の声（visible design: 白カード＋大きな引用符＋メタ行）
   ========================================================================== */
.kn-voices-wrap{
  background: var(--paper);
  padding-block: clamp(56px, 7vw, 96px) !important;
}
.kn-voices-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 1060px;
  margin: 0 auto;
  padding-inline: 24px;
}
.kn-voice-card{
  background:#fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 34px 30px 28px;
  position: relative;
  box-shadow: var(--shadow-card);
}
.kn-voice-card::before{
  content:"\201C"; /* “ */
  position:absolute;
  top: 6px;
  left: 20px;
  font-family:'Noto Serif JP', serif;
  font-size: 64px;
  color: var(--salmon);
  opacity: .35;
  line-height: 1;
}
.kn-voice-card .voice-body{
  font-family:'Noto Serif JP', serif;
  color: var(--ink);
  line-height: 2;
  font-size: 15.5px;
  margin: 0 0 18px;
  padding-top: 8px;
}
.kn-voice-card .voice-meta{
  font-family:'Noto Sans JP', sans-serif;
  font-size: 13px;
  color: var(--ink-mute);
  letter-spacing: .06em;
  display:flex; align-items:center; gap: 10px;
}
.kn-voice-card .voice-meta::before{
  content:"";
  display:inline-block;
  width: 18px; height: 1px;
  background: var(--ink-mute);
}


/* ==========================================================================
   20. シリーズ誘導バナー（緑帯・「全10回で解説」）
   ========================================================================== */
.kn-series-banner{
  background: var(--green-bg);
  border-radius: 8px;
  padding: 28px 32px;
  max-width: 1060px;
  margin: 40px auto 0;
  display: grid;
  grid-template-columns: 64px 1fr auto;
  align-items: center;
  gap: 24px;
}
.kn-series-banner .icon{
  width: 64px; height: 64px;
  background:#fff;
  border-radius: 8px;
  display:flex; align-items:center; justify-content:center;
  font-size: 28px;
}
.kn-series-banner h3{
  font-family:'Noto Serif JP', serif;
  color: var(--green-dd);
  font-size: 18px;
  margin: 0 0 6px;
  line-height: 1.6;
}
.kn-series-banner p{
  font-family:'Noto Sans JP', sans-serif;
  color: var(--ink-soft);
  font-size: 14px;
  line-height: 1.8;
  margin: 0;
}
.kn-series-banner .cta{
  background: var(--green-d);
  color:#fff;
  text-decoration: none;
  padding: 14px 24px;
  border-radius: 4px;
  font-family:'Noto Serif JP', serif;
  font-size: 14px;
  letter-spacing: .08em;
  white-space: nowrap;
  transition: background .2s;
}
.kn-series-banner .cta:hover{ background: var(--green); }


/* ==========================================================================
   21. CONTACT セクション（visible design: 深緑2カラム）
   ========================================================================== */
.kn-contact{
  background: var(--green-dd) !important;
  color: var(--paper) !important;
  padding-block: clamp(64px, 8vw, 110px) !important;
}
.kn-contact .kn-section-label{ color: var(--salmon); }
.kn-contact .kn-section-label::before,
.kn-contact .kn-section-label::after{ background: var(--salmon); opacity:.8; }
.kn-contact .kn-section-title{ color:#fff; }
.kn-contact .contact-lead{
  text-align: center;
  color: rgba(255,255,255,.72);
  font-size: 15px;
  line-height: 2;
  max-width: 640px;
  margin: 0 auto 48px;
  padding-inline: 24px;
}

.kn-contact-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  max-width: 1060px;
  margin: 0 auto;
  padding-inline: 24px;
}
.kn-contact-card{
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 6px;
  padding: 36px 32px;
}
.kn-contact-card h3{
  font-family:'Noto Serif JP', serif;
  color:#fff;
  font-size: 20px;
  letter-spacing: .15em;
  margin: 0 0 12px;
}
.kn-contact-card p{
  color: rgba(255,255,255,.72);
  font-size: 14px;
  line-height: 1.9;
  margin: 0 0 18px;
}
.kn-contact-card .tel-big{
  display:block;
  font-family:'Noto Serif JP', serif;
  font-size: clamp(30px, 4vw, 44px);
  color:#fff;
  text-decoration:none;
  letter-spacing: .05em;
  margin: 10px 0 6px;
}
.kn-contact-card .tel-hours{
  color: rgba(255,255,255,.65);
  font-size: 13px;
  font-family:'Noto Sans JP', sans-serif;
  margin: 0 0 20px;
}
.kn-contact-card .cta-pill{
  display:inline-block;
  background: var(--salmon);
  color:#fff !important;
  text-decoration:none;
  padding: 14px 28px;
  border-radius: 999px;
  font-family:'Noto Serif JP', serif;
  font-size: 15px;
  letter-spacing: .06em;
  transition: background .2s;
}
.kn-contact-card .cta-pill:hover{ background: var(--salmon-d); }
.kn-contact-card .cta-line{
  display:inline-block;
  background: #06c755;
  color:#fff !important;
  text-decoration:none;
  padding: 14px 28px;
  border-radius: 999px;
  font-family:'Noto Serif JP', serif;
  font-size: 15px;
  letter-spacing: .06em;
  transition: background .2s;
}
.kn-contact-card .cta-line:hover{ background:#05a648; }
.kn-contact-card hr.divider{
  border: 0;
  border-top: 1px solid rgba(255,255,255,.12);
  margin: 28px 0;
}

/* フォーム側（CF7対応も兼ねる） */
.kn-contact-card label{
  display:block;
  font-family:'Noto Sans JP', sans-serif;
  font-size: 13px;
  color: rgba(255,255,255,.85);
  margin-bottom: 6px;
  letter-spacing: .04em;
}
.kn-contact-card input[type="text"],
.kn-contact-card input[type="email"],
.kn-contact-card input[type="tel"],
.kn-contact-card select,
.kn-contact-card textarea,
.kn-contact-card .kn-input{
  width:100%;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.18);
  color:#fff;
  padding: 12px 14px;
  border-radius: 4px;
  font-family:'Noto Sans JP', sans-serif;
  font-size: 15px;
  margin-bottom: 16px;
  box-sizing: border-box;
}
.kn-contact-card input::placeholder,
.kn-contact-card textarea::placeholder{ color: rgba(255,255,255,.35); }
.kn-contact-card textarea{ min-height: 110px; resize: vertical; }
.kn-contact-card .submit-pill{
  width:100%;
  background: var(--salmon);
  color:#fff;
  border: 0;
  padding: 16px 20px;
  border-radius: 999px;
  font-family:'Noto Serif JP', serif;
  font-size: 17px;
  letter-spacing: .25em;
  cursor: pointer;
  transition: background .2s;
}
.kn-contact-card .submit-pill:hover{ background: var(--salmon-d); }

.kn-contact-badges{
  display:flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 28px;
  margin-top: 36px;
  color: rgba(255,255,255,.75);
  font-size: 14px;
  font-family:'Noto Sans JP', sans-serif;
  padding-inline: 24px;
}
.kn-contact-badges span::before{ content:"✓ "; color: var(--salmon); }


/* ==========================================================================
   22. ACCESS セクション（visible design: 和紙×白カード）
   ========================================================================== */
.kn-access-wrap{
  background: var(--paper);
  padding-block: clamp(56px, 7vw, 96px) !important;
}
.kn-access-card{
  background:#fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 36px 40px;
  max-width: 720px;
  margin: 0 auto;
  box-shadow: var(--shadow-card);
}
.kn-access-card h3{
  font-family:'Noto Serif JP', serif;
  color: var(--green-dd);
  font-size: 20px;
  margin: 0 0 20px;
  letter-spacing: .06em;
}
.kn-access-table{
  width:100%;
  border-collapse: collapse;
  font-family:'Noto Sans JP', sans-serif;
}
.kn-access-table th{
  text-align:left;
  font-weight: 500;
  color: var(--gold);
  letter-spacing: .2em;
  font-size: 13px;
  padding: 10px 24px 10px 0;
  width: 120px;
  vertical-align: top;
}
.kn-access-table td{
  padding: 10px 0;
  color: var(--ink);
  font-size: 15px;
  vertical-align: top;
}


/* ==========================================================================
   22b. SWELL h2 デコレーション強制リセット（ホームページ内のみ）
   --------------------------------------------------------------------------
   SWELLカスタマイザーで「h2見出しデザイン＝ベタ塗り」を選んでいた場合、
   home-swell ページ内の装飾h2（kn-section-title）を完全にノーマル化する。
   :where() でも where: の外の親指定も含めて強く打ち消す。
   ========================================================================== */
.page-id-4688 .kn-section-title,
.page-id-4688 [class*="kn-"] h2,
.page-id-4688 [class*="kn-"] [role="heading"]{
  background: none !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
  border-left: 0 !important;
  border-right: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
  -webkit-text-fill-color: currentColor !important;
}
.page-id-4688 .kn-section-title::before,
.page-id-4688 .kn-section-title::after,
.page-id-4688 [class*="kn-"] h2::before,
.page-id-4688 [class*="kn-"] h2::after{
  content: none !important;
  display: none !important;
  background: none !important;
  border: 0 !important;
}

/* kn-process-step 自動採番防止（SWELLが::beforeで番号を足す場合） */
.kn-process-step::before,
.kn-process-step::after{
  content: none !important;
  display: none !important;
}


/* ==========================================================================
   23. モバイル調整
   ========================================================================== */
@media (max-width: 768px){
  :root{ --fz_body: 16px !important; }
  .kn-hero-wrap .hero-title{ min-height: 360px; font-size: clamp(26px, 7vw, 40px); }
  .kn-about h2{ font-size: clamp(22px, 6vw, 30px); }
  .kn-contact .tel-big{ font-size: clamp(28px, 8vw, 40px); }

  .kn-voices-grid,
  .kn-contact-grid{ grid-template-columns: 1fr; }
  .kn-series-banner{
    grid-template-columns: 48px 1fr;
    grid-template-areas: "icon text" "cta cta";
    padding: 20px 22px;
  }
  .kn-series-banner .icon{ grid-area: icon; width: 48px; height:48px; font-size: 22px; }
  .kn-series-banner .cta{ grid-area: cta; text-align:center; }
  .kn-access-card{ padding: 28px 22px; }
  .kn-access-table th{ width: 92px; padding-right: 14px; font-size: 12px; }
}
