@charset "utf-8";
/* CSS Document */

/* スムーススクロール */
html {
  scroll-behavior: smooth;
}

/* ===================================================
   サブページ共通
=================================================== */

/* fixed header（52px + 68px = 120px）分の余白 */
body.subpage-body {
  padding-top: 120px;
  background:linear-gradient(
  to bottom,
  #f0f6f2 0%,
  #ffffff 30%,
  #ffffff 70%,
  #f0f6f2 100%
  );
}

/* ===================================================
   ページタイトルヒーロー（静的・木洩れ日グリーン）
=================================================== */
.subpage-hero {
  position: relative;
  overflow: hidden;
  min-height: 250px;
  display: flex;
  align-items: center;
  padding:12px 0 0;
  background:linear-gradient(155deg, #f0f6f2 0%, #f0f6f2 30%, #f8fcf9 55%, #f0f6f2 100%);
}

/* 右側の有機ブロブ（静的） */
.subpage-hero::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -60px;
  width: 540px;
  height: 440px;
  background:
    radial-gradient(ellipse 80% 70% at 60% 45%, rgba(255,255,255,0.60) 0%, rgba(255,255,255,0.40) 50%, transparent 75%),
    radial-gradient(ellipse 50% 50% at 80% 70%, rgba(255,255,255,0.70) 0%, transparent 60%);
  border-radius: 48% 52% 55% 45% / 46% 50% 50% 54%;
  filter: blur(28px);
  z-index: 0;
}
/* テキストブロック（左寄せ・コンテンツ幅に合わせて中央） */
.subpage-hero-left {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0;
}
.subpage-hero-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(26px, 3vw, 33px);
  font-weight: 500;
  color: #1a6640;
  letter-spacing: 0.16em;
  line-height: 1.3;
  margin: 0 0 10px;
}
.subpage-hero-en {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(13px, 1.1vw, 14px);
  font-weight: 400;
  color: #5a9a72;
  text-indent: 0.6em;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}
.subpage-hero-img {
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 45%;
  z-index: 0;
}
.subpage-hero-img img {
  height:280px;
}

/* プランページのヒーロー：キャッチコピー（subpage-hero-img削除分のスペースに表示） */
.subpage-hero-catch {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(14px, 1.4vw, 17px);
  font-weight: 400;
  color: #3a4f42;
  letter-spacing: 0.05em;
  line-height: 1.8;
  margin-top: 16px;
}

@media (max-width:1300px) {
.subpage-hero-img {
  width:60%;
}
  .subpage-hero-img img {
  height:200px;
}
}

@media (max-width:767px) {
.subpage-hero-img {
  width:80%;
  -webkit-mask-image: linear-gradient(to right, #000 50%, transparent 90%);
  mask-image: linear-gradient(to left, #000 50%, transparent 90%);
}
  .subpage-hero-img img {
  height:200px;
}  
}

/* ===================================================
   セクションタブナビ
=================================================== */
.section-tab-nav {
  max-width: 1080px;
  margin:10px auto;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  height: auto;
  font-family: 'Zen Maru Gothic', sans-serif;
  /* border-bottom: 1px solid #deeee6; */
}
.section-tab-nav a {
  flex: 1 1 0;
  text-align:center;
  font-weight: 500;
  gap: 6px 12px;
  padding: 20px 12px 18px;
  font-size: 17px;
  color: #4a5a52;
  text-decoration: none;
  letter-spacing: 0.02em;
  /* border-bottom: 2px solid transparent; */
  margin-bottom: -1px;
  transition: color 0.2s, border-color 0.2s;
  white-space: nowrap;
  transition: transform 0.35s ease;
}
.section-tab-nav a:hover {
  color: #127b45;
}
.section-tab-nav a.active {
	color: #127b45;
	letter-spacing:0.2px;
	font-weight:500;
	font-size: 17.5px;
}

/* company.html（4col）：activeタブ下線 */
.section-tab-nav--4col a.active {
  border-bottom:4px solid #deeee6;
  padding-bottom: 16px;
}

/* 会館タブ（hall）：activeタブ下線 */
.section-tab-nav--hall a.active {
  border-bottom:4px solid #deeee6;
  padding-bottom: 16px;
}

/* 会館タブ：カテゴリ名（家族葬専用ホール等） */
.section-tab-nav--hall .tab-hall-cat {
  display: inline-block;
  font-size:12px;
  font-weight:500;
  letter-spacing: 0.02em;
text-indent:0.02em;
  color: #4a5a52;
  border-top: 1.1px solid #4a5a52;
  border-bottom: 1.1px solid #4a5a52;
	margin-right:0.2em;
  padding: 1.3px 0px 1.6px 0px;
  transition: border-color 0.2s, color 0.2s;
  vertical-align: middle;
}
.section-tab-nav--hall a:hover .tab-hall-cat {
  color: #127b45;
	border-color:#127b45;
}
.section-tab-nav--hall a.active .tab-hall-cat {
  color: #127b45;
  border-color:#127b45;
}




/* 会館タブ：ホール名（希ホール・歩ホール） */
.section-tab-nav--hall .tab-hall-name {
  display: inline-block;
  font-size:18px;
  transition: font-size 0.2s ease, color 0.2s ease;
  vertical-align: middle;
}
.section-tab-nav--hall a.active .tab-hall-name {
  font-size: 23px;
  font-weight:500;
  color: #127b45;
}
.section-tab-nav .tab-sep {

  width:2px;
  height: 16px;
  background: #deeee6;
  flex-shrink: 0;
}

/* タブ内改行（会館タブ：希ホール／歩ホールの前で改行する箇所）
   PC：改行せず、前に0.5em分の間隔をあける
   SP：改行表示（間隔は不要） */
.section-tab-nav .tab-gap {
  display: inline-block;
  width: 0.5em;
}
.section-tab-nav .tab-br {
  display: none;
}

/* ===================================================
   コンテンツラッパー（幅を広げ、中央揃え）
=================================================== */
.subpage-wrap {
  max-width: 1280px;
  margin: 0 auto;
  padding: 34px 60px 96px;
  min-height: 500px;
}

/* ===================================================
   タブコンテンツ
=================================================== */
.tab-section {
  display: none;
  opacity: 0;
}
.tab-section.active {
  display: block;
  opacity: 1;
}

/* ===================================================
   セクション見出し
=================================================== */
.subpage-wrap h2 {
  position: relative;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(20px, 1.8vw, 24px);
  font-weight: 500;
  color: #1a6640;
  letter-spacing: 0.08em;
  padding-left: 25px;
  margin: 40px 0 20px;
  line-height: 1.3;
}
.subpage-wrap h2::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.15em;
  bottom: 0.05em;
  width: 6px;
  background: #44bb88;
  border-radius: 30px;
}
.subpage-wrap h2:first-child {
  margin-top: 0;
}

/* ===================================================
   レスポンシブ
=================================================== */
@media (max-width: 1280px) {
  .subpage-hero-left,
  .section-tab-nav,
  .subpage-wrap { max-width: 100%; padding-left: 40px; padding-right: 40px; }
  .subpage-wrap { padding-top: 56px; padding-bottom: 80px; }
  .kyouka-order-section { padding-left: 40px; padding-right: 40px; padding-bottom: 80px; }
}
@media (max-width: 960px) {
  .subpage-hero { padding: 56px 0 44px; min-height: 200px; }
  .subpage-hero::before { width: 380px; height: 320px; }
  .section-tab-nav a { font-size: 15px; padding: 18px 8px 16px; }
}
@media (max-width: 767px) {
  .subpage-hero { padding: 44px 0 36px; min-height: 150px; }
  .subpage-hero-left { padding: 0 20px; }
  .subpage-hero::before { width: 240px; height: 200px; top: -20px; right: -30px; }
  .subpage-hero::after { display: none; }
  .section-tab-nav a.active {
  color: #127b45;
  background:#fff;
  font-size: 16px;
  border-bottom: 0;
  }
  /* タブナビ：中央寄せ・折り返し可能 */
  .section-tab-nav {
    padding: 0 20px;
    flex-wrap: wrap;
    justify-content: center;
  }
  .section-tab-nav a {
    flex: 1 1 auto;
    padding: 14px 10px 12px;
    font-size:16px;
    white-space: normal;
  }
  .section-tab-nav .tab-sep {
    display: none;
  }

  /* 会館タブ（希ホール／歩ホール）：名称前で改行 */
  .section-tab-nav .tab-gap {
    display: none;
  }
  .section-tab-nav .tab-br {
    display: block;
  }
  .section-tab-nav--hall a {
    line-height: 1.6;
  }

  .subpage-wrap { padding: 36px 20px 64px; }
  .kyouka-order-section { padding: 0 20px 64px; }
  .company-table th { width: 100px; font-size: 13px; padding: 12px; }
  .company-table td { font-size: 14px; padding: 12px; }
  .faq-q { font-size: 14px; }
  .faq-a { padding-left: 40px; font-size: 14px; }
  .concept-lead { font-size: 14px; padding: 32px 0 36px; }
}

/* メモリアル如月タブ（4タブ）：767px以下で2列グリッド */
@media (max-width: 767px) {
  .section-tab-nav--4col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
  }
  .section-tab-nav--4col a {
    width: 100%;
    border-bottom: 1px solid #deeee6;
    border-right: 1px solid #deeee6;
    padding: 14px 8px;
  }
  .section-tab-nav--4col a:nth-of-type(even) {
    border-right: none;
  }
  .section-tab-nav--4col a:nth-of-type(3),
  .section-tab-nav--4col a:nth-of-type(4) {
    border-bottom: none;
  }
  .section-tab-nav--4col .tab-sep {
    display: none;
  }
}

/* ===================================================
   本文テキスト
=================================================== */
.subpage-text {
  font-size:16px;
  line-height: 2;
  color: #1e2e26;
  letter-spacing: 0.04em;
  margin-bottom: 1.6em;
}
.subpage-text:last-child {
  margin-bottom: 0;
}

/* ===================================================
   メモリアル如月について（コンセプト）
=================================================== */
.concept-lead {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(18px, 1.6vw, 26px);
  line-height: 2.3;
  color: #1a6640;
  letter-spacing: 0.1em;
  padding: 48px 0 52px;
  margin: 0 auto 50px;
  writing-mode: vertical-rl; /* 日本語の縦書き（右から左へ改行） */
}
/* 横書きバリアント（サブページ用） */
.concept-lead--horizontal {
  writing-mode: horizontal-tb;
  text-align: left;
  padding: 32px 0 40px;
  border-bottom: 1px solid #deeee6;
  margin-bottom: 40px;
  font-size: clamp(14px, 1.5vw, 18px);
}
.concept-body {
  border-top: 1.5px solid #e4eeea;
  padding-top:30px;
  font-size:16px;
  line-height: 2.1;
  color: #1e2e26;
  letter-spacing: 0.04em;
  max-width: 680px;
  margin: 0 auto;
}

/* ===================================================
   会社概要テーブル
=================================================== */
.company-table {
  width: 100%;
  margin:30px auto 0;
  border-collapse: collapse;
  font-size:16px;
  line-height: 1.9;
}
.company-table th,
.company-table td {
  padding:30px 24px;
  border-bottom: 1.5px solid #e4eeea;
  text-align: left;
  vertical-align: top;
}
.company-table th {
  width:220px;
  color: #127b45;
  font-weight: 500;
  letter-spacing: 0.05em;
  white-space: nowrap;
}
.company-table tr:first-child th,
.company-table tr:first-child td {
  border-top: 1.5px solid #e4eeea;
}
.company-table td {
  color: #1e2e26;
  letter-spacing: 0.03em;
}

/* ===================================================
   よくある質問（アコーディオン）
=================================================== */
.faq-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.faq-item {
  border-bottom: 1px solid #e4eeea;
  padding-right: 30px;
}
.faq-item:first-child {
  border-top: 1px solid #e4eeea;
}
.faq-q {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 22px 4px;
  cursor: pointer;
  font-size:17px;
  font-weight:500;
  color: #1e2e26;
  letter-spacing: 0.04em;
  line-height: 1.7;
  transition: color 0.2s;
  list-style: none;
  user-select: none;
}
.faq-q:hover {
  color: #127b45;
}
.faq-q-icon {
  flex: 0 0 30px;
  height:27px;
  padding-bottom:3px;
  border-radius: 50%;
  background: #edf7f1;
  color: #127b45;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 700;
  font-size:20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.faq-q-arrow {
  margin-left: auto;
  flex: 0 8px auto;
  width: 10px;
  height:10px;
  border-right: 1.8px solid #44bb88;
  border-bottom: 1.8px solid #44bb88;
  transform: rotate(45deg);
  transition: transform 0.25s;
}
.faq-item.open .faq-q-arrow {
  transform: rotate(-135deg);
}
.faq-a {
  display: none;
  padding: 4px 40px 28px 46px;
  font-size: 15px;
  line-height: 2;
  color: #3a4f42;
  letter-spacing: 0.04em;
}
.faq-item.open .faq-a {
  display: block;
}

/* ===================================================
   求人情報
=================================================== */
.recruit-notice {
  padding: 40px 0;
  font-size:16px;
  color: #1e2e26;
  line-height: 2;
  letter-spacing: 0.04em;
}

/* ===================================================
   希ホール専用ヒーロー
=================================================== */
.subpage-hero--hall {
  min-height: 280px;
  padding:50px 0 24px;
}

.subpage-hero--hall .subpage-hero-en {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 4px;
  font-size: clamp(13px, 1.1vw, 14px);
  letter-spacing: 0.2em;
}

.subpage-hall-label {
	display: inline-block;
	align-self: flex-start;
	/* background: rgba(255,255,255,0.5); */
	color: var(--green-deep);
	font-size: 15px;
	padding: 10px 15px;
	/* border-radius:8px; */
	letter-spacing: 0.1em;
	border-bottom: 1px solid var(--green-deep);
	border-top: 1px solid var(--green-deep);
	margin-bottom: 15px;
}

/*.hero-en-label {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(11px, 1vw, 12px);
  font-weight: 400;
  color: #8ab8a0;
  letter-spacing: 0.28em;
}*/
/* 「メモリアル如月」：希ホールと同一行に小さくインライン表示 */
.subpage-hero-hall-brand {
  display: inline-block;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 0.46em;
  font-weight: 500;
  color: #1a6640;
  letter-spacing: 0.18em;
  margin-right: 0.4em;
  vertical-align: middle;
  line-height: 1;
}
.subpage-hero--hall .subpage-hero-title {
  font-size: clamp(32px, 4vw, 40px);
  font-weight:500;
  margin: 0 0 14px;
  letter-spacing: 0.05em;
}
/*.subpage-hero-hall-catch {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(15px, 1.6vw, 19px);
  font-weight: 400;
  color: #3a6648;
  letter-spacing: 0.1em;
  line-height: 1.7;
  margin: 0;
}*/
@media (max-width: 960px) {
  .subpage-hero--hall .subpage-hero-left {
    padding: 0 40px;
  }
}
@media (max-width: 767px) {
  .subpage-hero--hall {
    min-height: 220px;
    padding: 16px 0 20px;
  }
  .subpage-hero--hall .subpage-hero-left {
    padding: 0 20px;
  }
  .subpage-hero--hall .subpage-hero-title {
    font-size: clamp(28px, 7vw, 36px);
  }
/*  .subpage-hero-hall-catch {
    font-size: 13px;
  }*/
}

/* ===================================================
   フォトギャラリー スライドショー
=================================================== */
.hall-slideshow {
  position: relative;
  width: 100%;
  max-width: 900px;
  margin: 50px auto 0;
}

/* メインビューア */
.slideshow-main {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: 8px;
  background: #1a2e22;
  /* 高さはJSで動的にセット。初期値は横長比率 */
  aspect-ratio: 16 / 9;
}
/* 縦画像があるとJSがdata-portrait="true"を付与してaspect-ratioを解除 */
.slideshow-main[data-portrait="true"] {
  aspect-ratio: unset;
}

/* ブラー背景（縦画像時に両サイドを埋める） */
.slideshow-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: blur(22px) brightness(0.5) saturate(0.6);
  transform: scale(1.1);
  opacity: 0;
  transition: opacity 0.55s ease;
  pointer-events: none;
  z-index: 0;
}
.slideshow-bg.active {
  opacity: 1;
}

.slideshow-main-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 0;
  transition: opacity 0.55s ease;
  pointer-events: none;
  z-index: 1;
}
.slideshow-main-img.active {
  opacity: 1;
}

/* キャプション */
.slideshow-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 22px 20px 14px;
  background: linear-gradient(transparent, rgba(20,40,28,0.68));
  color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-align: left;
  z-index:9;
  pointer-events: none;
}

/* 前後ボタン */
.slideshow-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 50%;
  background: rgba(255,255,255,0.82);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, box-shadow 0.2s;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.slideshow-btn:hover {
  background: #fff;
  box-shadow: 0 3px 12px rgba(0,0,0,0.22);
}
.slideshow-btn svg {
  width: 18px;
  height: 18px;
  stroke: #1a6640;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.slideshow-btn.prev { left: 12px; }
.slideshow-btn.next { right: 12px; }

/* インジケーター（ドット） */
.slideshow-dots {
  display: flex;
  justify-content: center;
  gap: 7px;
  margin: 14px 0 16px;
}
.slideshow-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #c8ddd2;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.25s, transform 0.25s;
}
.slideshow-dot.active {
  background: #127b45;
  transform: scale(1.25);
}

/* サムネイル帯 */
.slideshow-thumbs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 4px;
  scrollbar-width: thin;
  scrollbar-color: #c8ddd2 transparent;
}
.slideshow-thumbs::-webkit-scrollbar { height: 4px; }
.slideshow-thumbs::-webkit-scrollbar-thumb { background: #c8ddd2; border-radius: 2px; }

.slideshow-thumb {
  flex: 0 0 calc((100% - 8px * 4) / 5);
  min-width: 80px;
  aspect-ratio: 4 / 3;
  border-radius: 5px;
  overflow: hidden;
  cursor: pointer;
  scroll-snap-align: start;
  border: 2px solid transparent;
  transition: border-color 0.2s, opacity 0.2s;
  opacity: 0.65;
  background: #e4eeea;
}
.slideshow-thumb,
.slideshow-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.slideshow-thumb.active,
.slideshow-thumb:hover {
  border-color: #44bb88;
  opacity: 1;
}

/* レスポンシブ */
@media (max-width: 767px) {
  .slideshow-thumb {
    flex: 0 0 calc((100% - 8px * 2) / 3);
  }
  .slideshow-btn { width: 36px; height: 36px; }
  .slideshow-btn svg { width: 14px; height: 14px; }
  .hall-sub-features li {
    padding: 8px 16px;
    font-size: 13px;
  }
}

/* ===================================================
   会館の特徴バッジ（家族葬専用・プライベート空間など）
=================================================== */
.hall-sub-features {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  margin: 0 0 40px;
}
.hall-sub-features li {
  display: inline-flex;
  align-items: center;
  padding: 10px 20px 12px 22px;
  border-radius: 999px;
  background: #deeee6;
  color: #1a6640;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size:16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.4;
}
.hall-eyecatch {width:80%;max-width: 1000px;margin: 0 auto 56px;border-radius: 12px;overflow: hidden;line-height: 0;}
.hall-eyecatch img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
}
.hall-floormap { text-align:center;}

.hall-floormap img { 
  max-width:700px;
  margin:auto;
}

@media (max-width: 767px) {
.hall-eyecatch {
  width:100%;

}	
}

/* ===================================================
   プランページ専用 見出しヘッダー（MEMORIAL PLANS + 葉っぱ + h2）
=================================================== */
.sub-plan-header {
  text-align: center;
  margin: 50px 0 10px;
}
.sub-plan-header:first-child {
  margin-top: 30px;
}
.sub-section-label {
  font-size: 15px;
  letter-spacing: 0.25em;
  color: var(--green-light, #44bb88);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.sub-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: center;
  margin: 0 auto 16px;
  color: var(--green-pale, #a8ccb8);
}
.sub-divider::before, .sub-divider::after {
  content: '';
  display: block;
  width: 40px;
  height: 1px;
  background: var(--green-pale, #a8ccb8);
}
.sub-leaf-icon {
  width: 20px;
  height: 22px;
  display: block;
}
@media (max-width: 767px) {
  .sub-section-label {
    font-size: 13px;
    letter-spacing: 0.18em;
  }
  .sub-divider::before, .sub-divider::after {
    width: 28px;
  }
}

/* ===================================================
   葬儀プランページ専用 メインタイトル
=================================================== */
h2.plan-title {
  position: static;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(30px, 3.6vw, 38px);
  font-weight: 500;
  text-align: center;
  padding-left: 0;
  margin: 0 0 20px;
  letter-spacing: 0.04em;
  color: #1a6640;
  line-height:1.3;
}
.plan-title::before {
  display: none;
}
.plan-title .h2-sub {
  display: block;
  font-size: 0.65em;
  letter-spacing: 0.08em;
  margin-top: 14px;
}

/* h2直下の説明文 */
.plan-cap {
  display: block;
  text-align: center;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 18px;
  color: #5a9a72;
  font-weight: 500;
  letter-spacing: 0.08em;
  
  margin: 0 0 24px;
}

/* プランページ内のサブ見出し（h2の代わりに使用） */
.plan-wrap h3 {
  font-size: clamp(18px, 2vw, 30px);
  font-weight: 500;
  text-align: center;
  padding-left: 0;
  margin: 48px 0 20px;
  /* letter-spacing: 0.00em; */
  color: #1a6640;
}

/* ===================================================
   葬儀プランページ
=================================================== */

/* プランリード文 */
.plan-lead {
  font-size: 17px;
  color: #4a5a52;
  font-weight:500;
  line-height: 2;
  text-align:center;
  letter-spacing: 0.04em;
  margin: 40px auto;
  padding: 20px 24px;
  background: rgba(255,255,255,0.7);
  font-family: 'Zen Maru Gothic', sans-serif;
  border-radius: 8px;
  /* border-left: 3px solid #a8d8be; */
}

/* 注意書き */
.plan-note {
  font-size: 15px;
  color: #4a5a52;
  line-height: 1.8;
  letter-spacing: 0.03em;
  margin: 16px 0 40px;
  padding: 16px 20px;
  background: #f8f6f0;
  border-radius: 6px;
}
.plan-note ul {
  padding-left: 1.2em;
  list-style: disc;
  font-size: 14.5px;
}
.plan-note ul li {
  list-style: disc;
  margin-top: 4px;
  font-size: 14px;
}
.plan-note-strong {
  font-weight: 500;
  margin-bottom: 8px;
}
.plan-note-after {
  margin-top: 12px;
}

/* プランカード（各プラン） */
.plan-sub-card {
  /* border: 1.5px solid #deeee6; */
  /* border-radius: 12px; */
  /* overflow: hidden; */
  margin-bottom: 48px;
}
.plan-sub-card:last-child {
  margin-bottom: 0;
}

/* カードヘッダー */
.plan-sub-card-head {
  background: linear-gradient(135deg, #1a6640 0%, #2d8a58 100%);
  color: #fff;
  padding: 24px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.plan-sub-card-head--light {
  background: linear-gradient(135deg, #3a7a5a 0%, #55a878 100%);
}
.plan-sub-card-name {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.3;
}
.plan-sub-card-name-sub {
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.08em;
  opacity: 0.85;
  display: block;
  margin-top: 4px;
}
.plan-sub-card-price-wrap {
  text-align: right;
}
.plan-sub-card-price-label {
  font-size: 12px;
  opacity: 0.8;
  letter-spacing: 0.06em;
  margin-bottom: 2px;
}
.plan-sub-card-price {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 700;
  letter-spacing: 0.04em;
}

/* 金額の下に表示する「流れ」バッジ（お通夜→告別式→出棺） */
.plan-sub-card-flow {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
}
.plan-sub-card-flow-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 4px 10px;
  border-radius: 4px;
  background: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.55);
}
.plan-sub-card-flow-badge.is-on {
  background: rgba(255,255,255,0.95);
  color: var(--plan-color, #1a6640);
}
.plan-sub-card-flow-arrow {
  color: rgba(255,255,255,0.5);
  font-size: 12px;
}
.plan-sub-card-price-note {
  font-size: 11px;
  opacity: 0.75;
  margin-top: 2px;
}
.plan-sub-card-capacity {
  display: inline-block;
  background: rgba(255,255,255,0.2);
  border: 1px solid rgba(255,255,255,0.4);
  border-radius: 999px;
  padding: 4px 14px;
  font-size: 12px;
  letter-spacing: 0.05em;
  margin-top: 6px;
}

/* カードボディ */
.plan-sub-card-body {
  padding: 32px;
  background: #fff;
}
/* セット内容の見出し */
.plan-items-label {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.02em;
  margin-bottom: 20px;
  text-align:center;
  background: var(--green-mist);
  color: var(--green-deep);
  padding:6px 10px 8px;
  border-radius: 20px;
  letter-spacing: 0.04em;
}

/* 「共通の物品・サービス」＋「各プラン追加分」の見出しを2段で表示する場合 */
.plan-items-combo {
  text-align: center;
  margin-bottom: 20px;
}
.plan-items-combo .plan-items-label {
  margin-bottom: 0;
}
.plan-items-plus {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--green-deep);
  letter-spacing: 0.02em;
  margin: 6px 0;
}

/* 共通セット内容（各プランに共通の物品・サービス）を囲む枠 */
.plan-common-set {
  border: 6px solid rgba(45, 114, 90, 0.2);
  border-radius: 14px;
  padding: 32px;
  margin: 48px 0 100px;
}
.plan-common-set h3 {
  font-size: 18px;
  font-weight: 500;
  text-align: center;
  background: var(--green-mist);
  color: var(--green-deep);
  padding: 6px 10px 8px;
  border-radius: 20px;
  letter-spacing: 0.04em;
  margin: 0 0 20px;
}
.plan-common-set .plan-feature-list {
  margin-bottom: 0;
}

/* プラン祭壇選択エリア（白木 / 花） */
.plan-sub-card-img-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0;
  width: 100%;
  max-width: 1000px;
  margin: 24px auto 0;
}

/* 各写真ブロック */
.plan-sub-card-img-item {
  position: relative;
  flex: 1;
  min-width: 0;
}
.plan-sub-card-img-item:first-child img {
  border-radius: 8px 0 0 8px;
}
.plan-sub-card-img-item:last-child img {
  border-radius: 0 8px 8px 0;
}

.plan-sub-card-img {
  width: 100%;
  display: block;
}

/* 写真下ラベル「白木祭壇」「花祭壇」 */
.plan-sub-card-img-label {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: white;
  color: #3d7a60;
  font-size: 15px;
  font-weight: 500;
  padding: 3px 14px;
  border-radius: 20px;
  pointer-events: none;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

/* 中央バッジ「どちらか選べます」 */
.plan-sub-card-img-badge {
  position: relative;
  flex-shrink: 0;
  z-index: 2;
  width: 95px;
  height: 95px;
  margin: 0 -40px; /* 画像に重なるよう左右にはみ出す */
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.95);
  border: 3px solid #c8a060;
  color: #c8a060;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  pointer-events: none;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  letter-spacing: 0.02em;
}

/* ── スマホ：縦並び ── */
@media (max-width: 600px) {
  .plan-sub-card-img-wrap {
    flex-direction: column;
    gap: 0;
  }

  .plan-sub-card-img-item:first-child img {
    border-radius: 8px 8px 0 0;
  }
  .plan-sub-card-img-item:last-child img {
    border-radius: 0 0 8px 8px;
  }

  /* バッジを縦並び用に中央配置 */
  .plan-sub-card-img-badge {
    width: 90px;
    height: 90px;
    margin: -32px auto; /* 上下の写真に重なる */
    font-size: 13px;
  }

  .plan-sub-card-img-label {
    font-size: 12px;
    padding: 2px 10px;
    left: 50px;
    4:
    JIS04;
  }
}

@media (max-width: 960px) {
  .plan-sub-card-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  .plan-sub-card-price-wrap {
    text-align: left;
  }
}

@media (max-width: 767px) {
  .plan-sub-card-body {
    padding: 20px 0;
    background:none;
  }
  .plan-sub-card-head {
    padding: 18px 20px;
  }
  /* セット内容の見出し */
.plan-items-label {
  font-size:1.55vh;
  letter-spacing:0em;
}
  .plan-common-set {
    padding: 20px 16px;
    margin: 32px 0 32px;
  }
  .plan-common-set h3 {
    font-size: 1.55vh;
    letter-spacing: 0em;
  }
}

/* ===================================================
   葬儀プラン カード型タブナビ（plan_*.html 専用）
   ※TOPページの .plan-card デザインに準拠
=================================================== */
.section-tab-nav.plan-tab-nav {
  max-width: 1360px;
  margin: -20px auto 0;
  padding: 8px 0 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  border-bottom: none;
  align-items: stretch;
}
.plan-tab-nav .tab-sep {
  display: none;
}

/* カード本体 ― TOPの .plan-card に準拠 */
.plan-tab-nav a {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 0 0 10px;
  gap: 0px 12px;
  border-radius: 8px;
  background: #fff;
  text-align: center;
  color: #4a5a52;
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.06em;
  overflow: hidden;
  position: relative;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              box-shadow 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  white-space: normal;
  transform: scale(0.90);
}

/* 上部ライン（通常：薄緑） ― TOPの .plan-card::before に準拠 */
/*.plan-tab-nav a::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  transition: background 0.6s ease;
  z-index: 1;
}*/

.plan-tab-nav a {
 box-shadow: rgba(160, 210, 155, .14) -4px 9px 25px -6px;
}

/* 写真エリア */
.plan-tab-nav a .tab-card-img {
  width: 100%;
  height: 100px;
  overflow: hidden;
  /* background: #e4eeea; */
  flex-shrink: 0;
}
.plan-tab-nav a .tab-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* テキストエリア */
.plan-tab-nav a .tab-card-body {
  padding: 6px 16px 5px;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.plan-tab-nav a .tab-card-name {
  display: block;
  /* font-family: 'Zen Maru Gothic', sans-serif; */
  font-size: 24px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #2d725a;
  /* margin-bottom: 2px; */
  line-height: 1.3;
}
.plan-tab-nav a .tab-card-price {
  display: block;
  font-size: 28px;
  font-weight: 500;
  color: #2d725a;
  letter-spacing: 0.04em;
  line-height: 1.2;
  /* padding-top: 10px; */
  /* border-top: 1px solid #deeee6; */
  width: 100%;
  margin-top: auto;
  text-align: left;
  padding-left: 16px;
  padding-right: 16px;
}
.plan-tab-nav a .tab-card-price .small {
  font-size: 18px;
  font-weight: 400;
}

/* 価格行ラッパー：ラベル・金額・税込を横1列に */
.plan-tab-nav a .tab-card-price-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 3px 16px 0px;
  border-top: 1px solid #deeee6;
  width: 100%;
  box-sizing: border-box;
}

/* 「費用合計」「会員価格」ラベル */
.plan-tab-nav a .tab-card-price-from {
  display: inline-flex;
  align-items: center;
  font-size: 13px;
  color: #666;
  letter-spacing: 0.04em;
  flex-shrink: 0;
}
/* 「会員価格」は赤バッジ */
.plan-tab-nav a .tab-card-price-from.is-member {
  color: #1e2e26;
}
.plan-tab-nav a .tab-card-price-from.is-member::before {
  content: '会員価格';
  display: inline-block;
  background: #c0392b;
  color: #fff;
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.04em;
  padding: 1px 6px;
  border-radius: 3px;
  white-space: nowrap;
}
/* 「費用合計」は通常テキスト */
.plan-tab-nav a .tab-card-price-from.is-total::before {
  content: '費用合計';
  display: inline-block;
  font-size: 13px;
  color: #4a5a52;
  font-weight: 400;
}

/* 金額（同行に） */
.plan-tab-nav a .tab-card-price {
  display: inline;
  font-size: 20px;
  font-weight: 500;
  color: #2d725a;
  letter-spacing: 0.04em;
  line-height: 1.2;
  width: auto;
  margin-top: 0;
  padding: 0;
  text-align: left;
}
.plan-tab-nav a .tab-card-price .small {
  font-size: 15px;
  font-weight: 400;
}

/* 税込サブテキスト（同行に） */
.plan-tab-nav a .tab-card-price-sub {
  display: inline;
  font-size: 13px;
  color: #7a9a88;
  letter-spacing: 0.03em;
  padding: 6px 0 0;
  text-align: left;
}

/* アクティブ ― 上部ライン濃緑＋背景薄緑 */
.plan-tab-nav a.active {
  background: rgba(90,143,95,0.08);
  transform: scale(1.05) translateY(-6px);
  box-shadow: 0 20px 48px rgba(0,0,0,0.10);
  border: 3px solid #5a9a72;
}
.plan-tab-nav a.active::before {
  /* background: #127b45; */
}
.plan-tab-nav a.active .tab-card-name {
  color: #1a6640;
}
.plan-tab-nav a.active .tab-card-price {
  color: #1a6640;
  border-top-color: rgba(255,255,255,0.6);
}
.plan-tab-nav a.active .tab-card-price-row {
  border-top-color: rgba(255,255,255,0.6);
}


/* レスポンシブ */

@media (max-width:1460px) {
.section-tab-nav.plan-tab-nav {
  max-width:93%;
  gap: 5px;
}
}

@media (max-width: 1030px) {
  .section-tab-nav.plan-tab-nav {
    max-width: 90%;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  .plan-tab-nav a .tab-card-img {
    height:80px;
}
}
@media (max-width: 767px) {
  .section-tab-nav.plan-tab-nav {
    max-width: 100%;
    padding: 0 16px;
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .plan-tab-nav a {
    display: grid;
    grid-template-columns: 90px 1fr;
    grid-template-rows: auto auto;
    padding: 0;
    transform: none !important;
    box-shadow: none !important;
  }
  .plan-tab-nav a::before {
    top: 0; left: 0; bottom: 0; right: auto;
    width: 3px;
    height: 100%;
  }
  .plan-tab-nav a .tab-card-img {
    grid-column: 1;
    grid-row: 1 / 3;
    width: 90px;
    height: 90px;
    flex-shrink: 0;
    align-self: center;
  }
  .plan-tab-nav a .tab-card-body {
    grid-column: 2;
    grid-row: 1;
    padding: 12px 14px 4px;
    align-items: flex-start;
    text-align: left;
  }
  .plan-tab-nav a .tab-card-name { font-size: 16px; }
  .plan-tab-nav a .tab-card-price-row {
    grid-column: 2;
    grid-row: 2;
    padding: 0 14px 12px;
    gap: 4px;
    border-top: none;
  }
  .plan-tab-nav a .tab-card-price {
    font-size: 16px;
  }
  .plan-tab-nav a .tab-card-price-sub {
    font-size: 11px;
  }
  .plan-tab-nav a.active {
    transform: none !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.08) !important;
  }
}

/* ===================================================
   プランページ テーマカラー（4プラン色分け）
   ※家族葬プラン等の配色イメージを参考にした配色
=================================================== */
:root {
  --plan-color: #1a6640;
  --plan-color-light: #2d8a58;
  --plan-color-soft: #44bb88;
  --plan-bg-soft: #f0f8f3;
}
/* 直葬・火葬式：テラコッタ系（火葬式プランの配色） */
body.theme-kasou {
  --plan-color: #a8633f;
  --plan-color-light: #c08055;
  --plan-color-soft: #d9a781;
  --plan-bg-soft: #faf3ee;
}
/* 特別プラン：オリーブ系（1日葬プランの配色） */
body.theme-simple {
  --plan-color: #828a35;
  --plan-color-light: #9da64a;
  --plan-color-soft: #c3cd7e;
  --plan-bg-soft: #f7f8ef;
}
/* 家族葬：ティールグリーン系（家族葬プランの配色） */
body.theme-family {
  --plan-color: #2e8b7a;
  --plan-color-light: #45a594;
  --plan-color-soft: #7fc9bc;
  --plan-bg-soft: #eef8f6;
}
/* 一般葬：パープル系（お預かり葬プランの配色） */
body.theme-general {
  --plan-color: #7d63a0;
  --plan-color-light: #9580b8;
  --plan-color-soft: #bcaad3;
  --plan-bg-soft: #f5f1f9;
}

/* ===================================================
   お寺(お坊さん)紹介バナー（plan_*.html 各プラン比較の上）
=================================================== */
.monk-banner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 20px;
}
.monk-banner-link {
  display: flex;
  align-items: center;
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  min-height: 300px;
  box-shadow: 0 8px 28px rgba(45, 114, 90, 0.14);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.monk-banner-link:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(45, 114, 90, 0.2);
}
.monk-banner-photo {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.monk-banner-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.monk-banner-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, rgba(20,40,32,0.82) 0%, rgba(25,55,42,0.62) 45%, rgba(25,55,42,0.2) 80%);
}
.monk-banner-body {
  position: relative;
  z-index: 1;
  padding: 32px 36px;
  color: #fff;
}
.monk-banner-label {
  display: inline-block;
  font-size: 18px;
  letter-spacing: 0.15em;
  color: #d8ecdf;
  /* border: 1px solid rgba(255,255,255,0.5); */
  border-radius: 20px;
  padding: 0 0 5px;
  /* margin-bottom: 12px; */
}
.monk-banner-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(19px, 2.4vw, 28px);
  font-weight: 500;
  letter-spacing: 0.06em;
  margin-bottom: 15px;
}
.monk-banner-desc {
  font-size: 14px;
  line-height: 1.8;
  color: #e7f1ea;
  max-width: 460px;
}
.monk-banner-arrow {
  position: relative;
  z-index: 1;
  margin-left: auto;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #fff;
  padding: 10px 22px;
  border: 1.5px solid rgba(255,255,255,0.7);
  border-radius: 4px;
  white-space: nowrap;
  margin-right: 36px;
  transition: background 0.2s;
}
.monk-banner-link:hover .monk-banner-arrow {
  background: rgba(255,255,255,0.15);
}
.monk-banner-arrow .arrow-icon {
  display: inline-flex;
  align-items: center;
  transition: transform 0.2s ease;
}
.monk-banner-link:hover .arrow-icon {
  transform: translateX(5px);
}

@media (max-width: 767px) {
  .monk-banner-link {
    flex-direction: column;
    align-items: flex-start;
    min-height: 220px;
  }
  .monk-banner-body { padding: 28px 24px 20px; }
  .monk-banner-arrow {
    margin: 0 0 24px 24px;
  }
}

/* ===================================================
   各プラン比較テーブル（plan_*.html 共通フッター上）
=================================================== */
.plan-compare-section {
  max-width: 1280px;
  margin: 80px auto 100px;
  padding: 28px 20px 0;
}
.plan-compare-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(24px, 2.8vw, 30px);
  font-weight: 700;
  color: rgba(45, 114, 90, 0.9);
  text-align: center;
  letter-spacing: 0.1em;
  margin-bottom: 32px;
}

.plan-compare-scroll {
  overflow-x: visible;
  -webkit-overflow-scrolling: touch;
  position: relative;
  padding-top: 24px;
}

.plan-compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  table-layout: fixed;
}
.plan-compare-table th,
.plan-compare-table td {
  border: 1px solid rgba(45, 114, 90, 0.3);
  padding: 16px 14px;
  text-align: center;
  vertical-align: middle;
  background: #fff;
}
.plan-compare-table th.plan-compare-row-label {
  width: 90px;
  background: #fafafa;
  color: #555;
  font-weight: 500;
  letter-spacing: 0.05em;
  font-size: 14px;
}

/* 列ヘッダー（プラン名） */
.plan-compare-table thead th {
  padding: 0 0 16px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 19.5px;
  font-weight: 500;
  letter-spacing: 0.06em;
  position: relative;
  overflow: visible;
}

/* 比較表ヘッダーの写真 */
.plan-compare-img {
  width: 100%;
  height: 132px;
  overflow: hidden;
  margin-bottom: 14px;
  position: relative;
}
.plan-compare-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* 各プラン名（見出し）の背景色：テーマカラーは使わず、緑系の濃淡のみで分ける */
.plan-compare-col-jitaku { --header-bg: rgba(45, 114, 90, 0.04);--header-text: #2d725a; }
.plan-compare-col-kasou   { --header-bg: rgba(45, 114, 90, 0.08); --header-text: #2d725a; }
.plan-compare-col-simple  { --header-bg: rgba(45, 114, 90, 0.12); --header-text: #2d725a; }
.plan-compare-col-family  { --header-bg: rgba(45, 114, 90, 0.16); --header-text: #2d725a; }
.plan-compare-col-general { --header-bg: rgba(45, 114, 90, 0.20); --header-text: #2d725a; }

.plan-compare-table thead th[class*="plan-compare-col-"] {
  color: var(--header-text);
  background: var(--header-bg);
}
/* 価格行から下（tbody）はどのプランも白バックで統一 */
.plan-compare-table tbody td[class*="plan-compare-col-"] {
  background: #fff;
}
.plan-compare-table tbody th.plan-compare-row-label {
  background: #fafafa;
}

/* 表示中のプラン列を緑の太枠で強調（塗りはなし／白バックのまま） */
.plan-compare-table th.is-current,
.plan-compare-table td.is-current {
  border-left: 3px solid var(--current-frame, #2d725a);
  border-right: 3px solid var(--current-frame, #2d725a);
}
.plan-compare-table thead th.is-current {
  background: rgba(45, 114, 90, 0.9);
  color: #fff;
  border-top: 3px solid var(--current-frame, #2d725a);
}
.plan-compare-table tbody tr:last-child td.is-current {
  border-bottom: 3px solid var(--current-frame, #2d725a);
}

/* 「表示中のプラン」バッジ（正円・写真の上端からはみ出して重ねる） */
.plan-compare-badge-current {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: absolute;
  top: -18px;
  left: 50%;
  transform: translateX(-50%);
  width:72px;
  height:72px;
  border-radius: 50%;
  background: #e8635a;
  color: #fff;
  font-size: 12.5px;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.4;
  white-space: normal;
  z-index: 3;
  box-shadow: 0 2px 6px rgba(0,0,0,0.18);
}

/* プラン名リンク（矢印つき） */
.plan-compare-table thead a,
.plan-compare-table thead th > :not(.plan-compare-img):not(.plan-compare-badge-current) {
  padding: 0;
  display: block;
}
.plan-compare-table thead a {
  position: absolute;
  inset: 0;
  color: inherit;
  text-decoration: none;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 4px;
  padding: 0 12px 16px;
  transition: opacity 0.2s ease;
}
.plan-compare-table thead a:hover {
  opacity: 0.8;
}
.plan-compare-table thead a::after {
  content: '';
  display: inline-block;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background-color: #fff;
  background-image: url('./img/arrow_green.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: 9px 6px;
}

/* 価格行 */
.plan-compare-price {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 21px;
  font-weight: 700;
  color: #d9534f;
  letter-spacing: 0.02em;
}
.plan-compare-price-unit {
  font-size: 14px;
}
.plan-compare-price-sub {
  display: block;
  font-size: 13px;
  color: #888;
  margin-top: 4px;
}

/* 流れバッジ（お通夜・告別式・出棺） */
.plan-compare-flow {
  display: flex;
  justify-content: center;
  gap: 4px;
  flex-wrap: wrap;
}
/* 1つのプランに複数パターンの流れがある場合（特別プランなど）の行間 */
.plan-compare-flow + .plan-compare-flow {
  margin-top: 6px;
}
.plan-compare-flow-badge {
  display: inline-block;
  font-size: 11px;
  padding: 1.5px 7px 2px;
  border-radius: 4px;
  background: #eee;
  color: #777;
  letter-spacing: 0.02em;
  font-weight: 500;
}
.plan-compare-flow-badge.is-on {
  background: rgba(45, 114, 90, 0.8);
  color: #fff;
}

/* 内容セル：左寄せの方が読みやすい */
.plan-compare-table td.plan-compare-desc {
  text-align: left;
  line-height: 1.8;
  font-size:14px;
}

/* スワイプヒント（モバイルのみ表示） */
.plan-compare-swipe-hint {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0 0 14px;
  color: #3f8a55;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.plan-compare-swipe-hint .arrow {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

@media (max-width: 960px) {
  .plan-compare-swipe-hint {
    display: flex;
  }
  .plan-compare-scroll {
    overflow-x: auto;
  }
  .plan-compare-table {
    min-width: 760px;
  }
  /* 1列目（プラン名ラベル列）を左固定してスクロール時も見えるように */
  .plan-compare-table th.plan-compare-row-label {
    position: sticky;
    left: 0;
    z-index: 3;
  }
}
@media (max-width: 767px) {
  .plan-compare-section {
    margin: 56px auto 72px;
    padding: 24px 16px 0;
  }
  .plan-compare-title {
    font-size: 22px;
    margin-bottom: 16px;
  }
  .plan-compare-badge-current {
    width: 50px;
    height: 50px;
    font-size: 9px;
    top: -14px;
  }
  .plan-compare-table th,
  .plan-compare-table td {
    padding: 10px 8px;
    font-size: 12px;
  }
  .plan-compare-table thead th {
    font-size: 15px;
    padding: 0 0 12px;
  }
  .plan-compare-table thead a {
    padding: 0 8px 12px;
  }
  .plan-compare-price {
    font-size: 16px;
  }
}

/* ===================================================
   共通物品・サービス カード（横長・写真+ラベル+＋アイコン）
=================================================== */
.plan-feature-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 40px;
}
.plan-feature-card {
  display: flex;
  align-items: center;
  background: #fff;
  border: 1px solid #5a9a72;
  border-radius: 10px;
  overflow: hidden;
  height: 80px;
}
.plan-feature-card-img {
  flex: 0 0 80px;
  height: calc(100% - 12px);
  overflow: hidden;
  margin-left: 6px;
  border-radius: 6px;
}
.plan-feature-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.plan-feature-card-name {
  flex: 1;
  padding: 0 15px 0 30px;
  font-size: 16px;
  font-weight: 500;
  color: #6a7a72;
  line-height: 1.4;
}

@media (max-width:1200px) {
.plan-feature-card-name {
  padding: 0 15px 0 15px;
  font-size:15px;
}
.plan-feature-card-img {
  flex: 0 0 70px;}
}

/* タブレット（1024px以下）：3列 */
@media (max-width: 1024px) {
.plan-feature-card-name {
  padding: 0 15px 0 20px;
  font-size:15px;
}
  .plan-feature-list {
    grid-template-columns: repeat(3, 1fr);
  }
}
/* 767px以下：2列 */
@media (max-width: 767px) {
  .plan-feature-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
  .plan-feature-card {
    height: 76px;
    border-radius:6px;
  }
  .plan-feature-card-img {
    flex-basis:70px;
  }
  .plan-feature-card-name {
    padding: 0 15px;
  }
}
/* 480px以下：文字をさらに小さく、余白も詰める */
@media (max-width: 480px) {
  .plan-feature-list {
    gap: 8px;
  }
  .plan-feature-card {
    height: 64px;
  }
  .plan-feature-card-img {
    flex-basis: 60px;
  }
  .plan-feature-card-name {
    font-size:13px;
    padding: 0 8px;
    line-height: 1.3;
  }
}

/* ===================================================
   プラン詳細カード（左：価格情報 / 右：写真）
   画像参考デザイン：タグ+プラン名／価格／注記／カード決済 + 大きな写真＋人数・満足度バッジ
=================================================== */
.plan-detail-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid #a8ccb8;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 48px;
  background: #fff;
  box-shadow: 0 2px 30px rgba(160,210,155,.3);
}
.plan-detail-card:last-child {
  margin-bottom: 0;
}

/* 左カラム：価格情報 */
.plan-detail-info {
  padding: 32px 36px;
  display: flex;
  flex-direction: column;
}
.plan-detail-name-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.plan-detail-name {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(24px, 2.6vw, 36px);
  font-weight: 600;
  /*color: #4a5a52;*/
  color: #2d725a;
  letter-spacing: 0.06em;
}
.plan-detail-cap {
  font-size:18px;
  color: #5a9a72;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin: 8px 0 20px;
}

.plan-detail-price-block {
  border-top: 1px solid #eee;
  padding-top: 20px;
  margin-bottom: 20px;
}
.plan-detail-price-row {
  display: flex;
  align-items: flex-end;
  gap: 14px;
  flex-wrap: wrap;
}
.plan-detail-price-label-member {
  display: inline-block;
  position: relative;
  background: #e05a4a;
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  padding: 4px 18px 4px 12px;
  /* margin-bottom: 8px; */
  border-radius: 2px 0 0 2px;
  /* 右向き矢印（ペナント型） */
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 50%, calc(100% - 10px) 100%, 0 100%);
}
.plan-detail-price-label {
  display: inline-block;
  position: relative;
font-size: 13px;
font-weight: 500;
  color:#4a5a52;
　padding:0;
}

.plan-detail-price-main {
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.plan-detail-price-main .num {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(34px, 4vw, 46px);
  font-weight: 700;
  color: ver(--text-light);
  letter-spacing: 0.02em;
}
.plan-detail-price-main .unit {
  font-size: 20px;
  font-weight: 700;
  color: ver(--text-light);
}
.plan-detail-price-main .tax {
  font-size:18px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight:600;
  color: ver(--text-light);
  margin-left: 4px;
}
.plan-detail-price-tax-total {
  font-size: 16px;
  color: #777;
  /* margin-top: 6px; */
}

/* 金額の下（カード決済の場所）に表示する「流れ」 */
.plan-detail-flow {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
  flex-wrap: wrap;
}
.plan-detail-flow-badge {
  display: inline-block;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 5px 14px 6px;
  border-radius: 999px;
  background: #eee;
  color: #888;
}
.plan-detail-flow-badge.is-on {
  background: var(--plan-color, #1a6640);
  color: #fff;
}
.plan-detail-flow-arrow {
  display: inline-flex;
  align-items: center;
  color: #ccc;
}

/* 右カラム：写真 */
.plan-detail-photo {
  position: relative;
  background: #f0f0f0;
  min-height: 320px;
}
.plan-detail-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@media (max-width: 960px) {
  .plan-detail-card {
    grid-template-columns: 1fr;
  }
  .plan-detail-photo {
    min-height: 240px;
    order: -1;
  }
}
@media (max-width: 767px) {
  .plan-detail-info {
    padding: 24px 20px;
  }
  .plan-detail-name {
    font-size: 22px;
  }
  .plan-detail-price-main .num {
    font-size: 30px;
  }
  .plan-detail-flow-badge {
    font-size: 11px;
    padding: 4px 10px;
  }
}


/* ================================================
   plan_home.html 専用スタイル：自宅葬メリット
   ================================================ */

.plan-home-merit {
  margin: 48px 0 40px;
  text-align: center;
}

.plan-home-merit-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 22px;
  font-weight: 500;
  color: #1a6640;
  letter-spacing: 0.08em;
  margin: 0 0 32px;
  padding-left: 0 !important;
}

.plan-home-merit-title::before {
  display: none !important;
}

.plan-home-merit-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  text-align: left;
}

.plan-home-merit-card {
  background: #f6faf7;
  border: 1px solid #c8e0d0;
  border-top: 3px solid #3a8a5c;
  border-radius: 6px;
  padding: 28px 24px 24px;
}

.plan-home-merit-icon {
  width: 48px;
  height: 48px;
  margin: 0 0 14px;
  opacity: 0.75;
}

.plan-home-merit-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.plan-home-merit-head {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: #1a5c38;
  line-height: 1.55;
  margin: 0 0 12px;
  letter-spacing: 0.04em;
}

.plan-home-merit-body {
  font-size: 13.5px;
  color: #3a4a40;
  line-height: 1.8;
  margin: 0;
}

@media (max-width: 767px) {
  .plan-home-merit-list {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .plan-home-merit-card {
    padding: 22px 18px 20px;
  }
  .plan-home-merit-title {
    font-size: 18px;
  }
}
/* ===================================================
   お寺・ご僧侶のご紹介ページ（monk.html）
=================================================== */

/* ヒーロー：背景画像 */
.monk-hero {
  position: relative;
  height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  background-image: url('img/monk/monk-banner.webp');
  background-size: cover;
  background-position: center;
}
.monk-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(20,42,32,0.55) 0%, rgba(20,42,32,0.68) 100%);
}
.monk-hero-inner {
  position: relative;
  z-index: 1;
  color: #fff;
}
.monk-hero-label {
  font-size: 13px;
  letter-spacing: 0.2em;
  color: #d8ecdf;
  margin-bottom: 14px;
}
.monk-hero-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(24px, 3.4vw, 34px);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.6;
}

@media (max-width: 767px) {
  .monk-hero {
    height: 260px;
    padding: 0 20px;
  }
}

/* 本文共通 */
.monk-section {
  max-width: 860px;
  margin:30px auto 0;
  padding-bottom:50px;
}
.monk-section:last-child {
  margin-bottom: 0;
}
.monk-section h2.monk-section-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(19px, 2.2vw, 26px);
  font-weight: 700;
  color: #127b45;
  text-indent: 20px;
  margin-bottom:33px;
  letter-spacing: 0.02em;
  text-align: left;
  line-height: 1.6;
  position:relative;
}
.monk-section h2.monk-section-title:before {
content:"";
display:block!important;
width:62px;
height:62px;
border-radius:0;
background:url("./img/plan/jyuzu.svg") no-repeat;
position:absolute;
top:-10px;
left:-20px;
}




.monk-section-text {
  font-size: 16px;
  line-height: 2.1;
  color: #2a3d30;
  letter-spacing: 0.03em;
}
.monk-section-text + .monk-section-text {
  margin-top: 1.4em;
}

/* このような方にご利用いただいています：チェックリスト */
.monk-check-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.monk-check-list li {
  position: relative;
  padding: 16px 4px 16px 32px;
  font-size:18px;
  font-weight:500;
  line-height: 1.8;
  color: #127b45;
  letter-spacing: 0.02em;
  border-bottom: 1px solid #deeee6;
}
.monk-check-list li:first-child {
  border-top: 1px solid #deeee6;
}
.monk-check-list li::before {
  content: '';
  position: absolute;
  left: 4px;
  top: 24px;
  width: 8px;
  height: 8px;
  border-right: 2px solid #44bb88;
  border-bottom: 2px solid #44bb88;
  transform: rotate(45deg) translateY(-50%);
}

/* 宗派についての補足ボックス */
.monk-note-box {
  background: #fff;
  border: 1px solid #127b45;
  border-radius: 12px;
  padding: 20px 32px;
  text-align: center;
  margin: 15px auto 0;
}
.monk-note-box-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #127b45;
  letter-spacing: 0.04em;
  margin-bottom: 10px;
}
.monk-note-box-text {
  font-size: 15px;
  line-height: 1.9;
  color: #4a5a52;
  letter-spacing: 0.02em;
}


@media (max-width: 767px) {
  .monk-quote-box { padding: 24px 22px; }
  .monk-note-box { padding: 22px 22px; }
  .monk-check-list li { font-size: 15px; padding: 14px 4px 14px 28px; }
}

.monk-fuse-table {
  max-width: 80%;
  margin: 0 auto 16px;
  border: 1px solid #127b45;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}
.monk-fuse-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 32px;
  border-bottom: 1px solid #127b45;
}
.monk-fuse-row:last-child {
  border-bottom: none;
}
.monk-fuse-name {
  font-size:20px;
  color: #2a3d30;
  letter-spacing: 0.04em;
  font-weight: 500;
}
.monk-fuse-price {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size:30px;
  font-weight: 700;
  color: #127b45;
  letter-spacing: 0.02em;
}
.monk-fuse-price .unit {
  font-size:18px;
  font-weight:500;
  margin-left: 2px;
  color: #4a5a52;
}

.monk-fuse-note {
  max-width:80%;
  margin: 0 auto 72px;
  text-align: center;
  font-size: 16px;
  line-height: 1.9;
  color: #4a5a52;
  letter-spacing: 0.02em;
  background: #f0f6f2;
  border-radius: 8px;
  padding: 16px 20px;
}

@media (max-width: 767px) {
  .monk-fuse-row {
    padding: 18px 22px;
  }
  .monk-fuse-name { font-size: 15px; }
  .monk-fuse-price { font-size: 18px; }
}
/* ===================================================
   供花のご注文ページ（kyouka.html）
=================================================== */

.kyouka-category {
  margin-bottom: 64px;
}
.kyouka-category-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(20px, 2.2vw, 30px);
  font-weight: 600;
  color: #1a6640;
  letter-spacing: 0.06em;
  text-align: center;
  margin-bottom: 32px;
  padding-bottom: 10px;
  border-bottom: 3px solid #deeee6;
}

.kyouka-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.kyouka-card {
  background: #fff;
  border: 1px solid #deeee6;
  border-radius: 12px;
  overflow: hidden;
  text-align: center;
}
.kyouka-card-img {
  position: relative;
  width: 100%;
  aspect-ratio: 5 / 4.5;
  overflow: hidden;
  background: #f0f6f2;
  padding: 15px 0 5px;
}
.kyouka-card-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.kyouka-card-number {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 30px;
  padding: 0 14px;
  background: #fff;
  color: #1a6640;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
  border-radius: 15px;
  box-shadow: 0 0px 12px rgba(160,210,155,.5);
}
.kyouka-card-body {
  padding: 18px 16px 22px;
}
.kyouka-card-label {
  font-size: 16px;
  color: #4a5a52;
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}
.kyouka-card-price {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #127b45;
  letter-spacing: 0.02em;
  line-height: 1.7;
}
.kyouka-card-price .price-unit {
  font-size: 13px;
  font-weight: 400;
  color: #4a5a52;
  margin-right: 4px;
}

@media (max-width: 960px) {
  .kyouka-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}
@media (max-width: 600px) {
  .kyouka-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  .kyouka-card-body {
    padding: 12px 12px 16px;
  }
  .kyouka-card-price {
    font-size: 14px;
  }
}

@media (max-width:480px) {
.kyouka-card-img {
  position: relative;
  width: 100%;
  aspect-ratio: 5 / 6.5;
  overflow: hidden;
  background: #f0f6f2;
  padding:30px 0 0px;
}
}

/* 注文フォーム */
.kyouka-order-section {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 60px 96px;
}
.kyouka-order-box {
  max-width: 720px;
  margin: 0 auto;
  background: #f0f6f2;
  border-radius: 12px;
  padding: 44px 48px;
}
.kyouka-order-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(20px, 2.2vw, 23px);
  font-weight: 700;
  color: #1a6640;
  letter-spacing: 0.04em;
  text-align: center;
  margin-bottom: 8px;
}
.kyouka-order-desc {
  font-size: 14px;
  color: #4a5a52;
  letter-spacing: 0.03em;
  text-align: center;
  margin-bottom: 32px;
}
.kyouka-order-form {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px 24px;
}
.kyouka-order-field {
  display: flex;
  flex-direction: column;
}
.kyouka-order-field--full {
  grid-column: 1 / -1;
}
.kyouka-order-field label {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: #1a6640;
  letter-spacing: 0.03em;
  margin-bottom: 8px;
}
.kyouka-order-field label .req {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 8px;
  background: #c0392b;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  border-radius: 3px;
  vertical-align: middle;
}
.kyouka-order-field label .opt {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 8px;
  background: #9bb3a6;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  border-radius: 3px;
  vertical-align: middle;
}
.kyouka-order-field input,
.kyouka-order-field select,
.kyouka-order-field textarea {
  width: 100%;
  padding: 13px 16px;
  background: #fff;
  border: 1px solid #d6e3dc;
  border-radius: 6px;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 14px;
  color: #2a332e;
  letter-spacing: 0.02em;
}
.kyouka-order-field textarea {
  resize: vertical;
  min-height: 100px;
  line-height: 1.7;
}
.kyouka-order-field input:focus,
.kyouka-order-field select:focus,
.kyouka-order-field textarea:focus {
  outline: none;
  border-color: #1a6640;
}
.kyouka-order-field input::placeholder,
.kyouka-order-field textarea::placeholder {
  color: #a9b8b0;


}
.kyouka-order-amount {
  display: flex;
  align-items: center;
}
.kyouka-order-amount input {
  text-align: right;
}
.kyouka-order-amount-suffix {
  margin-left: 10px;
  font-size: 14px;
  color: #4a5a52;
  white-space: nowrap;
}
/* 支払い方法 案内文 */
.kyouka-order-payment-note {
  font-size: 13px;
  color: #6a7a72;
  line-height: 1.8;
  margin-top: 10px;
  padding: 10px 14px;
  background: #f0f6f2;
  border-radius: 6px;
  letter-spacing: 0.02em;
}
/* ラジオボタン（支払い方法） */
.kyouka-order-radio-group {
  display: flex;
  gap: 28px;
  align-items: center;
  padding: 10px 0 4px;
}
.kyouka-order-radio {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  color: #4a5a52;
  cursor: pointer;
}
.kyouka-order-radio input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: #1a6640;
  cursor: pointer;
}
/* ご請求先 セクション区切り */
.sub-section-divider {
  border-top: 1px solid #c8ddd1;
  padding-top: 20px !important;
  margin-top: 8px;
}
.kyouka-order-section-label {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #1a6640;
  letter-spacing: 0.06em;
  margin: 0;
}
.kyouka-order-submit-wrap {
  grid-column: 1 / -1;
  text-align: center;
  margin-top: 12px;
}
.kyouka-order-submit {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 15px 56px;
  background: #1a6640;
  color: #fff;
  border: none;
  border-radius: 4px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: background 0.2s;
}
.kyouka-order-submit::after {
  content: "";
  width: 7px;
  height: 7px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}
.kyouka-order-submit:hover {
  background: #127b45;
}
.kyouka-order-note {
  grid-column: 1 / -1;
  font-size: 12.5px;
  color: #4a5a52;
  letter-spacing: 0.02em;
  line-height: 1.8;
  margin-top: -4px;
}

@media (max-width: 600px) {
  .kyouka-order-box {
    padding: 32px 22px;
  }
  .kyouka-order-form {
    grid-template-columns: 1fr;
    gap: 18px;
  }
}

/* 盛籠AB ラベル */
.sub-ab-label {
  position: absolute;
  bottom: 10px;
  background: rgba(255, 255, 255, 0.88);
  color: #1a6640;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 14px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 4px;
  letter-spacing: 0.05em;
  line-height: 1.4;
}
.sub-ab-a {
  left: 10px;
}
.sub-ab-b {
  right: 10px;
}

/* 盛籠【A】【B】あり専用：区切り線（PC・SP共通） */

/* 【A】行の下に区切り線（常時） */
.kyouka-card-price.price-ab-a {
  padding-bottom: 6px;
  border-bottom: 1px solid #c8ddd1;
  margin-bottom: 4px;
}
/* 【B】行の上余白を詰める */
.kyouka-card-price.price-ab-b {
  margin-top: 0;
}

/* WEB申込みCTAボックス（旧FAXボックス置き換え） */
.sub-order-cta-box {
  max-width: 720px;
  margin: 0 auto 72px;
  text-align: center;
}
.sub-order-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 48px;
  background: #1a6640;
  color: #fff;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-decoration: none;
  border-radius: 6px;
  transition: background 0.2s, opacity 0.2s, transform 0.2s;
  margin-bottom: 16px;
}
.sub-order-cta-btn:hover {
  background: #127b45;
  opacity: 0.9;
  transform: translateY(-2px);
}
.sub-order-cta-btn:hover .btn-arrow img {
  transform: translateX(4px);
  transition: transform 0.2s;
}
.sub-order-cta-btn .btn-arrow {
  display: flex;
  align-items: center;
}
.sub-order-cta-btn .btn-arrow img {
  filter: brightness(0) invert(1);
}
.sub-fax-note {
  font-size: 13px;
  color: #7a8a82;
  letter-spacing: 0.03em;
  margin-top: 4px;
}
.sub-fax-note-link {
  color: #7a8a82;
  text-decoration: underline;
}
.sub-fax-note-link:hover {
  color: #1a6640;
}

/* 金額を大きく */
.kyouka-card-price {
  font-size: 22px !important;
}
.kyouka-card-price .price-unit {
  font-size: 13px !important;
}
@media (max-width: 600px) {
  .kyouka-card-price {
    font-size: 17px !important;
    line-height: 1.5;
  }
  .sub-order-cta-btn {
    font-size: 16px;
    padding: 14px 32px;
  }
}

/* 円（税込）をさらに小さく */
.kyouka-card-price .price-taxincl {
  font-size: 10px !important;
  font-weight: 400;
  color: #4a5a52;
  letter-spacing: 0.02em;
}

/* price-unit（一基・一対・一籠）と円（税込）を13pxに統一 */
.kyouka-card-price .price-unit,
.kyouka-card-price .price-taxincl {
  font-size: 13px !important;
  font-feature-settings: "palt";
  font-family: 'Noto Sans JP', sans-serif;
}

/* price-unit（一基・一対・一籠）を15pxに */
.kyouka-card-price .price-unit {
  font-size: 15px !important;
}

/* フォーム文字 全体+2px */
.kyouka-order-field label {
  font-size: 15px !important;
}
.kyouka-order-field input,
.kyouka-order-field select,
.kyouka-order-field textarea {
  font-size: 16px !important;
}
.kyouka-order-field select {
  font-size: 15px !important;
}
.kyouka-order-amount-suffix {
  font-size: 16px !important;
}
.kyouka-order-submit {
  font-size: 17px !important;
}
.kyouka-order-note {
  font-size: 14.5px !important;
}

/* フォーム横幅を900pxに拡大 */
.kyouka-order-box {
  max-width: 900px !important;
}

@media (max-width: 480px) {
  .kyouka-card-price .price-unit {display:block;text-align:left;text-indent: 1em;margin: 0 0 0 0;line-height: 1.5;}
  /* has-ab（【A】【B】あり）カードでは「一籠」はインライン表示を維持 */
  .has-ab .kyouka-card-price .price-unit {
    display: inline !important;
    text-indent: 0 !important;
    margin-right: 2px !important;
    line-height: inherit !important;
  }
}


/* ===================================================
   供花注文完了（thanks.html）
=================================================== */
.sub-thanks-box {
  text-align: center;
  padding: 60px 40px 72px;
  background: #f0f6f2;
  border-radius: 12px;
}
.sub-thanks-icon {
  margin-bottom: 20px;
}
.sub-thanks-leaf {
  width: 36px;
  opacity: 0.7;
}
.sub-thanks-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(22px, 3vw, 28px);
  font-weight: 700;
  color: #1a6640;
  letter-spacing: 0.08em;
  margin-bottom: 20px;
}
.sub-thanks-lead {
  font-size: 16px;
  color: #4a5a52;
  line-height: 1.9;
  margin-bottom: 28px;
}
.sub-thanks-note {
  font-size: 14px;
  color: #6a7a72;
  line-height: 1.9;
  background: #fff;
  border-radius: 8px;
  padding: 18px 24px;
  margin-bottom: 32px;
  text-align: left;
  display: inline-block;
  width: 100%;
  box-sizing: border-box;
}
.sub-thanks-note p {
  margin: 0 0 6px;
}
.sub-thanks-note p:last-child {
  margin-bottom: 0;
}
.sub-thanks-tel {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin-bottom: 36px;
}
.sub-thanks-tel-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 26px;
  font-weight: 700;
  color: #1a6640;
  text-decoration: none;
  letter-spacing: 0.04em;
}
.sub-thanks-tel-link:hover {
  opacity: 0.75;
}
.sub-thanks-tel-note {
  font-size: 13px;
  color: #6a7a72;
  letter-spacing: 0.04em;
}
.sub-thanks-back {
  display: inline-block;
  font-size: 14px;
  color: #1a6640;
  text-decoration: underline;
  letter-spacing: 0.04em;
}
.sub-thanks-back:hover {
  opacity: 0.7;
}
@media (max-width: 600px) {
  .sub-thanks-box {
    padding: 40px 20px 52px;
  }
  .sub-thanks-note {
    text-align: left;
    padding: 14px 16px;
  }
  .sub-thanks-tel-link {
    font-size: 22px;
  }
}

/* ===================================================
   かがやきの会（member.html）
=================================================== */

.member-hero-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1.3;
  margin-bottom: 18px;
}
.member-hero-catch {
  display: inline-block;
	color:#2d725a;
	font-weight:500;
  font-size: clamp(12px, 1.3vw, 14px);
  letter-spacing: 0.02em;
  background-color: #fff;
  border-radius: 20px;
  padding:4px 22px 6px;
}
/* hero 葉っぱアイコン単体 */
.member-hero-leaf-icon {
  margin-bottom: 20px;
}
.member-hero-leaf-icon img {
  width: 48px;
  height: 48px;
  filter: none;
  opacity: 0.85;
}


/* 特典1 ゴールドバッジ */
.member-benefit-badge--gold {
  border-color: #c8a84b;
  background: #c8a84b;
}
.member-benefit-badge--gold .member-benefit-badge-label,
.member-benefit-badge--gold .member-benefit-badge-num {
  color: #fff;
}

@media (max-width: 767px) {
  .member-hero-catch { font-size: 11px; padding: 5px 16px; }
}

/* ラップ */
.member-wrap {
  background: #f5f9f6;
}

/* セクション共通 */
.member-page-section {
  padding: 80px 20px;
}
.member-page-section:nth-child(even) {
  background: #fff;
}
.member-page-section-inner {
  max-width: 860px;
  margin: 0 auto;
}

/* ABOUTセクション内 旧heroブロック */
.member-about-hero-block {
  text-align: center;
  margin-bottom: 33px;
}
.member-about-hero-block .member-hero-leaf-icon {
  margin-bottom: 16px;
}
.member-about-hero-block .member-hero-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 700;
  letter-spacing: 0.12em;
  color: #006F38;
  line-height: 1.3;
  margin-bottom: 16px;
  text-shadow: 0px 2px 12px rgba(255,255,255,0.8), 0 0 24px rgba(255,255,255,0.6);
}
.member-about-hero-block .member-hero-catch {
  display: inline-block;
  color: #fff;
  font-weight: 500;
  font-size: clamp(13px, 1.4vw, 16px);
  letter-spacing: 0.04em;
  color: #c8a84b;
	border:3px solid #c8a84b;
  border-radius:30px;
  padding: 6px 28px 8px;
}

/* ABOUTセクション専用背景 — heroと同じ画像でつながって見せる */
.member-page-section--lead {
  background-image: url('img/member/member_back.webp') !important;
  background-size: cover !important;
  background-position: center 55% !important;
  background-attachment: fixed !important;
  position: relative;
}
.member-page-section--lead::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, rgba(255,248,252,0.52) 0%, rgba(240,255,248,0.62) 40%, rgba(255,248,240,0.60) 100%);
  pointer-events: none;
  z-index: 0;
}
.member-page-section--lead .member-page-section-inner {
  position: relative;
  z-index: 1;
}

/* セクション見出し */
.member-service-label {
  font-size: 13.5px;
  letter-spacing: 0.08em;
  color: #1a6640;
  text-align: center;
  margin-bottom: 2px;
}
.member-lead-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(24px, 2.8vw, 30px);
  font-weight: 600;
  color: #006F38;
  text-align: center;
  letter-spacing: 0.08em;
  margin: 0 0 6px;
}
.member-lead-divider {
  width: 36px;
  height: 2px;
  background: #6aaa80;
  margin: 14px auto 36px;
  border-radius: 1px;
}
.member-lead-text {
  font-size: 16px;
  line-height: 2.2;
  font-weight: 500;
  color: var(--green-deep);
  /* color: rgba(255,255,255,0.88); */
  background: rgba(255,255,255,1.0);
  letter-spacing: 0.04em;
  padding: 20px 15px 25px;
  border-radius: 20px;
  text-align: center;
  margin-bottom: 40px;
}

/* 旧名称ボックス */
.member-rename-box {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  color: #1a5535;
  /* background: rgba(255,255,255,0.92); */
  /* border-left: 3px solid #6ecf94; */
  border-radius: 8px;
  /* padding: 22px 30px; */
  max-width: 600px;
  margin: 0 auto;
}
.member-rename-icon {
  font-size: 18px;
  color: #2d8a5a;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 2px;
}
.member-rename-title {
  font-size: 14.5px;
  font-weight: 500;
  color: #1a5535;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}
.member-rename-text {
  font-size: 13.5px;
  color: #3a6a4a;
  letter-spacing: 0.03em;
}

/* BENEFITセクション専用 - 見出し色を白以外に戻す */
.member-page-section--benefit { background: #fff; }
.member-page-section--benefit .member-lead-divider { background: #44a86a; }

/* 特典リスト */
.member-benefit-list {
  list-style: none;
  margin: 32px 0 0;
  padding: 0;
  border-top: 1px solid #c8a84b;
}
.member-benefit-item {
  display: flex;
  align-items: flex-start;
  gap: 28px;
  padding: 32px 8px;
  border-bottom: 1px solid #c8a84b;
}

/* 番号バッジ */
.member-benefit-badge {
  flex-shrink: 0;
  width: 60px;
  height: 60px;
  border: 1.5px solid #c8a84b;
  background: #c8a84b;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}
.member-benefit-badge-label {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.14em;
  color: #fff;
  line-height: 1;
  margin-bottom: 1px;
}
.member-benefit-badge-num {
  /* font-family: 'Noto Sans JP', sans-serif; */
  font-size: 24px;
  font-weight: 500;
  color: #fff;
  line-height: 1;
  letter-spacing: 0;
}

/* テキストエリア */
.member-benefit-body {
  flex: 1;
  min-width: 0;
}
.member-benefit-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(18px, 1.9vw, 28px);
  font-weight: 700;
  color: #127b45;
  letter-spacing: 0.06em;
  line-height: 1.5;
  margin: 0 0 10px;
}
.member-benefit-desc {
  font-size: 16px;
  color: #1a3d28;
  font-weight: 500;
  line-height: 2.0;
  letter-spacing: 0.04em;
  margin: 0;
}
.member-benefit-note {
  display: inline-block;
  font-size: 12.5px;
  color: #6a8a76;
  letter-spacing: 0.03em;
  line-height: 1.8;
  margin-top: 6px;
}

/* 金額ハイライト */
.member-benefit-price {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  font-size: 14px;
  color: #4a6055;
  flex-wrap: wrap;
}
.member-benefit-price .before {
  text-decoration: line-through;
  color: #9ab0a0;
}
.member-benefit-price .arrow {
  display: inline-flex;
  align-items: center;
  color: #2d7a55;
}
.member-benefit-price .after {
  font-weight: 500;
  color: #c8a84b;
  font-size: 17px;
}
.member-benefit-price .after sub {
  font-size: 11px;
  vertical-align: baseline;
  position: relative;
  top: 2px;
}

@media (max-width: 767px) {
  .member-benefit-item {
    gap: 18px;
    padding: 24px 4px;
  }
  .member-benefit-badge {
    width: 48px;
    height: 48px;
  }
  .member-benefit-badge-num { font-size: 17px; }
}

@media (max-width: 767px) {
  .member-page-section { padding: 56px 20px; }
}

/* 会員特典 葉っぱアイコン */
.member-lead-leaf-icon {
  text-align: center;
  margin-bottom: 10px;
}
.member-lead-leaf-icon img {
  width: 36px;
  height: 36px;
  opacity: 0.85;
}

/* クロージングテキスト */
.member-closing-text {
  font-size: 16px;
  line-height: 2.2;
  font-weight: 500;
  color: var(--green-deep);
  letter-spacing: 0.04em;
  text-align: center;
  margin: 0;
}

/* ===================================================
   contact.html 専用スタイル
   ================================================ */

/* ヒーロー：中央配置・画像なし */
.sub-contact-hero {
  text-align: center;
}
.sub-contact-hero .subpage-hero-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 24px 20px 28px;
}
.sub-contact-hero .subpage-hero-title {
  font-size: clamp(24px, 3vw, 32px);
}

/* お問合せリード */
.sub-contact-lead {
  text-align: center;
  margin: 0 auto 40px;
  max-width: 640px;
  font-size: 17px;
  line-height: 2;
  color: #4a5a4f;
}

/* 電話CTAボックス */
.sub-contact-tel-box {
  background: #f0f6f2;
  border: 1px solid #c8dece;
  border-radius: 8px;
  padding: 28px 32px;
  margin: 0 auto 48px;
  max-width: 560px;
  text-align: center;
}
.sub-contact-tel-box .tel-label {
  font-size: 14px;
  font-weight: 500;
  color: #5a9a72;
  letter-spacing: 0.18em;
  margin-bottom: 6px;
}
.sub-contact-tel-box .tel-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 24px;
  letter-spacing: 2px;
  font-weight: 600;
  color: #006F38;
  margin-bottom: 10px;
}
.sub-contact-tel-box .tel-number {
  display: inline-block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(28px, 4vw, 38px);
  font-weight: 500;
  color: #1a6640;
  letter-spacing: 0.05em;
  text-decoration: none;
}
.sub-contact-tel-box .tel-number:hover { color: #2d8a5c; }
.sub-contact-tel-box .tel-note {
  font-size: 15px;
  color: #6a7a6f;
  margin-top: 6px;
}

/* セクション見出し（フォーム）*/
.sub-contact-form-head {
  text-align: center;
  margin-bottom: 32px;
}
.sub-contact-form-head .form-head-en {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.28em;
  color: #5a9a72;
  text-transform: uppercase;
  display: block;
  margin-bottom: 6px;
}
.sub-contact-form-title {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: clamp(20px, 2.4vw, 22px);
  color: #4a5a52;
  font-weight: 600;
  letter-spacing: 0.12em;
  margin: 0;
  padding-left: 0 !important;
}
.sub-contact-form-title::before {
  display: none !important;
}
.sub-contact-divider {
  display: flex;
  justify-content: center;
  margin: 10px 0 0;
}

/* フォームラッパー */
.sub-contact-form-wrap {
  width: 100%;
  max-width: 100%;
  margin: 0 auto 56px;
  background: #fff;
  border: 1px solid #dce8e0;
  border-radius: 10px;
  padding: 40px 48px;
}
@media (max-width: 640px) {
  .sub-contact-form-wrap { padding: 28px 20px; }
}

/* 必須注記 */
.sub-contact-required-note {
  font-size: 12px;
  color: #888;
  margin-bottom: 24px;
}
.sub-contact-required-note .req {
  color: #c0392b;
  font-weight: 500;
}

/* フォーム行 */
.sub-form-row {
  display: flex;
  gap: 0;
  margin-bottom: 20px;
  border-bottom: 1px solid #eaf0eb;
  padding-bottom: 20px;
  align-items: flex-start;
}
.sub-form-row:last-of-type {
  border-bottom: none;
  padding-bottom: 0;
}
.sub-form-label {
  width: 200px;
  flex-shrink: 0;
  font-size: 16px;
  color: #2a3a2f;
  font-weight: 500;
  padding-top: 10px;
  line-height: 1.5;
}
.sub-form-label .req {
  color: #c0392b;
  font-size: 11px;
  margin-left: 4px;
  vertical-align: top;
  line-height: 2;
}
.sub-form-field {
  flex: 1;
}

/* インプット・テキストエリア共通 */
.sub-form-field input[type="text"],
.sub-form-field input[type="email"],
.sub-form-field input[type="tel"],
.sub-form-field textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 11px 14px;
  border: 1px solid #c8d8cc;
  border-radius: 5px;
  font-size: 16px;
  font-family: 'Noto Sans JP', sans-serif;
  color: #2a3a2f;
  background: #fafdfb;
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
}
.sub-form-field input:focus,
.sub-form-field textarea:focus {
  border-color: #4a9a6a;
  box-shadow: 0 0 0 3px rgba(74,154,106,0.12);
  background: #fff;
}

/* 氏名横並び */
.sub-form-name-pair {
  display: flex;
  gap: 12px;
}
.sub-form-name-pair .name-group {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.sub-form-name-pair .name-group label {
  font-size: 11px;
  color: #6a7a6f;
  letter-spacing: 0.05em;
}

/* ラジオ・チェックボックス */
.sub-form-options {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  padding-top: 8px;
}
.sub-form-options label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 16px;
  color: #2a3a2f;
  cursor: pointer;
}
.sub-form-options input[type="radio"],
.sub-form-options input[type="checkbox"] {
  accent-color: #2d7a50;
  width: 15px;
  height: 15px;
  cursor: pointer;
}

/* テキストエリア */
.sub-form-field textarea {
  min-height: 120px;
  resize: vertical;
}

/* 郵送先（条件表示） */
.sub-form-postal-fields {
  margin-top: 16px;
  padding: 16px;
  background: #f4f9f5;
  border-radius: 6px;
  border: 1px solid #dce8e0;
  display: none;
}
.sub-form-postal-fields.visible { display: block; }
.sub-form-postal-fields input {
  margin-bottom: 10px;
}
.sub-form-postal-fields input:last-child { margin-bottom: 0; }
.sub-form-postal-note {

  font-size: 11px;
  color: #888;
  margin-top: 4px;
}

/* プライバシー同意 */
.sub-contact-privacy {
  width: 100%;
  max-width: 100%;
  margin: 0 auto 28px;
  font-size: 13px;
  color: #4a5a4f;
  line-height: 1.8;
  background: #f4f9f5;
  border: 1px solid #dce8e0;
  border-radius: 8px;
  padding: 20px 24px;
}

/* 送信ボタン */
.sub-contact-submit {
  text-align: center;
  margin-bottom: 64px;
}
.sub-contact-submit button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 56px;
  background: #1a6640;
  color: #fff;
  border: none;
  border-radius: 50px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.1em;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s;
}
.sub-contact-submit button:hover {
  background: #2d8a5c;
  transform: translateY(-2px);
}

/* モバイル調整 */
@media (max-width: 640px) {
  .sub-form-row {
    flex-direction: column;
    gap: 8px;
  }
  .sub-form-label {
    width: 100%;
    padding-top: 0;
  }
  .sub-form-name-pair {
    flex-direction: column;
    gap: 10px;
  }
  .sub-contact-tel-box { padding: 24px 20px; }
}

/* ===================================================
   emergency.html 専用スタイル
   ================================================ */

/* ヒーロー：中央配置（contactと同じ） */
.sub-emergency-hero {
  text-align: center;
}
.sub-emergency-hero .subpage-hero-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 24px 20px 28px;
  text-align: center;
}
.sub-emergency-hero .subpage-hero-title {
  font-size: clamp(24px, 3vw, 32px);
}

/* 電話番号：緊急カラー */
.sub-contact-tel-box .tel-number {
  color: #e05a4a !important;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 600;
}
.sub-contact-tel-box .tel-number:hover {
  color: #c94535 !important;
}

/* 情報カード（お伺い内容・ご準備） */
.sub-emg-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin-bottom: 48px;
}
.sub-emg-info-card {
  background: #fff;
  border: 3px solid #dce8e0;
  border-radius: 10px;
  padding: 36px 32px;
}
/* sub-emg-info-title: .subpage-wrap h2::before の縦線・paddingをリセット */
.sub-emg-info-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 22px;
  font-weight: 600;
  color: #4a5a52;
  letter-spacing: 0.06em;
  margin: 0 0 24px;
  padding-bottom: 16px;
  padding-left: 0 !important;
  border-bottom: 1px solid #dce8e0;
  font-family: 'Zen Maru Gothic', sans-serif;
}
.sub-emg-info-title::before {
  display: none !important;
}
.sub-emg-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sub-emg-list li {
  font-size: 16px;
  color: #2a3a2f;
  letter-spacing: 0.03em;
  padding: 10px 0;
  border-bottom: 1px solid #eaf0eb;
  display: flex;
  align-items: center;
  gap: 10px;
}
.sub-emg-list li::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #6aaa80;
  flex-shrink: 0;
}
.sub-emg-note {
  font-size: 13px;
  color: #888;
  margin: 12px 0 0;
}

/* ご準備リスト */
.sub-emg-list--prepare li {
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}
.sub-emg-list--prepare li::before { display: none; }
.sub-emg-prepare-name {
  font-size: 18px;
  font-weight: 500;
  color: #1a6640;
  display: flex;
  align-items: center;
  gap: 8px;
}
.sub-emg-prepare-name::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #6aaa80;
}
.sub-emg-prepare-desc {
  font-size: 14.5px;
  color: #4a5a4f;
  line-height: 1.8;
  padding-left: 13px;
}

@media (max-width: 767px) {
  .sub-emg-info-grid { grid-template-columns: 1fr; }
  .sub-emg-info-card { padding: 28px 20px; }
}

