@charset "UTF-8";

/* =========================================
   ヘッダー
   ========================================= */
.header { position: sticky; top: 0; z-index: 100; background: rgba(26, 26, 26, 0.95); backdrop-filter: blur(6px); }
.header__bar { display: flex; align-items: center; justify-content: space-between; width: 96%; max-width: var(--container); margin-inline: auto; min-height: 72px; }
.header__logo { width: 180px; }
.header__logo img { width: 100%; height: auto; }
.header__tel { padding: 9px 22px; font-size: 15px; letter-spacing: 0.06em; color: var(--color-white); border: 1px solid rgba(255, 255, 255, 0.5); }
.header__tel:hover { color: var(--color-ink); background: var(--color-white); opacity: 1; }

/* グローバルナビ（PC＝2段目・中央寄せ） */
.global-nav__list { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 0 2px; width: 96%; max-width: var(--container); margin-inline: auto; padding-bottom: 8px; }
.global-nav__item a { display: block; padding: 10px 15px; font-size: 14px; letter-spacing: 0.08em; color: var(--color-white); }
.global-nav__item--accent a { color: var(--color-gold); }
.global-nav__item--tel { display: none; }

/* ハンバーガー（SPのみ表示） */
.hamburger { display: none; }
.hamburger__bars { position: relative; display: block; width: 28px; height: 18px; }
.hamburger__bars span { position: absolute; left: 0; width: 100%; height: 2px; background: var(--color-white); transition: transform 0.3s ease, opacity 0.3s ease; }
.hamburger__bars span:nth-child(1) { top: 0; }
.hamburger__bars span:nth-child(2) { top: 8px; }
.hamburger__bars span:nth-child(3) { top: 16px; }
.hamburger__label { display: block; margin-top: 4px; font-size: 9px; letter-spacing: 0.1em; color: var(--color-white); text-align: center; }
.hamburger[aria-expanded="true"] .hamburger__bars span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.hamburger[aria-expanded="true"] .hamburger__bars span:nth-child(2) { opacity: 0; }
.hamburger[aria-expanded="true"] .hamburger__bars span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* =========================================
   ヒーロー（トップ動画）
   ========================================= */
.hero { position: relative; width: 100%; height: min(86vh, 720px); overflow: hidden; }
.hero__video { position: absolute; top: 50%; left: 50%; min-width: 100%; min-height: 100%; transform: translate(-50%, -50%); object-fit: cover; }
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(rgba(0, 0, 0, 0.35), rgba(0, 0, 0, 0.45)); }
.hero__inner { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 0 6%; color: var(--color-white); text-align: center; text-shadow: 0 2px 12px rgba(0, 0, 0, 0.5); }
.hero__title { font-size: clamp(26px, 4.4vw, 52px); letter-spacing: 0.16em; line-height: 1.6; }
.hero__lead { margin-top: 24px; font-size: clamp(13px, 1.6vw, 18px); letter-spacing: 0.12em; line-height: 2; }

/* =========================================
   創業二四〇年
   ========================================= */
.founding { padding: clamp(64px, 9vw, 120px) 0; background: var(--color-washi); text-align: center; }
.founding__title { font-size: clamp(22px, 3vw, 30px); letter-spacing: 0.2em; }
.founding__title span { display: block; margin-top: 8px; font-size: 0.5em; letter-spacing: 0.3em; color: var(--color-gold); }
.founding__text { max-width: 760px; margin: 36px auto 0; text-align: left; }

/* =========================================
   お知らせ
   ========================================= */
.news { padding: clamp(64px, 9vw, 110px) 0; }
.news__list { max-width: 820px; margin: 44px auto 0; border-top: 1px solid var(--color-line); }
.news__item { border-bottom: 1px solid var(--color-line); }
.news__item a { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px 28px; padding: 22px 8px; }
.news__item a:hover { opacity: 1; background: var(--color-washi); }
.news__date { font-family: var(--font-sans); font-size: 14px; letter-spacing: 0.08em; color: var(--color-text-light); }
.news__title { font-size: 16px; line-height: 1.7; }
.news__more { margin-top: 40px; text-align: center; }

/* =========================================
   職人業カード
   ========================================= */
.craft { padding: clamp(64px, 9vw, 110px) 0; background: var(--color-washi); }
.craft__cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; max-width: var(--container); margin: 0 auto; }
.craft-card { background: var(--color-white); box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06); overflow: hidden; }
.craft-card__img { aspect-ratio: 4 / 3; overflow: hidden; }
.craft-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.craft-card:hover .craft-card__img img { transform: scale(1.05); }
.craft-card__body { padding: 28px 26px 32px; }
.craft-card__title { font-size: 20px; letter-spacing: 0.1em; }
.craft-card__title span { font-size: 0.7em; color: var(--color-gold); }
.craft-card__text { margin: 16px 0 24px; font-size: 14.5px; line-height: 1.9; color: var(--color-text); }

/* =========================================
   仏壇・仏具
   ========================================= */
.products__head { display: flex; align-items: center; justify-content: center; min-height: 260px; padding: 40px 6%; background: linear-gradient(rgba(26, 26, 26, 0.5), rgba(26, 26, 26, 0.5)), url(../img/bg.jpg) center / cover no-repeat; color: var(--color-white); text-align: center; }
.products__head h2 { font-size: clamp(24px, 3.4vw, 36px); letter-spacing: 0.2em; }
.products__inner { width: 90%; max-width: 980px; margin: 0 auto; padding: clamp(48px, 7vw, 90px) 0; }
.products__subtitle { font-size: clamp(17px, 2.2vw, 22px); line-height: 1.9; text-align: center; letter-spacing: 0.08em; }
.products__feature { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; margin-top: 48px; }
.products__feature-img img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.products__feature-title { font-size: 22px; letter-spacing: 0.12em; margin-bottom: 18px; }
.products__list { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 44px; justify-content: center; }
.products__list a { display: block; padding: 12px 24px; font-size: 15px; letter-spacing: 0.06em; border: 1px solid var(--color-line); background: var(--color-washi); }
.products__list a:hover { opacity: 1; border-color: var(--color-gold); color: var(--color-brown); }

/* =========================================
   サービス（寺社・クリーニング・稚児）
   ========================================= */
.service__cards { display: grid; grid-template-columns: repeat(3, 1fr); }
.service-card { position: relative; display: flex; align-items: flex-end; min-height: 420px; padding: 40px 34px; color: var(--color-white); overflow: hidden; }
.service-card::before { content: ""; position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.6s ease; z-index: -2; }
.service-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0.7)); z-index: -1; }
.service-card:hover { opacity: 1; }
.service-card:hover::before { transform: scale(1.06); }
.service-card--temple::before { background-image: url(../img/temple01.jpg); }
.service-card--cleaning::before { background-image: url(../img/osentaku1.jpg); }
.service-card--rental::before { background-image: url(../img/genchouji1.jpg); }
.service-card__title { font-size: 23px; letter-spacing: 0.12em; }
.service-card__title small { display: block; margin-top: 8px; font-size: 0.62em; letter-spacing: 0.1em; color: var(--color-gold); }
.service-card__text { margin: 16px 0 20px; font-size: 14px; line-height: 1.9; text-shadow: 0 1px 6px rgba(0, 0, 0, 0.5); }
.service-card__more { display: inline-block; font-family: var(--font-sans); font-size: 13px; letter-spacing: 0.16em; border-bottom: 1px solid currentColor; padding-bottom: 4px; }

/* =========================================
   メッセージ＋動画
   ========================================= */
.message { padding: clamp(64px, 9vw, 110px) 0; text-align: center; }
.message__title { font-size: clamp(22px, 3vw, 30px); letter-spacing: 0.14em; }
.message__text { max-width: 720px; margin: 28px auto 0; }
.message__movie { max-width: 720px; margin: 48px auto 0; }
.message__embed { position: relative; width: 100%; padding-top: 56.25%; }
.message__embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; }
.message__caption { margin-top: 14px; font-size: 14px; color: var(--color-text-light); }

/* =========================================
   よくある質問
   ========================================= */
.faq { padding: clamp(64px, 9vw, 110px) 0; background: var(--color-washi); }
.faq__inner { width: 90%; max-width: var(--container); margin-inline: auto; }
.faq__body { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; margin-top: 44px; align-items: start; }
.faq__item { background: var(--color-white); margin-bottom: 14px; }
.faq__question { display: flex; align-items: center; gap: 14px; width: 100%; padding: 20px 22px; text-align: left; }
.faq__icon { flex: none; width: 30px; height: 30px; display: grid; place-items: center; font-family: var(--font-sans); color: var(--color-white); background: var(--color-navy); border-radius: 50%; }
.faq__q-text { flex: 1; font-size: 16px; line-height: 1.6; }
.faq__toggle { flex: none; position: relative; width: 16px; height: 16px; }
.faq__toggle::before,
.faq__toggle::after { content: ""; position: absolute; top: 50%; left: 50%; width: 14px; height: 2px; background: var(--color-text); transform: translate(-50%, -50%); transition: transform 0.3s ease; }
.faq__toggle::after { transform: translate(-50%, -50%) rotate(90deg); }
.faq__question[aria-expanded="true"] .faq__toggle::after { transform: translate(-50%, -50%) rotate(0); }
.faq__answer { overflow: hidden; max-height: 0; transition: max-height 0.35s ease; }
.faq__answer p { padding: 0 22px 22px; font-size: 15px; line-height: 1.9; }
.faq__cta { background: var(--color-white); }
.faq__cta-link { display: block; height: 100%; padding: 34px 30px; }
.faq__cta-text { display: block; font-size: 15px; line-height: 1.9; }
.faq__cta-more { display: inline-block; margin-top: 20px; font-family: var(--font-sans); font-size: 13px; letter-spacing: 0.14em; border-bottom: 1px solid var(--color-gold); padding-bottom: 4px; }

/* =========================================
   パンくずリスト
   ========================================= */
.breadcrumb { width: 90%; max-width: var(--container); margin: 16px auto; }
.breadcrumb__list { display: flex; flex-wrap: wrap; gap: 8px; font-size: 12px; color: var(--color-text-light); }
.breadcrumb__item:not(:last-child)::after { content: "›"; margin-left: 8px; color: var(--color-line); }
.breadcrumb__item a { color: var(--color-navy); }

/* =========================================
   フッター
   ========================================= */
.footer { margin-top: auto; padding: 56px 0 24px; background: var(--color-ink); color: #d8d4cc; }
.footer__inner { width: 90%; max-width: var(--container); margin-inline: auto; }
.footer__links { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px 28px; padding-bottom: 36px; border-bottom: 1px solid rgba(255, 255, 255, 0.12); }
.footer__links a { font-size: 14px; letter-spacing: 0.06em; color: #d8d4cc; }
.footer__company { display: flex; flex-direction: column; align-items: center; gap: 18px; margin-top: 40px; text-align: center; }
.footer__logo { width: 170px; }
.footer__address { display: flex; flex-direction: column; gap: 8px; font-size: 14px; line-height: 1.7; }
.footer__name { font-size: 16px; letter-spacing: 0.1em; color: var(--color-white); }
.footer__tel { display: inline-block; margin-top: 10px; padding: 12px 32px; font-size: 16px; letter-spacing: 0.08em; color: var(--color-white); background: var(--color-navy); }
.footer__sns { display: flex; justify-content: center; gap: 22px; margin-top: 36px; }
.footer__sns a { color: #d8d4cc; }
.footer__sns a:hover { color: var(--color-white); }
.footer__copy { margin-top: 36px; font-family: var(--font-sans); font-size: 12px; letter-spacing: 0.08em; text-align: center; color: #9b958a; }

/* =========================================
   下層ページ共通ヒーロー（about等で使用）
   ========================================= */
.page-hero { position: relative; display: flex; align-items: center; justify-content: center; min-height: 320px; padding: 60px 6%; color: var(--color-white); text-align: center; background: var(--color-ink); overflow: hidden; }
.page-hero__bg { position: absolute; inset: 0; object-fit: cover; opacity: 0.55; z-index: 0; }
.page-hero__title { position: relative; z-index: 1; font-size: clamp(26px, 4vw, 42px); letter-spacing: 0.18em; }
.page-hero__lead { position: relative; z-index: 1; margin-top: 16px; font-size: 15px; letter-spacing: 0.1em; }

/* =========================================
   レスポンシブ：タブレット
   ========================================= */
@media (max-width: 1000px) {
  .global-nav__item a { padding: 9px 11px; font-size: 13px; }
  .craft__cards { grid-template-columns: 1fr; max-width: 560px; }
  .service__cards { grid-template-columns: 1fr; }
  .faq__body { grid-template-columns: 1fr; }
}

/* =========================================
   レスポンシブ：スマートフォン
   ========================================= */
@media (max-width: 768px) {
  /* 上段バー：ロゴ＋ハンバーガー（電話ボタンはドロワー内へ） */
  .header__bar { min-height: 64px; }
  .header__tel { display: none; }
  .hamburger { display: block; position: relative; z-index: 110; }

  /* ナビをドロワー化 */
  .global-nav__list { position: fixed; top: 0; right: 0; z-index: 105; flex-direction: column; flex-wrap: nowrap; align-items: flex-start; justify-content: flex-start; gap: 0; width: 80%; height: 100vh; padding: 84px 28px 40px; background: var(--color-ink); overflow-y: auto; transform: translateX(100%); transition: transform 0.3s ease; }
  .global-nav__list.is-open { transform: translateX(0); }
  .global-nav__item { width: 100%; border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
  .global-nav__item a { padding: 16px 4px; font-size: 16px; }
  .global-nav__item--tel { display: block; border-bottom: none; }
  .global-nav__item--tel a { display: inline-block; margin-top: 18px; padding: 12px 24px; border: 1px solid rgba(255, 255, 255, 0.6); }

  .products__feature { grid-template-columns: 1fr; gap: 24px; }
  .products__feature-img { order: -1; }
  .news__item a { padding: 18px 6px; }
}

/* =========================================
   下層ページ：セクション枠
   ========================================= */
.l-section { padding: clamp(56px, 8vw, 100px) 0; }
.l-section--washi { background: var(--color-washi); }
.l-section--tight { padding: clamp(40px, 6vw, 72px) 0; }

/* =========================================
   下層ページ：リード文（中央寄せ）
   ========================================= */
.lead { width: 90%; max-width: 820px; margin-inline: auto; text-align: center; }
.lead__text { margin-top: 28px; text-align: left; }
.lead__text + .lead__text { margin-top: 20px; }

/* =========================================
   画像＋テキストの横並び（交互配置）
   ========================================= */
.media-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 56px); align-items: center; width: 90%; max-width: var(--container); margin-inline: auto; }
.media-row + .media-row { margin-top: clamp(40px, 6vw, 72px); }
.media-row--reverse .media-row__media { order: 2; }
.media-row__media img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.media-row__title { font-size: clamp(20px, 2.6vw, 28px); letter-spacing: 0.12em; margin-bottom: 20px; }
.media-row__title small { display: block; margin-bottom: 6px; font-size: 0.55em; letter-spacing: 0.14em; color: var(--color-gold); }
.media-row__text + .media-row__text { margin-top: 18px; }
/* グリッド子要素の最小幅を0に（画像の実寸が本文列を潰すのを防ぐ） */
.media-row__media { min-width: 0; }
.media-row__body { min-width: 0; }

/* =========================================
   技法カードグリッド（原田の職人業）
   ========================================= */
.tech-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; width: 90%; max-width: var(--container); margin: clamp(36px, 5vw, 56px) auto 0; }
.tech-card { padding: 36px 28px; background: var(--color-white); border: 1px solid var(--color-line); text-align: center; }
.tech-card__index { display: block; font-family: var(--font-sans); font-size: 13px; letter-spacing: 0.2em; color: var(--color-gold); }
.tech-card__title { margin: 12px 0 14px; font-size: 21px; letter-spacing: 0.14em; }
.tech-card__text { font-size: 14.5px; line-height: 1.9; text-align: left; }

/* =========================================
   画像ギャラリー（取扱仏壇・寺院施工例 ほか）
   ========================================= */
.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; width: 90%; max-width: var(--container); margin-inline: auto; }
.gallery--narrow { max-width: 900px; }
.gallery__item img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }

/* =========================================
   番号付きの流れ（クリーニング・寺院）
   ========================================= */
.steps { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; width: 90%; max-width: 920px; margin: clamp(32px, 5vw, 48px) auto 0; }
.step { display: flex; gap: 18px; padding: 24px; background: var(--color-white); border: 1px solid var(--color-line); }
.step__num { flex: none; width: 40px; height: 40px; display: grid; place-items: center; font-family: var(--font-sans); font-size: 16px; color: var(--color-white); background: var(--color-navy); border-radius: 50%; }
.step__title { font-size: 16px; letter-spacing: 0.06em; }
.step__text { margin-top: 8px; font-size: 14px; line-height: 1.8; }

/* 横並びの簡易フロー（寺院ご依頼の流れ） */
.flow-line { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px 26px; margin-top: 36px; }
.flow-line__item { position: relative; padding: 14px 26px; font-size: 15px; letter-spacing: 0.06em; background: var(--color-white); border: 1px solid var(--color-line); }
.flow-line__item:not(:last-child)::after { content: "›"; position: absolute; right: -16px; top: 50%; transform: translateY(-50%); color: var(--color-gold); }

/* =========================================
   電話CTA
   ========================================= */
.tel-cta { width: 90%; max-width: 720px; margin: clamp(40px, 6vw, 60px) auto 0; text-align: center; }
.tel-cta__lead { margin-bottom: 18px; font-size: 15px; }
.tel-cta__button { display: inline-flex; flex-direction: column; align-items: center; gap: 4px; padding: 18px 48px; color: var(--color-white); background: var(--color-navy); letter-spacing: 0.08em; }
.tel-cta__button:hover { opacity: 0.85; }
.tel-cta__num { font-size: clamp(22px, 3vw, 28px); letter-spacing: 0.1em; }
.tel-cta__note { font-size: 13px; }

/* =========================================
   会社概要（定義リスト）
   ========================================= */
.spec { width: 90%; max-width: 820px; margin-inline: auto; border-top: 1px solid var(--color-line); }
.spec__row { display: grid; grid-template-columns: 200px 1fr; border-bottom: 1px solid var(--color-line); }
.spec__row dt { padding: 20px 16px; font-weight: 400; letter-spacing: 0.08em; background: var(--color-washi); }
.spec__row dd { padding: 20px 16px; }
.spec__row dd a { color: var(--color-navy); text-decoration: underline; }

/* 沿革（年表） */
.history-list { width: 90%; max-width: 820px; margin-inline: auto; }
.history-list__row { display: grid; grid-template-columns: 160px 1fr; gap: 0 20px; padding: 18px 0; border-bottom: 1px solid var(--color-line); }
.history-list__date { font-family: var(--font-sans); font-size: 14px; letter-spacing: 0.06em; color: var(--color-text-light); }

/* =========================================
   地図
   ========================================= */
.map { width: 90%; max-width: var(--container); margin: clamp(36px, 5vw, 56px) auto 0; aspect-ratio: 16 / 9; }
.map iframe { width: 100%; height: 100%; border: 0; }

/* =========================================
   2択カード（クリーニングの選択）
   ========================================= */
.choose { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; width: 90%; max-width: var(--container); margin: clamp(32px, 5vw, 48px) auto 0; }
.choose__card { position: relative; display: flex; align-items: flex-end; min-height: 260px; padding: 32px; color: var(--color-white); overflow: hidden; }
.choose__card::before { content: ""; position: absolute; inset: 0; background-size: cover; background-position: center; z-index: -2; transition: transform 0.6s ease; }
.choose__card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.7)); z-index: -1; }
.choose__card:hover { opacity: 1; }
.choose__card:hover::before { transform: scale(1.06); }
.choose__card--honkaku::before { background-image: url(../img/osentaku1.jpg); }
.choose__card--visit::before { background-image: url(../img/DSC_0168.jpg); }
.choose__title { font-size: 20px; letter-spacing: 0.1em; }
.choose__text { margin-top: 10px; font-size: 14px; line-height: 1.8; text-shadow: 0 1px 6px rgba(0, 0, 0, 0.5); }

/* =========================================
   寺院施工例カード
   ========================================= */
.case { width: 90%; max-width: var(--container); margin-inline: auto; }
.case + .case { margin-top: clamp(40px, 6vw, 64px); padding-top: clamp(40px, 6vw, 64px); border-top: 1px solid var(--color-line); }
.case__head { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 48px); align-items: center; }
.case__media img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.case__title { font-size: clamp(19px, 2.4vw, 25px); letter-spacing: 0.1em; margin-bottom: 16px; }
.case__title small { display: block; margin-bottom: 6px; font-size: 0.55em; letter-spacing: 0.12em; color: var(--color-gold); }
.case__gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; margin-top: 24px; }
.case__gallery img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
/* グリッド子要素の最小幅を0に（本文潰れ防止） */
.case__head > * { min-width: 0; }

/* =========================================
   下層ページ：レスポンシブ（スマートフォン）
   ========================================= */
@media (max-width: 768px) {
  .media-row { grid-template-columns: 1fr; gap: 24px; }
  .media-row--reverse .media-row__media { order: 0; }
  .media-row__media { order: -1; }
  .tech-grid { grid-template-columns: 1fr; max-width: 480px; }
  .steps { grid-template-columns: 1fr; }
  .choose { grid-template-columns: 1fr; }
  .case__head { grid-template-columns: 1fr; }
  .spec__row { grid-template-columns: 1fr; }
  .spec__row dt { padding: 14px 16px 4px; }
  .spec__row dd { padding: 4px 16px 16px; }
  .history-list__row { grid-template-columns: 1fr; gap: 4px; }
  .flow-line__item:not(:last-child)::after { content: ""; }
}

/* =========================================
   チェックリスト（おすすめ・サービス内容）
   ========================================= */
.check-list { margin-top: 16px; display: grid; gap: 8px; }
.check-list li { position: relative; padding-left: 24px; font-size: 14.5px; line-height: 1.8; }
.check-list li::before { content: "✓"; position: absolute; left: 0; top: 0; font-family: var(--font-sans); color: var(--color-gold); }

/* =========================================
   アンカー位置の調整（固定ヘッダー分の余白）
   ========================================= */
.l-section,
.case,
.anchor-offset { scroll-margin-top: 96px; }

/* =========================================
   メディア枠：縦写真をトリミングせず全体表示（顔切れ防止）
   ========================================= */
.media-row__media--portrait img { aspect-ratio: auto; width: auto; max-width: 100%; max-height: 460px; margin-inline: auto; object-fit: contain; }

/* =========================================
   ギャラリー：2列固定（2枚並べ）
   ========================================= */
.gallery--2col { grid-template-columns: repeat(2, 1fr); }

@media (max-width: 600px) {
  .gallery--2col { grid-template-columns: 1fr; }
}

/* =========================================
   お知らせ一覧（記事リスト＋サイドバー）
   ========================================= */
.archive { padding: clamp(48px, 7vw, 90px) 0; }
.archive__layout { display: grid; grid-template-columns: 1fr 280px; gap: clamp(32px, 5vw, 56px); width: 90%; max-width: var(--container); margin-inline: auto; align-items: start; }

.post-list { border-top: 1px solid var(--color-line); }
.post-list__item { border-bottom: 1px solid var(--color-line); }
.post-list__item a { display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px 18px; padding: 22px 8px; }
.post-list__item a:hover { opacity: 1; background: var(--color-washi); }
.post-list__date { font-family: var(--font-sans); font-size: 13px; letter-spacing: 0.06em; color: var(--color-text-light); }
.post-list__cat { font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.08em; color: var(--color-navy); border: 1px solid var(--color-line); padding: 2px 10px; }
.post-list__title { flex: 1 1 58%; font-size: 16px; line-height: 1.7; }
.post-list__empty { padding: 48px 0; text-align: center; color: var(--color-text-light); }

/* サイドバー */
.sidebar { display: grid; gap: 36px; }
.sidebar__title { font-size: 16px; letter-spacing: 0.12em; padding-bottom: 12px; margin-bottom: 12px; border-bottom: 1px solid var(--color-line); }
.sidebar__title small { display: block; margin-top: 4px; font-family: var(--font-sans); font-size: 10px; letter-spacing: 0.2em; color: var(--color-gold); }
.sidebar__list li { border-bottom: 1px solid var(--color-line); }
.sidebar__list a { display: block; padding: 10px 4px; font-size: 14px; }
.sidebar__list a:hover { opacity: 1; color: var(--color-brown); }

/* =========================================
   ページネーション（hk_pagination 出力）
   ========================================= */
.pager { margin-top: 48px; }
.pager__list { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; }
.pager__item a,
.pager__current { display: grid; place-items: center; min-width: 42px; height: 42px; padding: 0 8px; font-family: var(--font-sans); font-size: 14px; border: 1px solid var(--color-line); }
.pager__item a:hover { opacity: 1; border-color: var(--color-gold); color: var(--color-brown); }
.pager__current { color: var(--color-white); background: var(--color-navy); border-color: var(--color-navy); }

/* =========================================
   記事本文（お知らせ single）
   ========================================= */
.single { padding: clamp(48px, 7vw, 90px) 0; }
.single__inner { width: 90%; max-width: 820px; margin-inline: auto; }
.single__head { padding-bottom: 24px; margin-bottom: 36px; border-bottom: 1px solid var(--color-line); }
.single__date { font-family: var(--font-sans); font-size: 13px; letter-spacing: 0.06em; color: var(--color-text-light); }
.single__title { margin-top: 10px; font-size: clamp(22px, 3vw, 30px); line-height: 1.5; letter-spacing: 0.06em; }
.single__back { margin-top: 48px; text-align: center; }

/* WYSIWYG本文 */
.entry { line-height: 2; }
.entry > * + * { margin-top: 1.4em; }
.entry h2 { margin-top: 1.8em; padding-bottom: 10px; font-size: 22px; letter-spacing: 0.06em; border-bottom: 1px solid var(--color-line); }
.entry h3 { margin-top: 1.6em; font-size: 19px; letter-spacing: 0.06em; }
.entry img { margin-inline: auto; }
.entry a { color: var(--color-navy); text-decoration: underline; }
.entry ul { padding-left: 1.4em; list-style: disc; }
.entry ol { padding-left: 1.4em; list-style: decimal; }
.entry li + li { margin-top: 0.4em; }
.entry blockquote { padding: 16px 20px; border-left: 3px solid var(--color-gold); background: var(--color-washi); }

/* =========================================
   404
   ========================================= */
.error404 { padding: clamp(64px, 10vw, 140px) 0; text-align: center; }
.error404__code { font-family: var(--font-sans); font-size: clamp(64px, 12vw, 120px); line-height: 1; letter-spacing: 0.1em; color: var(--color-line); }
.error404__title { margin-top: 12px; font-size: clamp(20px, 3vw, 26px); letter-spacing: 0.1em; }
.error404__text { margin-top: 20px; color: var(--color-text-light); }
.error404__actions { margin-top: 36px; }

/* =========================================
   伝統工芸体験（金箔押し体験）：情報ボックス
   ========================================= */
.info-box { padding: clamp(24px, 4vw, 36px); background: var(--color-washi); border: 1px solid var(--color-line); }
.info-box__row { display: grid; grid-template-columns: 130px 1fr; gap: 8px 16px; padding: 14px 0; }
.info-box__row + .info-box__row { border-top: 1px solid var(--color-line); }
.info-box__row dt { font-family: var(--font-sans); font-size: 12px; letter-spacing: 0.1em; color: var(--color-brown); }

/* =========================================
   WPテンプレート：レスポンシブ
   ========================================= */
@media (max-width: 900px) {
  .archive__layout { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .info-box__row { grid-template-columns: 1fr; gap: 2px; }
}
