@charset "utf-8";
/*
 * ======================================
 * 大杖呉服店 サイト固有CSS（site.css）
 * 共通 main.css で再現できないデザイン差分を ots- プレフィックスで追加
 * ======================================
 *
 * 追加クラス一覧（共通SCSS取り込み検討用）
 * .mincho / .mincho-num        - 明朝体（見出し）/ 明朝体数字（日付・電話）
 * .ots-header*                 - 透過縦書きナビ／白固定横ナビ／モバイルドロワー
 * .ots-nav-toggle / .ots-drawer- ハンバーガー・SPドロワー
 * .ots-hero*                   - TOPメインビュー（背景写真＋縦中央テキスト＋ドット）
 * .ots-eyebrow                 - Cormorant金色のeyebrow（Since — Awaji, Gunge）
 * .ots-sec / .ots-sec--tex     - セクション余白／麻の葉テクスチャ背景
 * .ots-wrap*                   - 中央寄せ内側ラッパー（1100/1180px）
 * .ots-sechead*                - 雲アイコン付き中央セクション見出し
 * .ots-h2*                     - 明朝見出し（深緑）
 * .ots-lead                    - 下層ページ導入リード
 * .ots-greeting*               - TOPごあいさつ（左見出し＋右本文）
 * .ots-news*                   - TOPお知らせ行
 * .ots-biz*                    - TOP事業カード
 * .ots-twocol*                 - 画像＋テキスト2カラム（下層共通）
 * .ots-itemlist* / .ots-chip*  - 取扱品目リスト／チップ
 * .ots-infobox                 - 体験会・出張査定の白枠ボックス
 * .ots-page-hero*              - 下層ページヒーロー（麻の葉＋深緑）
 * .ots-crumb                   - パンくず
 * .ots-company* / .ots-policy* - 会社情報テーブル／プライバシーポリシー
 * .ots-mapbox*                 - 簡易マップボックス
 * .ots-cta*                    - フッター上CTA帯
 * .ots-footer* / .ots-side*    - フッター／お知らせサイドバー
 * .ots-postlist* / .ots-pager* - お知らせ一覧／ページネーション
 * .ots-entry*                  - お知らせ詳細記事
 * .ots-pagetop                 - ページトップボタン
 *
 * ======================================
 * 共通SCSSに不足していたもの（5分類）
 * ======================================
 * ・構造不足：透過オーバーレイ＋縦書き(writing-mode)ナビのヘッダー型 → ots-header--overlay
 * ・装飾パターン不足：麻の葉テクスチャ(multiply)背景、雲(kumo)あしらい見出し → ots-sec--tex / ots-sechead
 * ・値の粒度不足：本文 15.5px / line-height 2.2〜2.3、見出し34px等の和の余白感 → ots- 各クラスで個別指定
 */

/* ========== フォント ========== */
.mincho { font-family: 'Shippori Mincho', 'Yu Mincho', '游明朝', serif; }
.mincho-num { font-family: 'Yu Mincho', '游明朝', 'Hiragino Mincho ProN', 'Shippori Mincho', serif; }

::selection { background: #C5A059; color: #fff; }

/* スマホ専用改行（PCでは改行しない） */
.ots-br-sp { display: none; }
@media (max-width: 760px) { .ots-br-sp { display: inline; } }

/* ========== 共通レイアウト ========== */
.ots-wrap, .ots-wrap--wide, .ots-wrap--narrow, .ots-wrap--xnarrow { margin: 0 auto; }
.ots-wrap { max-width: 1100px; }
.ots-wrap--wide { max-width: 1180px; }
.ots-wrap--narrow { max-width: 880px; }
.ots-wrap--xnarrow { max-width: 820px; }

.ots-sec { position: relative; padding: 110px 40px; overflow: hidden; }
.ots-sec--cream { background: linear-gradient(180deg, #FAF9F4 0%, #F1EFE6 100%); }
.ots-sec--white { background: linear-gradient(180deg, #FFFFFF 0%, #FBFAF6 100%); }
.ots-sec--90 { padding: 90px 40px; }
.ots-sec--84 { padding: 84px 40px; }
.ots-sec--entry { padding: 64px 40px 100px; }

/* 麻の葉テクスチャ背景 */
.ots-sec--tex::before {
  content: ""; position: absolute; inset: 0;
  background: url('https://ros-cdn.s3.ap-northeast-1.amazonaws.com/hp/img/ros_keiyaku/28302/asanoha.jpg') center / 620px repeat;
  opacity: 0.2; mix-blend-mode: multiply; pointer-events: none;
}
.ots-sec--tex > * { position: relative; z-index: 1; }

/* ========== eyebrow（Cormorant 金） ========== */
.ots-eyebrow {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: 22px; letter-spacing: 0.14em; color: #C5A059; margin: 0;
}

/* ========== セクション見出し ========== */
.ots-h2 { font-family: 'Shippori Mincho', serif; font-weight: 600; color: #2E4A3F; margin: 0; }
.ots-h2--34 { font-size: 34px; letter-spacing: 0.1em; }
.ots-h2--30 { font-size: 30px; letter-spacing: 0.05em; }
.ots-h2--32 { font-size: 32px; letter-spacing: 0.1em; }

.ots-sechead { text-align: center; margin-bottom: 50px; }
.ots-sechead__sub { font-size: 14.5px; color: #5b665f; letter-spacing: 0.04em; margin: 14px 0 0; }
.ots-sechead--cloud { margin-bottom: 40px; }
.ots-sechead__cloud { width: 34px; height: auto; display: inline-block; margin-bottom: 8px; }

/* 見出し＋右リンク（お知らせ） */
.ots-headrow { display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: 16px; margin-bottom: 40px; }
.ots-morelink { font-size: 14px; color: #2E4A3F; text-decoration: none; letter-spacing: 0.06em; border-bottom: 1px solid #C5A059; padding-bottom: 4px; }
.ots-morelink:hover { color: #C5A059; }

/* ========== TOP メインビュー（claude-design-output 準拠：中央揃え／着物背景） ========== */
.ots-hero {
  position: relative; min-height: 100vh; display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  background: #1c1712 url('https://ros-cdn.s3.ap-northeast-1.amazonaws.com/hp/img/ros_keiyaku/28302/mv-kimono.jpg') center 30% / cover no-repeat;
}
.ots-hero::before {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(20,14,8,0.42) 0%, rgba(20,14,8,0.2) 26%, rgba(20,14,8,0.2) 58%, rgba(20,14,8,0.5) 100%);
}
.ots-hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(ellipse 58% 52% at 50% 50%, rgba(12,8,4,0.42) 0%, rgba(12,8,4,0.12) 55%, rgba(12,8,4,0) 78%);
}
.ots-hero__inner {
  position: relative; z-index: 2; text-align: center;
  display: flex; flex-direction: column; align-items: center;
  padding: 90px 24px 0;
  animation: mvUp 1.4s ease both;
}
@keyframes mvUp { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
.ots-hero__ornament { display: flex; align-items: center; gap: 22px; margin: 40px 0 38px; }
.ots-hero__ornament-line { width: 68px; height: 1px; background: rgba(255,255,255,0.5); }
.ots-hero__ornament-diamond { width: 11px; height: 11px; border: 1px solid #C5A059; transform: rotate(45deg); }
.ots-hero__catch {
  font-family: 'Shippori Mincho', serif; font-weight: 500; color: #fff;
  font-size: clamp(30px, 4vw, 46px); letter-spacing: 0.3em; line-height: 1.7;
  margin: 0; text-shadow: 0 2px 26px rgba(0,0,0,0.55);
}
.ots-hero__sub {
  color: #f0e9df; font-size: 18.5px; letter-spacing: 0.16em; line-height: 2.1;
  margin: 0; text-shadow: 0 1px 14px rgba(0,0,0,0.5);
}
.ots-hero__scroll {
  position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%);
  width: 1px; height: 52px; z-index: 2;
  background: linear-gradient(rgba(255,255,255,0.85), rgba(255,255,255,0));
}
/* CMSメインスライダー：タブレット・スマホは縦80vh（MVラッパーと同期。詳細度でCMS側に勝たせる） */
@media (max-width: 1024px) {
  .ots-hero { min-height: 80vh; }
  #slideshow #main_slider.slider_wrapper { --swiper-wrapper-height: 80vh; }
}
/* CMSスライダーをヒーロー全面に敷く（暗幕＝z1・テキスト＝z2 の下に来る） */
#slideshow #cms-slider-1-1-area { position: absolute; inset: 0; z-index: 0; }
#slideshow #cms-slider-1-1-area .swiper,
#slideshow #cms-slider-1-1-area .swiper-slide { width: 100%; height: 100%; }
#slideshow #cms-slider-1-1-area img { width: 100%; height: 100%; object-fit: cover; }

/* ========== TOP セクション横断・連続背景キャンバス（左右レイヤー） ========== */
/* ヒーロー以降のセクションを1枚の背景でつなぐ。色帯で区切らず、左右に縦のあしらいを通す */
.ots-canvas {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #fbfaf6 0%, #f6f5ef 20%, #eff0e7 50%, #f6f5ef 80%, #fbfaf6 100%);
}
/* 連続する麻の葉テクスチャ（セクションで途切れさせず1枚で通す） */
.ots-canvas::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: url('https://ros-cdn.s3.ap-northeast-1.amazonaws.com/hp/img/ros_keiyaku/28302/asanoha.jpg') center top / 640px repeat;
  opacity: 0.3; mix-blend-mode: multiply;
}
/* 中の各セクションは透明化（cream/white の色帯をやめる）。個別テクスチャも止めて連続背景に一本化 */
.ots-canvas .ots-sec { z-index: 1; }
.ots-canvas .ots-sec--cream,
.ots-canvas .ots-sec--white { background: transparent; }
.ots-canvas .ots-sec--tex::before { display: none; }
/* お知らせは連続背景の中で白パネルにする */
.ots-canvas .ots-sec--news { background: #fff; }

/* 左右レイヤー：全高でセクションをまたいで縦に通る */
.ots-canvas__layer { position: absolute; top: 0; bottom: 0; z-index: 0; width: clamp(54px, 10vw, 168px); pointer-events: none; }
.ots-canvas__layer--left { left: 0; }
.ots-canvas__layer--right { right: 0; display: flex; justify-content: flex-end; }
/* 縦に通る金の細罫（横断の連続感を出す芯） */
.ots-canvas__layer::after {
  content: ""; position: absolute; top: 0; bottom: 0; width: 1px;
  background: linear-gradient(180deg, transparent 0%, rgba(197,160,89,0.5) 10%, rgba(197,160,89,0.5) 90%, transparent 100%);
}
.ots-canvas__layer--left::after { left: clamp(26px, 4.6vw, 70px); }
.ots-canvas__layer--right::after { right: clamp(26px, 4.6vw, 70px); }
/* 画面が狭いと本文に被るため、左右レイヤーは広い画面のみ表示（連続背景は維持） */
@media (max-width: 1080px) {
  .ots-canvas__layer { display: none; }
  .ots-canvas::before { opacity: 0.24; }
}

/* ========== TOP ごあいさつ ========== */
.ots-greeting { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 64px; align-items: start; }
.ots-greeting__titlecol { position: relative; }
.ots-greeting__title { position: relative; z-index: 1; font-family: 'Shippori Mincho', serif; font-weight: 600; font-size: 34px; line-height: 1.7; letter-spacing: 0.04em; margin: 0; color: #2E4A3F; }
.ots-greeting__gold { position: absolute; z-index: 0; left: -110px; bottom: -110px; width: 250px; height: 250px; background: rgba(197,160,89,0.24); pointer-events: none; }
/* タブレット（2カラム）：あしらいを左端寄せ・タイトル左下に被るよう調整 */
@media (min-width: 761px) and (max-width: 1024px) {
  .ots-greeting__gold { left: -40px; bottom: -40px; width: 158px; height: 158px; }
}
.ots-body { font-size: 15.5px; line-height: 2.3; letter-spacing: 0.03em; color: #33403a; margin: 0 0 22px; }
.ots-sign { font-family: 'Shippori Mincho', serif; font-size: 17px; color: #2E4A3F; letter-spacing: 0.08em; margin: 0; text-align: right; }

/* ========== TOP お知らせ / お知らせ一覧（ブログCMS） ========== */
.ots-news { border-top: 1px solid #e6e6df; }
/* CMSが注入する .ots-news__row を行として並べる（span は inline のため block 化） */
#cms-blog-entry-list-1-area { display: block; }
/* お知らせ一覧 CMSページャ（.pages / .page_prev / .page_next）：横並び・中央寄せ */
#cms-blog-entry-list-1-area .pages { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 10px 14px; margin-top: 44px; }
#cms-blog-entry-list-1-area .pages > div { display: inline-flex; }
#cms-blog-entry-list-1-area .pages a { display: inline-flex; align-items: center; justify-content: center; color: #2E4A3F; text-decoration: none; font-size: 14px; letter-spacing: 0.04em; border: 1px solid #d8d4c7; padding: 10px 20px; transition: all 0.25s ease; }
#cms-blog-entry-list-1-area .pages a:hover { border-color: #2E4A3F; background: #2E4A3F; color: #fff; }
#cms-blog-entry-list-1-area .pages .now_page, #cms-blog-entry-list-1-area .pages .current { display: inline-flex; align-items: center; justify-content: center; background: #2E4A3F; color: #fff; padding: 10px 18px; font-size: 14px; }
/* TOPのお知らせはページャを出さない（id詳細度に勝たせる） */
.ots-news--top #cms-blog-entry-list-1-area .pages { display: none; }
.ots-news__row { display: grid; grid-template-columns: 130px 1fr; gap: 28px; align-items: center; padding: 22px 6px; border-bottom: 1px solid #e6e6df; text-decoration: none; transition: background 0.25s ease; }
.ots-news__row:hover { background: #faf7ef; }
.ots-news__date { font-size: 15px; letter-spacing: 0.08em; color: #8a958f; }
.ots-news__title { font-size: 15.5px; color: #28332d; line-height: 1.6; letter-spacing: 0.02em; }
.ots-news__row:hover .ots-news__title { color: #2E4A3F; }

/* ========== TOP 事業のご案内：四角を重ねた背景パネル（参考イメージ準拠） ========== */
/* 大きめの四角い面を上下左右にずらして重ね、麻の葉テクスチャ（連続背景）を透かす */
.ots-biz-deco { position: absolute; inset: 0; z-index: 0; overflow: visible; pointer-events: none; }
.ots-biz-deco__panel { position: absolute; }
.ots-biz-deco__panel--a { top: 0; left: -4%; width: 70%; bottom: 70px; background: rgba(244,240,232,0.6); }
/* 右パネル：上はセクションからはみ出すほど高く、左端は中央より左まで伸ばす */
.ots-biz-deco__panel--b { top: -100px; left: 36%; right: -4%; bottom: 0; background: rgba(214,198,165,0.18); }
/* 右パネルが上方向へはみ出せるようセクションのクリップを外す */
#business { overflow: visible; }
/* コンテンツをパネルの上に乗せる */
#business .ots-wrap { position: relative; z-index: 1; }

/* ========== TOP 事業カード（写真主役：テキストを写真上にオーバーレイ・白余白なし） ========== */
.ots-biz { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
/* 角丸：右上・左下を強めて非対称に（モダンなあしらい）。順は 左上 右上 右下 左下 */
.ots-biz__card { position: relative; display: block; text-decoration: none; aspect-ratio: 1 / 1; overflow: hidden; background: #2E4A3F; border-radius: 5px 26px 5px 26px; }
.ots-biz__photo { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.7s ease; }
.ots-biz__card:hover .ots-biz__photo { transform: scale(1.07); }
/* タイトル＋矢印の背景に緑の帯（下部バー） */
.ots-biz__overlay { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; display: flex; align-items: center; justify-content: space-between; gap: 10px; background: rgba(46,74,63,0.9); padding: 14px 14px 14px 18px; }
.ots-biz__title { font-family: 'Shippori Mincho', serif; font-weight: 600; font-size: 17px; letter-spacing: 0.06em; color: #fff; margin: 0; line-height: 1.4; }
.ots-biz__more { flex: none; width: 34px; height: 34px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.75); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 14px; line-height: 1; transition: background 0.35s ease, border-color 0.35s ease; }
.ots-biz__card:hover .ots-biz__more { background: #C5A059; border-color: #C5A059; }

/* ========== TOP 店内スライドショー ========== */
/* 店内写真の横スライド（右→左へ自動で流れる・全幅） */
.ots-shopflow { position: relative; left: 50%; width: 100vw; margin-left: -50vw; overflow: hidden; }
.ots-shopflow__track { display: flex; width: max-content; animation: otsShopFlow 55s linear infinite; }
.ots-shopflow:hover .ots-shopflow__track { animation-play-state: paused; }
.ots-shopflow__item { flex: none; width: 460px; aspect-ratio: 3 / 2; margin-right: 18px; background-size: cover; background-position: center; background-color: #23362f; }
/* 前半・後半が同一の並びなので -50% で継ぎ目なく無限ループ */
@keyframes otsShopFlow { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (max-width: 760px) {
  .ots-shopflow__item { width: 280px; margin-right: 12px; }
  .ots-shopflow__track { animation-duration: 34s; }
}
@media (prefers-reduced-motion: reduce) { .ots-shopflow__track { animation: none; } }

/* ========== TOP 外部販売のご案内（せきれいの里） ========== */
.ots-sekirei { background: #fff; border-radius: 16px; padding: 50px 52px; text-align: center; color: #2E4A3F; box-shadow: 0 14px 34px rgba(46,74,63,0.10); }
.ots-sekirei__eyebrow { display: inline-block; background: #2E4A3F; color: #fff; border-radius: 999px; padding: 7px 22px; font-size: 17px; letter-spacing: 0.16em; margin-bottom: 18px; }
.ots-sekirei__title { font-weight: 600; font-size: 24px; line-height: 1.65; letter-spacing: 0.06em; color: #2E4A3F; margin: 0 0 22px; }
.ots-sekirei .ots-body { text-align: center; }
.ots-sekirei .ots-chips { justify-content: center; margin-top: 20px; }
@media (max-width: 760px) {
  .ots-sekirei { padding: 36px 24px; }
  .ots-sekirei__eyebrow { font-size: 14px; }
  .ots-sekirei__title { font-size: 20px; }
  .ots-sekirei .ots-body { text-align: left; }
}

/* ========== その他事業 カードグリッド（画像付き・2カラム） ========== */
.ots-bizlist { display: grid; grid-template-columns: repeat(2, 1fr); gap: 48px; }
.ots-bizlist__card { background: #fff; border: 1px solid #e3e0d6; display: flex; flex-direction: column; overflow: hidden; }
.ots-bizlist__photo { height: 280px; position: relative; background: #23362f center / cover no-repeat; }
.ots-bizlist__photo--ph { background: linear-gradient(135deg, #3c5d4f, #56796a); }
.ots-bizlist__photo--ph::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(rgba(255,255,255,0.12) 1.3px, transparent 1.3px); background-size: 24px 24px; }
.ots-bizlist__cap { position: absolute; left: 16px; bottom: 14px; font-size: 11px; color: rgba(255,255,255,0.78); letter-spacing: 0.06em; }
.ots-bizlist__body { padding: 26px 30px 30px; border-top: 3px solid #C5A059; display: flex; flex-direction: column; flex: 1; }
.ots-bizlist__title { display: flex; align-items: center; gap: 11px; font-family: 'Shippori Mincho', serif; font-weight: 600; font-size: 21px; color: #2E4A3F; letter-spacing: 0.05em; margin: 0 0 16px; padding-bottom: 14px; border-bottom: 1px solid #ece9e0; }
.ots-bizlist__title::before { content: ""; flex: none; width: 9px; height: 9px; background: #C5A059; transform: rotate(45deg); }
.ots-bizlist__text { font-size: 14.5px; line-height: 2.05; letter-spacing: 0.02em; color: #4a544e; margin: 0; }
@media (max-width: 680px) { .ots-bizlist { grid-template-columns: 1fr; gap: 32px; } .ots-bizlist__photo { height: 240px; } }

/* ========== 下層 ページヒーロー ========== */
.ots-page-hero { position: relative; background: #23362f url('https://ros-cdn.s3.ap-northeast-1.amazonaws.com/hp/img/ros_keiyaku/28302/hero-shippo.jpg') center / cover no-repeat; color: #fff; padding: 88px 40px; overflow: hidden; }
.ots-page-hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, rgba(30,46,40,0.82), rgba(34,54,47,0.7)); }
.ots-page-hero__inner { position: relative; max-width: 1100px; margin: 0 auto; }
.ots-page-hero__title { font-family: 'Shippori Mincho', serif; font-weight: 600; font-size: 40px; letter-spacing: 0.1em; margin: 14px 0 0; }
.ots-page-hero__title--sm { font-size: 38px; letter-spacing: 0.08em; }
.ots-page-hero__crumb { margin-top: 20px; font-size: 12.5px; letter-spacing: 0.06em; color: #bcc8c2; }
.ots-page-hero__crumb a { color: #bcc8c2; text-decoration: none; }
.ots-page-hero__crumb a:hover { color: #fff; }

/* ========== 下層 リード ========== */
.ots-lead { max-width: 820px; margin: 0 auto; padding: 80px 40px 16px; text-align: center; }
.ots-lead__p { font-family: 'Shippori Mincho', serif; font-size: 22px; line-height: 2.1; letter-spacing: 0.05em; color: #2E4A3F; margin: 0; }

/* ========== 下層 2カラム（画像＋テキスト） ========== */
.ots-twocol { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.ots-twocol__img { height: 360px; position: relative; overflow: hidden; background: #23362f; background-size: cover; background-position: center; }
.ots-twocol__img--340 { height: 340px; }

/* 画像プレースホルダ（差し替え用・グラデーション＋キャプション） */
.ots-imgph { height: 360px; position: relative; overflow: hidden; }
.ots-imgph--g1 { background: linear-gradient(135deg, #3c5d4f, #56796a); }
.ots-imgph--g2 { background: linear-gradient(135deg, #56796a, #8a9a6a); }
.ots-imgph--dots::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(rgba(255,255,255,0.12) 1.3px, transparent 1.3px); background-size: 24px 24px; }
.ots-imgph--stripe::before { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 22px); }
.ots-imgph__cap { position: absolute; left: 18px; bottom: 16px; font-size: 11px; color: rgba(255,255,255,0.7); letter-spacing: 0.08em; }
.ots-imgph__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
/* 画像を見切れさせず全体表示（美と健康ページ等） */
.ots-imgph--contain { height: auto; overflow: visible; }
.ots-imgph--contain .ots-imgph__img { position: static; width: 100%; height: auto; object-fit: contain; }
/* 画像の高さを抑えて収める（縦長画像用・中央寄せ） */
.ots-imgph--mh { text-align: center; }
.ots-imgph--mh .ots-imgph__img { width: auto; max-width: 100%; max-height: 400px; }
/* 2カラム下に置く横長画像（うっすら金の背景パネル・中央寄せ） */
.ots-healthimg { margin-top: 48px; padding: 44px; background: rgba(197,160,89,0.05); }
.ots-healthimg img { display: block; width: 100%; max-width: 860px; height: auto; margin: 0 auto; }
/* 美と健康ページ スマホ調整 */
@media (max-width: 760px) {
  .ots-imgph:not(.ots-imgph--contain) { height: 200px; }      /* 美容器具のサイド画像（suiso）を低く */
  .ots-healthimg { padding: 0; background: none; }             /* スマホ：背景なし・セクション幅いっぱいに */
  .ots-healthimg img { max-width: 100%; }
  .ots-twocol--sp-imgfirst .ots-imgph { order: -1; }           /* 電磁波：画像→テキストの順に */
}

/* 取扱品目見出し（テキスト＋金の罫線） */
.ots-itemhead { display: flex; align-items: center; gap: 12px; margin: 0 0 16px; }
.ots-itemhead__label { font-family: 'Shippori Mincho', serif; font-size: 14px; color: #2E4A3F; letter-spacing: 0.1em; white-space: nowrap; }
.ots-itemhead__line { flex: 1; height: 1px; background: #e3e0d6; }

/* 取扱品目リスト（番号 or ●） */
.ots-itemlist { }
.ots-itemlist__row { display: flex; align-items: center; gap: 12px; padding: 6px 2px; }
.ots-itemlist__num { font-family: 'Yu Mincho', serif; font-size: 18px; color: #C5A059; flex: none; min-width: 22px; }
.ots-itemlist__dot { width: 7px; height: 7px; background: #C5A059; border-radius: 50%; flex: none; }
.ots-itemlist__text { font-family: 'Shippori Mincho', serif; font-size: 16px; color: #2E4A3F; letter-spacing: 0.05em; }
.ots-itemlist__text small { font-size: 13px; color: #8a958f; letter-spacing: 0.04em; }

/* サービスチップ（2列グリッド） */
.ots-chipgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.ots-chip-cell { border: 1px solid #e3e0d6; background: rgba(255,255,255,0.5); padding: 13px 16px; font-size: 13.5px; color: #2E4A3F; letter-spacing: 0.04em; }

/* チップ（枠線・横並び） */
.ots-chips { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 4px; }
.ots-chip { border: 1px solid #2E4A3F; color: #2E4A3F; font-size: 13px; padding: 8px 16px; letter-spacing: 0.04em; }
.ots-chip--gold { border-color: #C5A059; color: #9a7c3e; }
.ots-sekirei .ots-chip::before { content: "✓"; margin-right: 6px; }

/* 情報ボックス（体験会・出張査定） */
.ots-infobox { background: #fff; border: 1px solid #e3e0d6; padding: 24px 26px; }
.ots-infobox__title { font-family: 'Shippori Mincho', serif; font-size: 16px; color: #2E4A3F; letter-spacing: 0.06em; margin-bottom: 8px; }
.ots-infobox__text { font-size: 13.5px; line-height: 1.95; color: #56615a; margin: 0 0 16px; }
.ots-btn-tel { display: inline-flex; align-items: center; gap: 9px; background: #2E4A3F; color: #fff; text-decoration: none; font-size: 14px; padding: 13px 24px; letter-spacing: 0.05em; transition: background 0.3s ease; }
.ots-btn-tel:hover { background: #3c5d4f; }

/* ========== about：代表挨拶 ========== */
.ots-about-greet { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 56px; align-items: center; }
.ots-portrait { height: 420px; position: relative; overflow: hidden; background: #23362f; background-size: cover; background-position: center; }
.ots-about-greet__title { font-family: 'Shippori Mincho', serif; font-weight: 600; font-size: 32px; letter-spacing: 0.05em; color: #2E4A3F; margin: 12px 0 22px; line-height: 1.6; }
.ots-about-greet__sign { display: flex; align-items: baseline; gap: 14px; }
.ots-about-greet__sign-label { font-size: 13px; color: #8a958f; letter-spacing: 0.08em; }
.ots-about-greet__sign-name { font-family: 'Shippori Mincho', serif; font-size: 24px; color: #2E4A3F; letter-spacing: 0.12em; }

/* ========== about：会社情報テーブル ========== */
.ots-company { margin: 0; border-top: 1px solid #ddd9cc; }
.ots-company__row { display: grid; grid-template-columns: 150px 1fr; gap: 24px; padding: 18px 4px; border-bottom: 1px solid #ddd9cc; }
.ots-company__dt { font-family: 'Shippori Mincho', serif; font-size: 14.5px; color: #2E4A3F; letter-spacing: 0.06em; }
.ots-company__dd { margin: 0; font-size: 14.5px; color: #3a443e; line-height: 1.8; letter-spacing: 0.02em; }

/* ========== about：プライバシーポリシー ========== */
.ots-policy { list-style: none; padding: 0; margin: 0; border-top: 1px solid #ddd9cc; }
.ots-policy__row { display: grid; grid-template-columns: 44px 1fr; gap: 18px; padding: 24px 4px; border-bottom: 1px solid #ddd9cc; align-items: start; }
.ots-policy__num { font-family: 'Yu Mincho', serif; font-size: 22px; color: #C5A059; line-height: 1.2; }
.ots-policy__text { font-size: 14.5px; line-height: 2.1; color: #3a443e; margin: 0; letter-spacing: 0.02em; }
.ots-policy__sub { list-style: none; padding: 0; margin: 14px 0 0; display: flex; flex-direction: column; gap: 8px; }
.ots-policy__sub li { display: flex; gap: 12px; align-items: flex-start; font-size: 14px; color: #56615a; line-height: 1.9; }
.ots-policy__sub-mark { color: #C5A059; flex: none; }
.ots-policy__date { margin-top: 36px; text-align: right; color: #2E4A3F; line-height: 2; letter-spacing: 0.06em; font-family: 'Shippori Mincho', serif; }
.ots-policy__date-small { font-size: 13.5px; color: #6a746d; }
.ots-policy__date-name { font-size: 15px; margin-top: 8px; }

/* ========== Googleマップ埋め込み ========== */
.ots-map { position: relative; overflow: hidden; }
.ots-map iframe { display: block; width: 100%; height: 100%; border: 0; }
.ots-map--about { height: 360px; border: 1px solid #ddd9cc; }
.ots-map--footer { height: 170px; border: 1px solid rgba(255,255,255,0.18); }
@media (max-width: 760px) {
  .ots-map--about { height: 260px; }
}

/* ========== 簡易マップボックス（旧ダミー・未使用） ========== */
.ots-mapbox { display: block; text-decoration: none; border: 1px solid #ddd9cc; overflow: hidden; }
.ots-mapbox--mt { margin-top: 28px; }
.ots-mapbox__inner { height: 200px; background: linear-gradient(135deg, #faf7ef, #efe9da); position: relative; display: flex; align-items: center; justify-content: center; }
.ots-mapbox__inner::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(46,74,63,0.07) 1px, transparent 1px), linear-gradient(90deg, rgba(46,74,63,0.07) 1px, transparent 1px); background-size: 28px 28px; }
.ots-mapbox__content { position: relative; text-align: center; color: #2E4A3F; }
.ots-mapbox__pin { color: #C5A059; font-size: 30px; margin-bottom: 8px; }
.ots-mapbox__addr { font-size: 13.5px; letter-spacing: 0.08em; }
.ots-mapbox__link { font-size: 11.5px; color: #9a7c3e; margin-top: 5px; }

/* ========== CTA帯 ========== */
.ots-cta { background: #2E4A3F; padding: 20px 40px; text-align: center; color: #fff; position: relative; overflow: hidden; }
.ots-cta::before { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 24px); }
.ots-cta__inner { position: relative; max-width: 900px; margin: 0 auto; padding: 50px 44px; }
/* タイトル上の金のあしらい（◇・FVと統一） */
.ots-cta__ornament { display: flex; align-items: center; justify-content: center; gap: 14px; margin-bottom: 22px; }
.ots-cta__ornament-line { width: 42px; height: 1px; background: rgba(197,160,89,0.6); }
.ots-cta__ornament-diamond { width: 8px; height: 8px; border: 1px solid #C5A059; transform: rotate(45deg); }
.ots-cta__title { font-family: 'Shippori Mincho', serif; font-weight: 500; font-size: 30px; line-height: 1.7; letter-spacing: 0.06em; margin: 0 0 14px; }
.ots-cta__tel { display: inline-flex; flex-direction: column; align-items: center; text-decoration: none; padding: 14px 44px; }
.ots-cta__tel-note { font-size: 12px; letter-spacing: 0.14em; color: #C5A059; margin-bottom: 6px; }
.ots-cta__tel-num { font-size: clamp(34px, 6vw, 39px); color: #fff; letter-spacing: 0.04em; line-height: 1; transition: opacity 0.3s ease; }
.ots-cta__tel:hover .ots-cta__tel-num { opacity: 0.85; }

/* ========== ヘッダー（共通） ========== */
.ots-header__logo { text-decoration: none; display: flex; align-items: center; flex: none; }
.ots-header__logo-img { height: 48px; width: auto; display: block; }
.ots-header__logo-img--invert { height: 52px; filter: brightness(0) invert(1); }
.ots-header__ig, .ots-header__mobile-tel { display: flex; align-items: center; justify-content: center; flex: none; text-decoration: none; }

/* --- TOP 透過オーバーレイ --- */
.ots-header--overlay { position: absolute; top: 0; left: 0; right: 0; z-index: 50; background: linear-gradient(180deg, rgba(18,13,8,0.5) 0%, rgba(18,13,8,0) 100%); }
.ots-header--overlay .ots-header__inner { max-width: 1560px; margin: 0 auto; padding: 30px 46px; display: flex; justify-content: space-between; align-items: flex-start; gap: 28px; }
.ots-header--overlay .ots-header__right { display: flex; flex-direction: column; align-items: flex-end; gap: 20px; }
.ots-header__contact { display: flex; align-items: center; gap: 15px; }
.ots-header__tel { font-size: 16px; color: #fff; text-decoration: none; letter-spacing: 0.08em; }
.ots-header__divider { width: 1px; height: 18px; background: rgba(255,255,255,0.45); }
.ots-header--overlay .ots-header__ig { width: 34px; height: 34px; border: 1px solid rgba(255,255,255,0.7); border-radius: 50%; color: #fff; }
.ots-header__vnav { display: flex; flex-direction: row; align-items: flex-start; }
.ots-header__vnav-item { writing-mode: vertical-rl; font-size: 17px; letter-spacing: 0.14em; line-height: 1; text-decoration: none; color: rgba(255,255,255,0.92); padding: 9px 14px; border-left: 1px solid rgba(255,255,255,0.3); transition: color 0.3s ease; }
.ots-header__vnav-item:first-child { border-right: 1px solid rgba(255,255,255,0.3); }
.ots-header__vnav-item:hover { color: #e7d3a8; }
.ots-header__vnav-item.is-current { color: #e7d3a8; }

/* --- 下層 白固定 --- */
.ots-header--solid { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.94); backdrop-filter: saturate(140%) blur(6px); border-bottom: 1px solid rgba(197,160,89,0.35); }
.ots-header--solid .ots-header__inner { max-width: 1240px; margin: 0 auto; padding: 0 24px; height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.ots-header--solid .ots-header__right { display: flex; align-items: center; gap: 26px; }
.ots-header__nav { display: flex; align-items: center; gap: 6px; }
.ots-header__nav-item { text-decoration: none; font-size: 16.5px; letter-spacing: 0.05em; color: #3a423d; padding: 8px 13px; transition: color 0.3s ease; font-family: 'Shippori Mincho', serif; }
.ots-header__nav-item:hover { color: #2E4A3F; }
.ots-header__nav-item.is-current { color: #2E4A3F; font-weight: 700; background: linear-gradient(#C5A059, #C5A059) bottom center / 10px 2px no-repeat; }
.ots-header__tools { display: flex; align-items: center; gap: 14px; padding-left: 22px; border-left: 1px solid rgba(0,0,0,0.1); }
.ots-header__tel-block { display: flex; flex-direction: column; align-items: flex-end; text-decoration: none; line-height: 1.1; }
.ots-header__tel-label { font-size: 10px; letter-spacing: 0.14em; color: #6b7770; }
.ots-header__tel-num { font-size: 21px; font-weight: 500; color: #2E4A3F; letter-spacing: 0.04em; }
.ots-header__ig--solid { width: 40px; height: 40px; border: 1px solid #2E4A3F; border-radius: 50%; color: #2E4A3F; transition: background 0.3s ease, color 0.3s ease; }
.ots-header__ig--solid:hover { background: #2E4A3F; color: #fff; }

/* --- モバイル共通ヘッダー --- */
.ots-header--mobile { display: none; position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.94); backdrop-filter: saturate(140%) blur(6px); border-bottom: 1px solid rgba(197,160,89,0.35); }
.ots-header--mobile .ots-header__inner { padding: 0 24px; height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.ots-header__mobile-tools { display: flex; align-items: center; gap: 10px; }
.ots-header__mobile-tel { width: 44px; height: 44px; border-radius: 50%; background: #2E4A3F; color: #fff; }

/* ハンバーガー */
.ots-nav-toggle { width: 44px; height: 44px; border: 1px solid #2E4A3F; border-radius: 50%; background: transparent; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px; cursor: pointer; flex: none; }
.ots-nav-toggle__line { width: 18px; height: 1.5px; background: #2E4A3F; display: block; transition: transform 0.3s ease, opacity 0.3s ease; }
.ots-nav-toggle.is-active .ots-nav-toggle__line:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.ots-nav-toggle.is-active .ots-nav-toggle__line:nth-child(2) { opacity: 0; }
.ots-nav-toggle.is-active .ots-nav-toggle__line:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* SPドロワー */
.ots-drawer { display: none; position: fixed; top: 78px; left: 0; right: 0; z-index: 49; background: #fff; border-top: 1px solid rgba(197,160,89,0.35); padding: 8px 24px 22px; max-height: calc(100vh - 78px); overflow-y: auto; }
.ots-drawer.is-open { display: block; }
.ots-drawer__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.ots-drawer__link { display: flex; align-items: baseline; gap: 12px; padding: 15px 10px; font-size: 16px; color: #1A1A1A; text-decoration: none; border-bottom: 1px solid #eee; letter-spacing: 0.04em; }
.ots-drawer__link.is-current { color: #2E4A3F; }
.ots-drawer__en { font-size: 11px; color: #C5A059; letter-spacing: 0.1em; min-width: 56px; }
.ots-drawer__bottom { margin-top: 18px; display: flex; flex-direction: column; align-items: center; text-align: center; gap: 14px; }
.ots-drawer__tel { color: #2E4A3F; text-decoration: none; font-size: 22px; letter-spacing: 0.04em; }
.ots-drawer__ig { display: inline-flex; align-items: center; gap: 10px; color: #2E4A3F; text-decoration: none; font-size: 14px; letter-spacing: 0.04em; }
body.is-drawer-open { overflow: hidden; }

/* ========== フッター ========== */
.ots-footer { background: linear-gradient(180deg, #243a32 0%, #1f332c 100%); color: #e8ece9; border-top: 1px solid rgba(197,160,89,0.5); }
.ots-footer__inner { max-width: 1240px; margin: 0 auto; padding: 64px 24px 0; display: grid; grid-template-columns: 1.3fr 1fr 1.1fr; gap: 48px; align-items: start; }
.ots-footer__logo { height: 56px; width: auto; display: block; filter: brightness(0) invert(1); margin-bottom: 22px; }
.ots-footer__addr { font-size: 13.5px; line-height: 2; color: #c2ccc6; margin: 0 0 22px; }
.ots-footer__btns { display: flex; gap: 12px; flex-wrap: wrap; }
.ots-footer__btn { display: inline-flex; align-items: center; gap: 9px; text-decoration: none; font-size: 14px; letter-spacing: 0.05em; padding: 13px 22px; transition: opacity 0.3s ease; }
.ots-footer__btn:hover { opacity: 0.85; }
.ots-footer__btn--tel { background: #C5A059; color: #23362f; font-weight: 700; padding: 13px 24px; }
.ots-footer__btn--ig { border: 1px solid rgba(255,255,255,0.5); color: #fff; }
.ots-footer__heading { font-family: 'Shippori Mincho', serif; font-size: 14px; color: #C5A059; letter-spacing: 0.16em; margin: 0 0 18px; font-weight: 500; }
.ots-footer__nav { display: flex; flex-direction: column; gap: 12px; }
.ots-footer__nav-link { color: #d6ddd9; text-decoration: none; font-size: 13.5px; transition: color 0.3s ease; }
.ots-footer__nav-link:hover { color: #C5A059; }
.ots-footer__map { display: block; text-decoration: none; border: 1px solid rgba(255,255,255,0.18); overflow: hidden; }
.ots-footer__map-inner { height: 170px; background: linear-gradient(135deg, #faf7ef, #efe9da); position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #2E4A3F; }
.ots-footer__map-inner::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(46,74,63,0.07) 1px, transparent 1px), linear-gradient(90deg, rgba(46,74,63,0.07) 1px, transparent 1px); background-size: 26px 26px; }
.ots-footer__map-pin { position: relative; color: #C5A059; font-size: 28px; margin-bottom: 8px; }
.ots-footer__map-addr { position: relative; font-size: 13px; letter-spacing: 0.08em; }
.ots-footer__map-link { position: relative; font-size: 11px; color: #9a7c3e; margin-top: 4px; }
.ots-footer__map-note { font-size: 11.5px; color: #9fb0a8; margin: 12px 0 0; line-height: 1.7; }
.ots-footer__bottom { max-width: 1240px; margin: 48px auto 0; padding: 22px 24px; border-top: 1px solid rgba(255,255,255,0.12); display: flex; flex-wrap: wrap; gap: 8px 20px; align-items: center; justify-content: center; }
.ots-footer__bottom .font-en { font-family: 'Cormorant Garamond', serif; font-size: 12px; letter-spacing: 0.14em; color: #9fb0a8; }

/* ========== お知らせサイドバー ========== */
.ots-side { display: flex; flex-direction: column; gap: 34px; }
.ots-side__heading { font-family: 'Shippori Mincho', serif; font-size: 16px; color: #2E4A3F; letter-spacing: 0.08em; margin: 0 0 16px; padding-bottom: 12px; border-bottom: 2px solid #C5A059; }
.ots-side__cats { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.ots-side__cat { border-bottom: 1px solid #eee; }
.ots-side__cat-link { display: flex; justify-content: space-between; padding: 12px 2px; font-size: 13.5px; color: #3a443e; text-decoration: none; letter-spacing: 0.03em; transition: color 0.25s ease; }
.ots-side__cat-link:hover { color: #2E4A3F; }
.ots-side__cat-link.is-current { color: #2E4A3F; font-weight: 700; }
.ots-side__cat-count { color: #9aa49d; }
.ots-side__recent { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 16px; }
.ots-side__recent-link { text-decoration: none; display: block; }
.ots-side__recent-date { display: block; font-size: 12.5px; color: #9aa49d; letter-spacing: 0.06em; margin-bottom: 3px; }
.ots-side__recent-title { display: block; font-size: 13px; line-height: 1.6; color: #33403a; transition: color 0.25s ease; }
.ots-side__recent-link:hover .ots-side__recent-title { color: #2E4A3F; }
.ots-side__contact { background: #2E4A3F; padding: 26px 24px; color: #fff; }
.ots-side__contact-title { font-family: 'Shippori Mincho', serif; font-size: 15px; letter-spacing: 0.06em; margin-bottom: 10px; }
.ots-side__contact-desc { font-size: 12.5px; line-height: 1.9; color: #cdd6d1; margin: 0 0 14px; }
.ots-side__contact-tel { font-size: 24px; color: #fff; text-decoration: none; letter-spacing: 0.04em; }

/* ========== お知らせ一覧 ========== */
.ots-list-layout { max-width: 1140px; margin: 0 auto; display: grid; grid-template-columns: 1fr 280px; gap: 56px; align-items: start; }
.ots-catfilter { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 30px; }
.ots-catfilter__item { border: 1px solid #d8d4c7; color: #3a443e; font-size: 13px; padding: 8px 18px; letter-spacing: 0.05em; cursor: pointer; text-decoration: none; transition: all 0.25s ease; }
.ots-catfilter__item.is-active { background: #2E4A3F; color: #fff; border-color: #2E4A3F; }
.ots-catfilter__item:hover { border-color: #2E4A3F; }
.ots-postlist { display: flex; flex-direction: column; }
.ots-post { display: grid; grid-template-columns: 200px 1fr; gap: 26px; padding: 24px 0; border-bottom: 1px solid #e6e6df; text-decoration: none; align-items: center; }
.ots-post__thumb { height: 130px; position: relative; overflow: hidden; background: #2E4A3F; background-size: cover; background-position: center; }
.ots-post__thumb::after { content: ""; position: absolute; inset: 0; background-image: radial-gradient(rgba(255,255,255,0.12) 1.2px, transparent 1.2px); background-size: 20px 20px; }
.ots-post__thumb--g1 { background: linear-gradient(135deg, #3c5d4f, #56796a); }
.ots-post__thumb--g2 { background: linear-gradient(135deg, #4a5d44, #6b7d4a); }
.ots-post__thumb--g3 { background: linear-gradient(135deg, #2E4A3F, #3c5d4f); }
.ots-post__thumb--g4 { background: linear-gradient(135deg, #56796a, #8a9a6a); }
.ots-post__thumb--g5 { background: linear-gradient(135deg, #3c5d4f, #2E4A3F); }
.ots-post__thumb--g6 { background: linear-gradient(135deg, #4a5d44, #56796a); }
.ots-post__meta { display: flex; align-items: center; gap: 14px; margin-bottom: 10px; }
.ots-post__date { font-size: 14px; color: #8a958f; letter-spacing: 0.06em; }
.ots-post__cat { font-size: 11px; letter-spacing: 0.08em; color: #2E4A3F; border: 1px solid #2E4A3F; padding: 3px 11px; }
.ots-post__title { font-family: 'Shippori Mincho', serif; font-weight: 600; font-size: 19px; line-height: 1.6; color: #28332d; margin: 0 0 8px; letter-spacing: 0.02em; transition: color 0.25s ease; }
.ots-post:hover .ots-post__title { color: #2E4A3F; }
.ots-post__excerpt { font-size: 13px; line-height: 1.9; color: #6a746d; margin: 0; }

/* ページネーション */
.ots-pager { display: flex; justify-content: center; gap: 8px; margin-top: 46px; }
.ots-pager__item { width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; border: 1px solid #d8d4c7; color: #3a443e; text-decoration: none; font-family: 'Yu Mincho', serif; transition: all 0.25s ease; }
.ots-pager__item:hover { border-color: #2E4A3F; color: #2E4A3F; }
.ots-pager__item.is-current { background: #2E4A3F; color: #fff; border-color: #2E4A3F; }

/* ========== お知らせ詳細 ========== */
.ots-crumb-bar { background: #F5F5F0; padding: 18px 40px; border-bottom: 1px solid #e6e3d8; }
.ots-crumb-bar__nav { max-width: 1140px; margin: 0 auto; font-size: 12.5px; letter-spacing: 0.05em; color: #7a857d; }
.ots-crumb-bar__nav a { color: #7a857d; text-decoration: none; }
.ots-crumb-bar__nav a:hover { color: #2E4A3F; }
.ots-crumb-bar__nav .is-current { color: #2E4A3F; }
.ots-entry__meta { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.ots-entry__date { font-size: 15px; color: #8a958f; letter-spacing: 0.06em; }
.ots-entry__cat { font-size: 11.5px; letter-spacing: 0.08em; color: #fff; background: #2E4A3F; padding: 4px 13px; }
.ots-entry__title { font-family: 'Shippori Mincho', serif; font-weight: 600; font-size: 25px; line-height: 1.55; letter-spacing: 0.04em; color: #1f2b25; margin: 0 0 28px; }
.ots-entry__hero { height: 380px; position: relative; overflow: hidden; background: #23362f; background-size: cover; background-position: center; margin-bottom: 36px; }
.ots-entry__hero--ph { background: linear-gradient(135deg, #3c5d4f, #56796a); }
.ots-entry__hero--ph::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(rgba(255,255,255,0.12) 1.4px, transparent 1.4px); background-size: 26px 26px; }
.ots-entry__hero-cap { position: absolute; left: 20px; bottom: 18px; font-size: 11px; color: rgba(255,255,255,0.7); letter-spacing: 0.08em; }
.ots-entry__body { font-size: 15.5px; line-height: 2.3; letter-spacing: 0.03em; color: #39433d; }
.ots-entry__body p { margin: 0 0 24px; }
.ots-entry__h2 { font-family: 'Shippori Mincho', serif; font-weight: 600; font-size: 23px; color: #2E4A3F; letter-spacing: 0.04em; margin: 38px 0 16px; padding-left: 16px; border-left: 3px solid #C5A059; }
.ots-entry__ul { list-style: none; padding: 0; margin: 0 0 24px; display: flex; flex-direction: column; gap: 12px; }
.ots-entry__ul li { display: flex; gap: 12px; align-items: flex-start; }
.ots-entry__ul li::before { content: ""; width: 7px; height: 7px; background: #C5A059; border-radius: 50%; flex: none; margin-top: 11px; }
.ots-entry__telbox { background: #F5F5F0; border: 1px solid #e3e0d6; padding: 26px 28px; text-align: center; }
.ots-entry__telbox-label { font-size: 12px; letter-spacing: 0.12em; color: #8a958f; margin-bottom: 6px; }
.ots-entry__telbox-num { font-size: clamp(28px, 5vw, 40px); color: #2E4A3F; text-decoration: none; letter-spacing: 0.04em; }
.ots-entry__telbox-note { font-size: 12.5px; color: #6a746d; margin-top: 6px; }
/* 記事本文CMSは span(inline) に div を注入するため block 化 */
#cms-blog-entry-detail-2-area { display: block; }
.ots-entry__body img { margin: 8px 0; }
.ots-entry__pager { margin-bottom: 22px; }
.ots-entry__pager .pages { display: flex; flex-wrap: wrap; gap: 10px 20px; justify-content: space-between; align-items: center; }
.ots-entry__pager .pages a { color: #2E4A3F; text-decoration: none; font-size: 14px; letter-spacing: 0.04em; }
.ots-entry__pager .pages a:hover { color: #C5A059; }
.ots-entry__back { margin-top: 44px; padding-top: 28px; border-top: 1px solid #e6e6df; }
.ots-entry__back-btn { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; color: #2E4A3F; text-decoration: none; letter-spacing: 0.05em; border: 1px solid #2E4A3F; padding: 13px 28px; transition: background 0.3s ease, color 0.3s ease; }
.ots-entry__back-btn:hover { background: #2E4A3F; color: #fff; }
.ots-entry__back-btn--side { width: 100%; justify-content: center; }

/* ========== ページトップ ========== */
.ots-pagetop { position: fixed; right: 20px; bottom: 20px; width: 48px; height: 48px; border-radius: 50%; border: none; background: #2E4A3F; color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transform: translateY(10px); transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease; z-index: 90; }
.ots-pagetop.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.ots-pagetop:hover { background: #3c5d4f; }

/* ==========================================================================
   レスポンシブ
   ========================================================================== */
@media (max-width: 980px) {
  .ots-header--pc { display: none !important; }
  .ots-header--mobile { display: block; }
  .ots-biz { grid-template-columns: repeat(2, 1fr); gap: 30px 18px; }
  /* ハンバーガー表示時はフッターのサイトメニュー（ナビ重複）を非表示 */
  .ots-footer__col--menu { display: none; }
}

@media (max-width: 860px) {
  .ots-footer__inner { grid-template-columns: 1fr; }
}

@media (max-width: 820px) {
  .ots-list-layout { grid-template-columns: 1fr; gap: 48px; }
  .ots-post { grid-template-columns: 110px 1fr; gap: 16px; }
  .ots-post__thumb { height: 78px; }
  .ots-post__title { font-size: 16px; }
  .ots-crumb-bar { padding: 16px 24px; }
  .ots-sec--entry { padding: 40px 24px 64px; }
  .ots-entry__title { font-size: 24px; }
  .ots-entry__hero { height: 220px; }
  .ots-entry__h2 { font-size: 19px; }
}

@media (max-width: 760px) {
  .ots-sec { padding: 56px 24px; }
  .ots-sec--90, .ots-sec--84 { padding: 52px 24px; }
  .ots-hero__catch { font-size: 23px; margin: 28px 0 0; letter-spacing: 0.01em; }
  .ots-hero__sub { font-size: 12px; }
  .ots-greeting, .ots-about-greet { grid-template-columns: 1fr; gap: 28px; }
  .ots-greeting__title { font-size: 26px; }
  /* スマホ：四角あしらいを右側・画面右端にぴったり、タイトル2行目〜本文にかかる縦長。透過は強めに */
  .ots-greeting__gold { display: block; left: auto; right: -24px; top: 40px; bottom: auto; width: 180px; height: 195px; background: rgba(197,160,89,0.20); }
  .ots-h2--34 { font-size: 26px; }
  .ots-h2--30, .ots-h2--32 { font-size: 23px; }
  .ots-body { font-size: 14.5px; }
  .ots-news__row { grid-template-columns: 1fr; gap: 5px; }
  .ots-news__date { font-size: 12px; }
  .ots-news__title { font-size: 14px; }
  .ots-page-hero { padding: 54px 24px; }
  .ots-page-hero__title { font-size: 28px; }
  .ots-page-hero__title--sm { font-size: 24px; }
  .ots-lead { padding: 48px 24px; }
  .ots-lead__p { font-size: 17px; text-align: left; }
  .ots-twocol { grid-template-columns: 1fr; gap: 28px; }
  .ots-twocol__img, .ots-twocol__img--340 { height: 220px; }
  .ots-portrait { height: 260px; }
  .ots-company__row { grid-template-columns: 96px 1fr; gap: 12px; }
  .ots-policy__row { grid-template-columns: 32px 1fr; gap: 8px; }
  .ots-cta { padding: 20px 24px; }
  .ots-cta__inner { padding: 34px 20px; }
  .ots-cta__title { font-size: 22px; }
  /* スマホ時は電話ボタンの左右パディングを無くす */
  .ots-cta__tel { padding-left: 0; padding-right: 0; }
  .ots-chipgrid { grid-template-columns: 1fr; }
  /* フッター：電話＋Instagramボタンを横並び（等幅・1行） */
  .ots-footer__btns { flex-wrap: nowrap; gap: 8px; }
  .ots-footer__btn { flex: 1; justify-content: center; font-size: 12px; gap: 6px; white-space: nowrap; }
  .ots-footer__btn--tel, .ots-footer__btn--ig { padding: 13px 6px; }
}

@media (max-width: 560px) {
  .ots-biz { grid-template-columns: 1fr; gap: 16px; }
  .ots-biz__card { aspect-ratio: 1 / 1; }
}
