@charset "UTF-8";
/* ============================================================
   JIN:R Beauty Medical — custom overlay
   iwakura-kibo-clinic.com TTPの左サイド固定ナビ＋黄緑×クリーム配色
   ============================================================ */

:root {
  --bm-accent: #cbd34a;        /* 黄緑（iwakura踏襲） */
  --bm-accent-dark: #a8b033;
  --bm-accent-light: #e6e89a;
  --bm-cream: #fffdf7;
  --bm-cream-2: #f7f3e6;
  --bm-ink: #2d2a26;
  --bm-ink-soft: #5b554c;
  --bm-pink: #f6c8d3;           /* nobikuriロゴのピンク */
  --bm-side-w: 200px;           /* PC左サイドバー幅 */
  --bm-sp-top-h: 60px;
  --bm-sp-bottom-h: 72px;
  --bm-radius: 12px;
}

/* ---------- Font stacks ---------- */
html, body {
  font-family: "Zen Maru Gothic", "Roboto", "Inter", "Hiragino Sans", "Yu Gothic UI", sans-serif;
  background: var(--bm-cream);
  color: var(--bm-ink);
}
h1, h2, h3, h4, h5, h6,
.beauty-side__nav a,
.beauty-cta-btn,
.beauty-sp-bottom__btn {
  font-family: "Zen Maru Gothic", "Roboto", "Hiragino Sans", sans-serif;
  font-weight: 600;
  letter-spacing: 0.02em;
}
/* 英数字は Roboto/Inter 優先 */
.num, time, .price, .en, code, kbd, samp {
  font-family: "Roboto", "Inter", sans-serif;
}

/* ============================================================
   PC: 左サイド固定ナビ（≥ 992px）
   ============================================================ */
.beauty-side {
  position: fixed;
  top: 0; left: 0;
  width: var(--bm-side-w);
  height: 100vh;
  background: var(--bm-accent);
  color: var(--bm-ink);
  z-index: 1000;
  padding: 24px 16px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}
.beauty-side__logo {
  display: block;
  text-align: center;
  margin-bottom: 24px;
}
.beauty-side__logo img {
  max-width: 130px;
  height: auto;
  display: inline-block;
}
.beauty-side__nav {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.beauty-side__nav a {
  display: block;
  padding: 12px 14px;
  color: var(--bm-ink);
  text-decoration: none;
  font-size: 14px;
  border-radius: 8px;
  transition: background 0.15s ease;
}
.beauty-side__nav a:hover {
  background: rgba(255,255,255,0.5);
}
.beauty-side__nav .current-menu-item a,
.beauty-side__nav .current_page_item a {
  background: var(--bm-cream);
  font-weight: 700;
}

/* 右上Instagram風アイコン（オプション、コンテンツ右上） */
.beauty-side__sns {
  position: fixed;
  top: 16px; right: 16px;
  z-index: 999;
  display: flex;
  gap: 8px;
}
.beauty-side__sns a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  background: var(--bm-accent);
  border-radius: 50%;
  color: var(--bm-ink);
  text-decoration: none;
  font-size: 12px;
  font-weight: 700;
}

/* メインコンテンツをサイドバー分右にずらす */
@media (min-width: 992px) {
  body { padding-left: var(--bm-side-w); }
  #wrapper, .l--site-wrapper, .l--site-container {
    padding-left: 0 !important;
  }
  /* JIN:Rの既存ヘッダーは非表示（左サイドナビと競合するため） */
  .l--header, .l--global-nav, header.l--header {
    display: none !important;
  }
  .beauty-sp-top, .beauty-sp-bottom,
  .beauty-sp-drawer, .beauty-sp-drawer-overlay { display: none !important; }
  /* JIN:Rのヘッダー系クラスを念のためまとめて抑制 */
  #header, .l--header-wrap, .l--header-container, .a--header-style-parts,
  .l--global-nav, .l--global-nav-wrap, .c--gnav, nav.l--global-nav {
    display: none !important;
  }
}

/* ドロワー類はデフォルト非表示。SP @media クエリ内でのみ表示する。
   ログイン時のadmin barと被らないよう、念入りに position 固定で隠す */
.beauty-sp-drawer,
.beauty-sp-drawer-overlay {
  display: none !important;
}

/* ============================================================
   WP admin bar 対応（ログインユーザーのみ）
   admin bar 高さ: PC=32px / SP(<=782px)=46px
   ============================================================ */
.admin-bar .beauty-side {
  top: 32px;
  height: calc(100vh - 32px);
}
.admin-bar .beauty-sp-top {
  top: 32px;
}
@media (max-width: 782px) {
  .admin-bar .beauty-sp-top { top: 46px; }
  .admin-bar { padding-top: 46px; }
}

/* ============================================================
   SP: 上部ロゴ+ハンバーガー、下部fixed CTA（< 992px）
   ============================================================ */
@media (max-width: 991.98px) {
  .beauty-side, .beauty-side__sns { display: none !important; }
  .beauty-sp-drawer-overlay { display: block !important; }
  .beauty-sp-drawer { display: block !important; }
  body {
    padding-top: var(--bm-sp-top-h);
    padding-bottom: var(--bm-sp-bottom-h);
  }
  /* JIN:R既存ヘッダーを抑制 */
  .l--header, header.l--header {
    display: none !important;
  }

  /* 上部固定ヘッダー */
  .beauty-sp-top {
    position: fixed;
    top: 0; left: 0; right: 0;
    height: var(--bm-sp-top-h);
    background: var(--bm-cream);
    border-bottom: 2px solid var(--bm-accent);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 16px;
  }
  .beauty-sp-top__logo {
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: var(--bm-ink);
  }
  .beauty-sp-top__logo img {
    height: 42px;
    width: auto;
  }
  .beauty-sp-top__catch {
    font-size: 11px;
    line-height: 1.3;
    font-weight: 600;
    color: var(--bm-ink);
  }
  .beauty-sp-top__menu-btn {
    width: 40px; height: 40px;
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    padding: 8px;
  }
  .beauty-sp-top__menu-btn span {
    display: block;
    height: 2px;
    background: var(--bm-ink);
    border-radius: 2px;
  }

  /* SPメニュードロワー */
  .beauty-sp-drawer {
    position: fixed;
    top: 0; right: -100%;
    width: 80%;
    max-width: 320px;
    height: 100vh;
    background: var(--bm-accent);
    z-index: 1100;
    padding: 80px 24px 24px;
    transition: right 0.25s ease;
    overflow-y: auto;
  }
  .beauty-sp-drawer.is-open { right: 0; }
  .beauty-sp-drawer__close {
    position: absolute;
    top: 16px; right: 16px;
    width: 40px; height: 40px;
    background: none;
    border: none;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: var(--bm-ink);
  }
  .beauty-sp-drawer ul {
    list-style: none;
    padding: 0; margin: 0;
  }
  .beauty-sp-drawer ul li a {
    display: block;
    padding: 14px 12px;
    color: var(--bm-ink);
    text-decoration: none;
    font-size: 16px;
    font-weight: 600;
    border-bottom: 1px solid rgba(0,0,0,0.08);
  }
  .beauty-sp-drawer-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 1099;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease;
  }
  .beauty-sp-drawer-overlay.is-open {
    opacity: 1;
    visibility: visible;
  }

  /* 下部固定CTA */
  .beauty-sp-bottom {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: var(--bm-sp-bottom-h);
    background: var(--bm-accent);
    z-index: 999;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2px;
    padding: 6px;
    box-sizing: border-box;
  }
  .beauty-sp-bottom__btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--bm-cream);
    color: var(--bm-ink);
    text-decoration: none;
    font-size: 10px;
    line-height: 1.2;
    border-radius: 6px;
    padding: 4px;
  }
  .beauty-sp-bottom__btn .ico {
    font-size: 18px;
    margin-bottom: 2px;
  }
}

/* ============================================================
   共通: 装飾、見出し、リンクの色味
   ============================================================ */
a { color: var(--bm-accent-dark); }
a:hover { color: var(--bm-ink); }

.entry-content h2 {
  border-left: 6px solid var(--bm-accent);
  padding-left: 12px;
  background: var(--bm-cream-2);
  padding: 12px 16px 12px 18px;
  border-radius: 0 var(--bm-radius) var(--bm-radius) 0;
}
.entry-content h3 {
  border-bottom: 2px dashed var(--bm-accent);
  padding-bottom: 4px;
}

.beauty-tag {
  display: inline-block;
  padding: 2px 10px;
  background: var(--bm-accent);
  color: var(--bm-ink);
  border-radius: 100px;
  font-size: 12px;
  font-weight: 600;
}

/* メインビジュアル領域（フロントページ） */
.beauty-mv {
  background: var(--bm-cream);
  padding: 48px 24px;
  text-align: center;
}
.beauty-mv__catch {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(22px, 4vw, 36px);
  font-weight: 700;
  color: var(--bm-ink);
  line-height: 1.5;
}
.beauty-mv__sub {
  margin-top: 12px;
  color: var(--bm-ink-soft);
  font-size: 14px;
}

/* ============================================================
   JIN:R 実物セレクタに対する強い上書き (v5)
   v1〜v4で見落としていた `#commonHeader`, `#commonFooter`, `aside`
   等のJIN:R独自IDを完全に塗り直す
   ============================================================ */

/* JIN:Rのトップヘッダーを完全非表示 */
#commonHeader,
header#commonHeader,
#commonHeaderInner,
.a--header-style-parts {
  display: none !important;
}

/* 左サイドナビ：背景を強制で黄緑に */
aside.beauty-side,
.beauty-side {
  background-color: #cbd34a !important;
  background: var(--bm-accent) !important;
  color: var(--bm-ink) !important;
}

/* body / wrapper / main 領域の背景をクリームに */
body,
body.admin-bar,
#wrapper,
#mainContent,
#mainContentInner {
  background-color: var(--bm-cream) !important;
}

/* メイン記事ブロック（記事ゼロでも見栄え担保） */
#jinrArticle,
#postContent {
  background: var(--bm-cream) !important;
}
#postHeader {
  background: var(--bm-cream-2) !important;
  border-radius: var(--bm-radius);
  padding: 24px 16px;
  margin-bottom: 24px;
}
.d--archive-subtitle {
  color: var(--bm-accent-dark) !important;
  letter-spacing: 0.2em;
  font-weight: 600;
}
#jinrPostTitle,
h1.c--entry-title {
  color: var(--bm-ink) !important;
  font-family: "Zen Maru Gothic", "Roboto", sans-serif !important;
}

/* JIN:Rフッターを黄緑＋クリーム系に塗る（非表示にはしない） */
#commonFooter,
footer#commonFooter,
#commonFooterInner {
  background: var(--bm-accent) !important;
  color: var(--bm-ink) !important;
}
#commonFooter a,
#commonFooter .a--footer-copyright,
#commonFooter #footerInfo,
#commonFooter #footerMenuList {
  color: var(--bm-ink) !important;
}
#commonFooter a:hover { opacity: 0.7; }

/* パンくず（HOME > ...）を黄緑系に */
#breadcrumb,
.c--breadcrumb,
.breadcrumb,
nav.breadcrumb {
  background: var(--bm-cream-2) !important;
  color: var(--bm-ink) !important;
}
#breadcrumb a, .breadcrumb a {
  color: var(--bm-accent-dark) !important;
}

/* 「記事がありません」のエンプティステート（記事ゼロのときだけ表示）
   ※ .new-post-list-item は記事1件1件にも付くクラスなので、全件装飾しないこと。
   空状態は <article class="new-post-list-item">記事がありません</article> でリンクが入らないため、
   `:not(:has(a))` で「中身にリンクが無いもの」だけターゲットする */
.new-post-list-item:not(:has(a)):not(:has(img)) {
  text-align: center;
  padding: 80px 20px;
  font-size: 16px;
  color: var(--bm-ink-soft);
  background: var(--bm-cream);
  border: 2px dashed var(--bm-accent-light);
  border-radius: var(--bm-radius);
  margin: 24px 0;
}
.new-post-list-item:not(:has(a)):not(:has(img))::before {
  content: "📝";
  display: block;
  font-size: 48px;
  margin-bottom: 16px;
}

/* 通常の記事リストカードのトンマナ揃え */
.new-post-list-item {
  background: var(--bm-cream);
}
.new-post-list-item a { color: var(--bm-ink); }
.new-post-list-item a:hover { color: var(--bm-accent-dark); }

/* JIN:R のサイドバー（既存のもの）が出てたら隠す（左サイドナビと役割重複） */
#sidebar,
.l--sidebar,
.l--sidebar-wrap {
  display: none !important;
}

/* ============================================================
   v7: sticky footer 実装
   コンテンツが短くてもフッターを画面最下部に貼り付ける。
   html 背景を cream にして、フッター下の白抜けを完全に消す
   ============================================================ */
html {
  background-color: var(--bm-cream) !important;
  min-height: 100%;
}
body {
  background-color: var(--bm-cream) !important;
  min-height: 100vh !important;
}
/* v11緊急修正: flex化は撤回（PCで横並び崩壊の原因）。
   フッター下の白抜けは html, body の cream で覆う */

/* v12: sticky footer をmin-heightだけで安全実現（display変更なし）
   #mainContent に min-height を与えてフッターを画面下まで押し下げる */
@media (min-width: 992px) {
  #wrapper { min-height: 100vh; }
  #mainContent { min-height: calc(100vh - 220px); }
  body.admin-bar #mainContent { min-height: calc(100vh - 252px); }
}
@media (max-width: 991.98px) {
  #mainContent { min-height: calc(100vh - 360px); }
}

/* ============================================================
   v8: フロントトップページのスタイル
   iwakuraTTP: FV / カテゴリ4カード / ピックアップ / 最新記事 / CTA
   ============================================================ */
.bm-top-fv {
  background: linear-gradient(180deg, var(--bm-accent-light) 0%, var(--bm-cream) 100%);
  padding: 64px 24px 80px;
}
.bm-top-fv__inner {
  max-width: 960px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: center;
}
.bm-top-fv__lead {
  display: inline-block;
  padding: 4px 12px;
  background: var(--bm-accent);
  color: var(--bm-ink);
  border-radius: 100px;
  font-size: 13px;
  font-weight: 600;
  margin: 0 0 16px;
}
.bm-top-fv__catch {
  font-family: "Zen Maru Gothic", "Roboto", sans-serif;
  font-size: clamp(24px, 3.4vw, 38px);
  font-weight: 700;
  color: var(--bm-ink);
  line-height: 1.45;
  margin: 0 0 16px;
}
.bm-top-fv__sub {
  font-size: 15px;
  line-height: 1.8;
  color: var(--bm-ink-soft);
  margin: 0 0 24px;
}
.bm-top-fv__ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.bm-top-fv__img img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

.bm-top-cta {
  display: inline-block;
  padding: 14px 28px;
  border-radius: 100px;
  font-weight: 700;
  text-decoration: none !important;
  font-size: 15px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.bm-top-cta--primary {
  background: var(--bm-accent);
  color: var(--bm-ink) !important;
  box-shadow: 0 4px 0 var(--bm-accent-dark);
}
.bm-top-cta--ghost {
  background: var(--bm-cream);
  color: var(--bm-ink) !important;
  border: 2px solid var(--bm-accent);
}
.bm-top-cta:hover { transform: translateY(2px); box-shadow: 0 2px 0 var(--bm-accent-dark); }

.bm-top-h2 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(20px, 2.4vw, 28px);
  font-weight: 700;
  text-align: center;
  margin: 0 0 32px;
  position: relative;
  padding-bottom: 12px;
}
.bm-top-h2::after {
  content: "";
  display: block;
  width: 60px;
  height: 4px;
  background: var(--bm-accent);
  border-radius: 4px;
  margin: 12px auto 0;
}

.bm-top-cats { padding: 64px 24px; background: var(--bm-cream); }
.bm-top-cats__grid {
  max-width: 960px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.bm-top-card {
  display: block;
  padding: 28px 20px;
  background: var(--bm-cream-2);
  border-radius: var(--bm-radius);
  text-decoration: none !important;
  color: var(--bm-ink) !important;
  text-align: center;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.bm-top-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 16px rgba(168, 176, 51, 0.2);
}
.bm-top-card__emoji {
  font-size: 40px;
  margin-bottom: 12px;
}
.bm-top-card__title {
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 8px;
}
.bm-top-card__desc {
  font-size: 12px;
  color: var(--bm-ink-soft);
  line-height: 1.6;
  margin: 0;
}

.bm-top-pickup { padding: 64px 24px; background: var(--bm-cream-2); }
.bm-top-pickup__grid {
  max-width: 960px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.bm-top-pick {
  background: var(--bm-cream);
  border-radius: var(--bm-radius);
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}
.bm-top-pick img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
}
.bm-top-pick__body { padding: 20px; }
.bm-top-pick__tag {
  display: inline-block;
  padding: 2px 10px;
  background: var(--bm-accent);
  color: var(--bm-ink);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  margin-bottom: 10px;
}
.bm-top-pick h3 {
  font-size: 17px;
  font-weight: 700;
  line-height: 1.5;
  margin: 0 0 8px;
  color: var(--bm-ink);
}
.bm-top-pick p {
  font-size: 13px;
  color: var(--bm-ink-soft);
  line-height: 1.7;
  margin: 0;
}

.bm-top-latest { padding: 64px 24px; background: var(--bm-cream); }
.bm-top-latest .wp-block-latest-posts {
  max-width: 960px;
  margin: 0 auto;
}
.bm-top-latest .wp-block-latest-posts.is-grid {
  list-style: none;
  padding: 0;
  gap: 16px;
}
.bm-top-latest .wp-block-latest-posts li {
  background: var(--bm-cream-2);
  border-radius: var(--bm-radius);
  overflow: hidden;
  padding: 12px;
}
.bm-top-latest .wp-block-latest-posts__featured-image img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-radius: 8px;
  margin-bottom: 12px;
}
.bm-top-latest .wp-block-latest-posts a {
  color: var(--bm-ink);
  text-decoration: none;
  font-weight: 600;
  line-height: 1.5;
}
.bm-top-latest .wp-block-latest-posts__post-date {
  display: block;
  font-size: 12px;
  color: var(--bm-ink-soft);
  margin-top: 4px;
}

.bm-top-about-cta {
  padding: 80px 24px;
  background: var(--bm-accent);
  text-align: center;
}
.bm-top-about-cta__inner {
  max-width: 720px;
  margin: 0 auto;
}
.bm-top-about-cta h2 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(22px, 2.6vw, 30px);
  margin: 0 0 16px;
  color: var(--bm-ink);
}
.bm-top-about-cta p {
  font-size: 15px;
  line-height: 1.8;
  margin: 0 0 24px;
  color: var(--bm-ink);
}

@media (max-width: 768px) {
  .bm-top-fv__inner { grid-template-columns: 1fr; text-align: center; }
  .bm-top-fv__img { order: -1; }
  .bm-top-fv__img img { max-width: 200px; }
  .bm-top-fv__ctas { justify-content: center; }
  .bm-top-cats__grid { grid-template-columns: repeat(2, 1fr); }
  .bm-top-pickup__grid { grid-template-columns: 1fr; }
}

/* v9.1: メインナビと小さなセカンダリリンク（TOP戻り・サイト概要）の差別化 */
.beauty-side__nav--secondary {
  margin-top: 24px !important;
  padding-top: 16px !important;
  border-top: 1px solid rgba(0,0,0,0.1);
}
.beauty-side__nav--secondary a {
  font-size: 12px !important;
  color: var(--bm-ink-soft) !important;
  padding: 8px 14px !important;
}
.beauty-side__nav--secondary a:hover {
  color: var(--bm-ink) !important;
}
/* SPドロワー内のセカンダリも小さく */
.beauty-sp-drawer .beauty-side__nav--secondary {
  border-top-color: rgba(0,0,0,0.15);
}
.beauty-sp-drawer .beauty-side__nav--secondary a {
  font-size: 13px !important;
}

/* ============================================================
   v11: 全面磨き上げ
   - 左サイドバー: 縦グラデ + 質感
   - FV: SVG blob + 立体カード + ウェーブ
   - カテゴリカード: SVGアイコン + 色分け + 装飾
   - セクション見出し: ENサブ + メイン + 装飾線
   - 最新記事: モダンカードグリッド
   - aboutCTA: 黄緑ベースの大型ブロック
   ============================================================ */

/* --- 左サイドバーを縦グラデ + 立体感に --- */
.beauty-side {
  background: linear-gradient(180deg, #d6dd5e 0%, #cbd34a 50%, #b8c038 100%) !important;
  box-shadow: 4px 0 24px rgba(168, 176, 51, 0.18);
  padding: 32px 16px !important;
}
.beauty-side__logo {
  margin-bottom: 28px !important;
  position: relative;
}
.beauty-side__logo::after {
  content: "";
  display: block;
  width: 40px;
  height: 3px;
  background: rgba(45, 42, 38, 0.25);
  border-radius: 3px;
  margin: 16px auto 0;
}
.beauty-side__nav a {
  position: relative;
  padding: 12px 16px !important;
  letter-spacing: 0.05em;
  transition: padding 0.18s ease, background 0.18s ease;
}
.beauty-side__nav a::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  width: 0; height: 2px;
  background: var(--bm-ink);
  transform: translateY(-50%);
  transition: width 0.18s ease;
}
.beauty-side__nav a:hover {
  background: rgba(255,255,255,0.45) !important;
  padding-left: 22px !important;
}
.beauty-side__nav a:hover::before {
  width: 12px;
}

/* --- 重要：絵文字を全てwp.org SVGに置換させないため、トップカードからは絵文字を除いてSVG使用 --- */

/* ============================================================
   フロントトップ (front-page.php) スタイル
   ============================================================ */
.bm-front {
  background: var(--bm-cream);
}
.bm-front-inner {
  width: 100%;
  max-width: none;
  padding: 0 !important;
}

/* ----- FV ----- */
.bm-fv {
  position: relative;
  padding: 80px 32px 120px;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(246,200,211,0.25) 0%, transparent 50%),
    radial-gradient(ellipse at 10% 80%, rgba(203,211,74,0.25) 0%, transparent 50%),
    linear-gradient(180deg, #fffdf7 0%, #faf6ea 100%);
  overflow: hidden;
}
.bm-fv__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}
.bm-fv__blob {
  position: absolute;
  width: 600px; height: 600px;
}
.bm-fv__blob--a { top: -120px; right: -120px; opacity: 0.85; }
.bm-fv__blob--b { bottom: -180px; left: -100px; opacity: 0.85; }
.bm-fv__dots {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  opacity: 0.5;
}
.bm-fv__inner {
  position: relative;
  z-index: 1;
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 56px;
  align-items: center;
}
.bm-fv__lead {
  display: inline-block;
  font-family: "Roboto", "Inter", sans-serif;
  font-size: 13px;
  letter-spacing: 0.28em;
  font-weight: 600;
  color: var(--bm-accent-dark);
  margin: 0 0 16px;
  padding: 4px 14px;
  border: 1.5px solid var(--bm-accent-dark);
  border-radius: 100px;
}
.bm-fv__catch {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 700;
  line-height: 1.4;
  color: var(--bm-ink);
  margin: 0 0 20px;
}
.bm-fv__catch em {
  font-style: normal;
  background: linear-gradient(transparent 65%, var(--bm-accent-light) 65%);
  padding: 0 6px;
}
.bm-fv__sub {
  font-size: 15px;
  line-height: 1.9;
  color: var(--bm-ink-soft);
  margin: 0 0 32px;
}
.bm-fv__ctas {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.bm-fv__visual {
  display: flex;
  justify-content: center;
}
.bm-fv__visual-card {
  position: relative;
  background: white;
  border-radius: 24px;
  padding: 32px;
  box-shadow:
    0 20px 60px rgba(168,176,51,0.18),
    0 4px 12px rgba(0,0,0,0.06);
  transform: rotate(-2deg);
  transition: transform 0.3s ease;
}
.bm-fv__visual-card:hover { transform: rotate(0deg) scale(1.02); }
.bm-fv__visual-card::before {
  content: "";
  position: absolute;
  inset: -8px;
  border: 2px dashed var(--bm-accent);
  border-radius: 28px;
  z-index: -1;
  opacity: 0.5;
}
.bm-fv__visual-card img {
  max-width: 240px;
  height: auto;
  display: block;
}
.bm-fv__wave {
  position: absolute;
  bottom: -1px;
  left: 0; right: 0;
  width: 100%;
  height: 90px;
  z-index: 2;
}

/* ----- CTAボタン全体 ----- */
.bm-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 16px 32px;
  border-radius: 100px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none !important;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  cursor: pointer;
}
.bm-cta__arrow {
  transition: transform 0.2s ease;
  font-family: "Roboto", sans-serif;
  font-size: 16px;
}
.bm-cta:hover .bm-cta__arrow { transform: translateX(4px); }
.bm-cta--primary {
  background: var(--bm-ink) !important;
  color: var(--bm-cream) !important;
  box-shadow: 0 6px 0 var(--bm-accent-dark), 0 10px 20px rgba(0,0,0,0.1);
}
.bm-cta--primary:hover { transform: translateY(3px); box-shadow: 0 3px 0 var(--bm-accent-dark), 0 5px 10px rgba(0,0,0,0.12); }
.bm-cta--ghost {
  background: transparent !important;
  color: var(--bm-ink) !important;
  border: 2px solid var(--bm-ink);
}
.bm-cta--ghost:hover { background: var(--bm-ink) !important; color: var(--bm-cream) !important; }
.bm-cta--ghost-on-accent {
  background: transparent !important;
  color: var(--bm-ink) !important;
  border: 2px solid var(--bm-ink);
}
.bm-cta--ghost-on-accent:hover { background: var(--bm-ink) !important; color: var(--bm-accent) !important; }

/* ----- セクション見出し共通 ----- */
.bm-section-h {
  text-align: center;
  margin: 0 0 48px;
}
.bm-section-h__sub {
  display: block;
  font-family: "Roboto", "Inter", sans-serif;
  font-size: 12px;
  letter-spacing: 0.32em;
  font-weight: 600;
  color: var(--bm-accent-dark);
  margin-bottom: 8px;
}
.bm-section-h__main {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(22px, 2.6vw, 32px);
  font-weight: 700;
  color: var(--bm-ink);
  margin: 0;
  position: relative;
  display: inline-block;
}
.bm-section-h__main::before,
.bm-section-h__main::after {
  content: "";
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--bm-accent);
  vertical-align: middle;
  margin: 0 16px;
}

/* ----- カテゴリ4カード ----- */
.bm-cats {
  padding: 96px 32px 80px;
  background: var(--bm-cream);
}
.bm-cats__grid {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.bm-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  padding: 32px 28px;
  background: white;
  border-radius: 20px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.04);
  text-decoration: none !important;
  color: var(--bm-ink) !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  overflow: hidden;
}
.bm-card::before {
  content: "";
  position: absolute;
  top: 0; right: 0;
  width: 100%; height: 5px;
  background: var(--bm-accent);
  transition: background 0.2s ease;
}
.bm-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(168,176,51,0.2);
}
.bm-card__icon {
  width: 64px; height: 64px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  background: var(--bm-cream-2);
  color: var(--bm-accent-dark);
}
.bm-card__icon svg { width: 36px; height: 36px; }
.bm-card--acne  .bm-card__icon { background: #fff0e0; color: #d97757; }
.bm-card--diet  .bm-card__icon { background: #e0f0e0; color: #4a9b4a; }
.bm-card--spots .bm-card__icon { background: #fff7d0; color: #c79c00; }
.bm-card--aga   .bm-card__icon { background: #e0e7ff; color: #5566cc; }
.bm-card--acne::before  { background: #d97757; }
.bm-card--diet::before  { background: #4a9b4a; }
.bm-card--spots::before { background: #c79c00; }
.bm-card--aga::before   { background: #5566cc; }
.bm-card__title {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--bm-ink);
}
.bm-card__desc {
  font-size: 13px;
  line-height: 1.7;
  color: var(--bm-ink-soft);
  margin: 0 0 16px;
  flex: 1;
}
.bm-card__more {
  font-family: "Roboto", sans-serif;
  font-size: 12px;
  letter-spacing: 0.1em;
  font-weight: 600;
  color: var(--bm-accent-dark);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.bm-card__more i { font-style: normal; transition: transform 0.2s ease; }
.bm-card:hover .bm-card__more i { transform: translateX(4px); }

/* ----- ピックアップ ----- */
.bm-pickup {
  padding: 96px 32px;
  background: linear-gradient(180deg, var(--bm-cream-2) 0%, var(--bm-cream) 100%);
}
.bm-section-h--on-cream { /* 既定と同じ */ }
.bm-pickup .bm-top-pickup__grid {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 768px) {
  .bm-pickup .bm-top-pickup__grid { grid-template-columns: 1fr; }
}
.bm-pickup .bm-top-pick {
  background: white;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,0.05);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.bm-pickup .bm-top-pick:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.08);
}
.bm-pickup .bm-top-pick img {
  height: 220px;
  width: 100%;
  object-fit: cover;
  display: block;
}
.bm-pickup .bm-top-pick__body { padding: 24px; }

/* ----- 最新記事グリッド ----- */
.bm-latest-section {
  padding: 96px 32px;
  background: var(--bm-cream);
}
.bm-latest__grid {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.bm-latest__card {
  display: flex;
  flex-direction: column;
  background: white;
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none !important;
  color: var(--bm-ink) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.bm-latest__card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.08);
}
.bm-latest__thumb {
  width: 100%;
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
  background-color: var(--bm-cream-2);
}
.bm-latest__body { padding: 20px; }
.bm-latest__tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 3px 10px;
  border-radius: 100px;
  background: var(--bm-accent);
  color: var(--bm-ink);
  margin-bottom: 10px;
}
.bm-latest__title {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.55;
  margin: 0 0 10px;
  color: var(--bm-ink);
}
.bm-latest__date {
  font-family: "Roboto", sans-serif;
  font-size: 12px;
  color: var(--bm-ink-soft);
  letter-spacing: 0.05em;
}
.bm-empty {
  text-align: center;
  color: var(--bm-ink-soft);
  padding: 60px 20px;
}

/* ----- このサイトについて CTA ----- */
.bm-about-cta {
  padding: 96px 32px;
  background:
    linear-gradient(135deg, var(--bm-accent) 0%, #b8c038 100%);
  position: relative;
  overflow: hidden;
}
.bm-about-cta::before {
  content: "";
  position: absolute;
  top: -100px; right: -100px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(255,255,255,0.2) 0%, transparent 70%);
  border-radius: 50%;
}
.bm-about-cta__inner {
  position: relative;
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.bm-about-cta__badge {
  display: inline-block;
  font-family: "Roboto", sans-serif;
  font-size: 11px;
  letter-spacing: 0.32em;
  font-weight: 700;
  padding: 4px 14px;
  background: rgba(255,255,255,0.4);
  color: var(--bm-ink);
  border-radius: 100px;
  margin-bottom: 16px;
}
.bm-about-cta__title {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 700;
  margin: 0 0 16px;
  color: var(--bm-ink);
}
.bm-about-cta__text {
  font-size: 15px;
  line-height: 1.9;
  color: var(--bm-ink);
  margin: 0 0 28px;
}

/* ============================================================
   archive / single / search / page の体験を統一
   ============================================================ */
#postHeader, .l--post-header {
  background: transparent !important;
  border: none !important;
  padding: 60px 24px 40px !important;
  position: relative !important;
}
#postHeader::after {
  content: "";
  display: block;
  width: 40px;
  height: 3px;
  background: var(--bm-accent);
  margin-top: 16px;
  border-radius: 3px;
}
#postHeaderInner {
  max-width: 880px;
  margin: 0 auto;
  text-align: left;
}
.d--archive-subtitle {
  font-family: "Roboto", sans-serif !important;
  font-size: 12px !important;
  letter-spacing: 0.32em !important;
  font-weight: 600 !important;
  color: var(--bm-accent-dark) !important;
  margin-bottom: 8px !important;
  display: block;
}
#jinrPostTitle, h1.c--entry-title {
  font-family: "Zen Maru Gothic", sans-serif !important;
  font-size: clamp(24px, 3.2vw, 36px) !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  color: var(--bm-ink) !important;
}

/* JINR 記事リストカードのトンマナ調整 */
#jinrPostList .o--postlist-inner {
  gap: 24px !important;
}
.new-post-list-item {
  background: white !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.new-post-list-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.08);
}

/* 検索ボックス共通スタイル */
#JinrSearchBox input[type="search"], 
.c--notfound-box input[type="search"] {
  border-radius: 100px !important;
  padding: 12px 20px !important;
  border: 2px solid var(--bm-accent-light) !important;
}

/* レスポンシブ調整 */
@media (max-width: 768px) {
  .bm-fv { padding: 56px 24px 90px; }
  .bm-fv__inner { grid-template-columns: 1fr; text-align: center; gap: 40px; }
  .bm-fv__visual { order: -1; }
  .bm-fv__visual-card { transform: rotate(0); padding: 24px; }
  .bm-fv__visual-card img { max-width: 180px; }
  .bm-fv__ctas { justify-content: center; }
  .bm-fv__lead { display: inline-block; }
  .bm-cats { padding: 64px 24px; }
  .bm-cats__grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .bm-card { padding: 24px 20px; }
  .bm-pickup, .bm-latest-section, .bm-about-cta { padding: 64px 24px; }
  .bm-latest__grid { grid-template-columns: 1fr; }
  .bm-section-h { margin-bottom: 32px; }
  .bm-section-h__main::before, .bm-section-h__main::after { width: 16px; margin: 0 10px; }
}

/* ============================================================
   v11.1 緊急: フロントテンプレ用コンテナをblock強制
   JIN:Rの既存flex/grid設定と衝突しないよう、フロントだけ独立化
   ============================================================ */
main.bm-front,
.bm-front {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}
.bm-front-inner,
#mainContentInner.bm-front-inner {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
/* フロント直下の各セクションは縦並び（block）で */
.bm-front > .bm-front-inner > section,
.bm-front-inner > section {
  display: block !important;
  width: 100% !important;
  flex: none !important;
}

/* ============================================================
   v13: カテゴリページ ピラー型レイアウト
   ============================================================ */
.bm-pillar {
  padding: 0;
  max-width: 100%;
}
.bm-pillar__header {
  background: linear-gradient(180deg, var(--bm-accent-light) 0%, var(--bm-cream) 100%);
  padding: 80px 32px 60px;
  text-align: center;
  border-bottom: 1px solid var(--bm-cream-2);
}
.bm-pillar__cat {
  display: inline-block;
  font-family: "Roboto", "Inter", sans-serif;
  font-size: 12px;
  letter-spacing: 0.32em;
  font-weight: 700;
  color: var(--bm-accent-dark);
  margin-bottom: 12px;
}
.bm-pillar__title {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 700;
  color: var(--bm-ink);
  margin: 0 0 16px;
  line-height: 1.3;
}
.bm-pillar__desc {
  max-width: 720px;
  margin: 0 auto;
  font-size: 15px;
  line-height: 1.9;
  color: var(--bm-ink-soft);
}
.bm-pillar__content {
  max-width: 880px;
  margin: 0 auto;
  padding: 64px 32px;
  font-size: 16px;
  line-height: 1.95;
  color: var(--bm-ink);
}
.bm-pillar__content h2 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(22px, 2.6vw, 28px);
  font-weight: 700;
  color: var(--bm-ink);
  margin: 56px 0 20px;
  padding: 14px 20px;
  background: var(--bm-cream-2);
  border-left: 6px solid var(--bm-accent);
  border-radius: 0 12px 12px 0;
}
.bm-pillar__content h3 {
  font-size: 18px;
  font-weight: 700;
  margin: 36px 0 16px;
  padding-bottom: 8px;
  border-bottom: 2px dashed var(--bm-accent);
}
.bm-pillar__content h4 {
  font-size: 15px;
  font-weight: 700;
  margin: 24px 0 12px;
  color: var(--bm-accent-dark);
}
.bm-pillar__content p { margin: 0 0 20px; }
.bm-pillar__content ul, .bm-pillar__content ol { margin: 0 0 24px; padding-left: 1.4em; }
.bm-pillar__content li { margin-bottom: 10px; }
.bm-pillar__content table { width: 100%; border-collapse: collapse; margin: 24px 0; font-size: 14px; }
.bm-pillar__content table th { background: var(--bm-accent); color: var(--bm-ink); padding: 12px; text-align: left; }
.bm-pillar__content table td { padding: 12px; border-bottom: 1px solid var(--bm-cream-2); }
.bm-pillar__content blockquote {
  background: var(--bm-cream-2);
  border-left: 4px solid var(--bm-accent);
  padding: 16px 20px;
  margin: 24px 0;
  font-size: 14px;
  color: var(--bm-ink-soft);
}
.bm-pillar__posts {
  background: var(--bm-cream-2);
  padding: 80px 32px;
}
.bm-pillar__posts .bm-latest__grid {
  max-width: 1080px;
  margin: 0 auto;
}

/* ============================================================
   v14: FVロゴの白カード撤去＋ふんわり浮遊アニメーション
   ============================================================ */
/* 白背景・回転・枠線をリセット */
.bm-fv__visual-card {
  background: none !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
  transform: none !important;
}
.bm-fv__visual-card::before { display: none !important; }

.bm-fv__visual-card img {
  max-width: 320px !important;
  animation: bm-logo-float 5s ease-in-out infinite;
  /* 黄緑のドロップシャドウで浮遊感、ロゴ透過部分には影が落ちない */
  filter: drop-shadow(0 16px 28px rgba(168, 176, 51, 0.3))
          drop-shadow(0 4px 8px rgba(0, 0, 0, 0.06));
  will-change: transform;
}

@keyframes bm-logo-float {
  0%, 100% {
    transform: translateY(0) scale(1) rotate(0deg);
  }
  33% {
    transform: translateY(-10px) scale(1.03) rotate(-1deg);
  }
  66% {
    transform: translateY(-6px) scale(1.05) rotate(1deg);
  }
}

/* 後ろに薄い円形のグロー（オプション的な装飾） */
.bm-fv__visual {
  position: relative;
}
.bm-fv__visual::before {
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  width: 360px; height: 360px;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(203, 211, 74, 0.25) 0%, transparent 65%);
  border-radius: 50%;
  z-index: -1;
  animation: bm-glow-pulse 4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes bm-glow-pulse {
  0%, 100% { opacity: 0.6; transform: translate(-50%, -50%) scale(1); }
  50% { opacity: 1; transform: translate(-50%, -50%) scale(1.1); }
}

/* SP では浮遊弱め、グローも小さく */
@media (max-width: 768px) {
  .bm-fv__visual-card img { max-width: 220px !important; }
  .bm-fv__visual::before { width: 260px; height: 260px; }
  @keyframes bm-logo-float {
    0%, 100% { transform: translateY(0) scale(1); }
    50% { transform: translateY(-6px) scale(1.03); }
  }
}

/* モーション抑制を選んでるユーザーには配慮 */
@media (prefers-reduced-motion: reduce) {
  .bm-fv__visual-card img,
  .bm-fv__visual::before {
    animation: none !important;
  }
}

/* ============================================================
   v15: 固定ページ/シングル記事の本文装飾を統一
   .bm-pillar__content と #postContent の両方に同じ装飾を効かせる
   JIN:R の `#postContent` は single.php / page.php 共通のラッパー
   ============================================================ */
#postContent h2,
.bm-pillar__content h2,
.entry-content h2,
.bm-pillar__content > h2 {
  font-family: "Zen Maru Gothic", sans-serif !important;
  font-size: clamp(22px, 2.6vw, 28px) !important;
  font-weight: 700 !important;
  color: var(--bm-ink) !important;
  margin: 56px 0 20px !important;
  padding: 14px 18px 14px 22px !important;
  background: var(--bm-cream-2) !important;
  border-left: 6px solid var(--bm-accent) !important;
  border-radius: 0 12px 12px 0 !important;
  line-height: 1.5 !important;
}
#postContent h3,
.bm-pillar__content h3,
.entry-content h3 {
  font-size: 18px !important;
  font-weight: 700 !important;
  margin: 36px 0 16px !important;
  padding: 0 0 8px !important;
  border-bottom: 2px dashed var(--bm-accent) !important;
  color: var(--bm-ink) !important;
  background: transparent !important;
}
#postContent h4,
.bm-pillar__content h4,
.entry-content h4 {
  font-size: 15px !important;
  font-weight: 700 !important;
  margin: 24px 0 12px !important;
  color: var(--bm-accent-dark) !important;
  padding-left: 12px !important;
  border-left: 3px solid var(--bm-accent) !important;
}
#postContent p,
.bm-pillar__content p,
.entry-content p {
  margin: 0 0 20px;
  line-height: 1.95;
  font-size: 16px;
  color: var(--bm-ink);
}

/* リスト系 */
#postContent ul,
#postContent ol,
.bm-pillar__content ul,
.bm-pillar__content ol,
.entry-content ul,
.entry-content ol {
  margin: 0 0 24px;
  padding-left: 1.6em;
  line-height: 1.9;
}
#postContent ul li,
.bm-pillar__content ul li,
.entry-content ul li {
  list-style: none;
  position: relative;
  margin-bottom: 12px;
  padding-left: 8px;
}
#postContent ul li::before,
.bm-pillar__content ul li::before,
.entry-content ul li::before {
  content: "";
  position: absolute;
  left: -18px;
  top: 0.8em;
  width: 8px;
  height: 8px;
  background: var(--bm-accent);
  border-radius: 50%;
}
#postContent ol,
.bm-pillar__content ol,
.entry-content ol {
  counter-reset: bm-ol;
  padding-left: 0;
}
#postContent ol li,
.bm-pillar__content ol li,
.entry-content ol li {
  list-style: none;
  position: relative;
  margin-bottom: 14px;
  padding-left: 40px;
  counter-increment: bm-ol;
}
#postContent ol li::before,
.bm-pillar__content ol li::before,
.entry-content ol li::before {
  content: counter(bm-ol);
  position: absolute;
  left: 0;
  top: 0.05em;
  width: 28px;
  height: 28px;
  line-height: 28px;
  background: var(--bm-accent);
  color: var(--bm-ink);
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-size: 13px;
  text-align: center;
  border-radius: 50%;
}

/* テーブル */
#postContent table,
.bm-pillar__content table,
.entry-content table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin: 24px 0 !important;
  font-size: 14px !important;
  background: white !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04) !important;
}
#postContent table th,
.bm-pillar__content table th,
.entry-content table th {
  background: var(--bm-accent) !important;
  color: var(--bm-ink) !important;
  padding: 14px 16px !important;
  text-align: left !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  border: none !important;
}
#postContent table td,
.bm-pillar__content table td,
.entry-content table td {
  padding: 14px 16px !important;
  border-bottom: 1px solid var(--bm-cream-2) !important;
  background: white !important;
  color: var(--bm-ink) !important;
}
#postContent table tr:nth-child(even) td,
.bm-pillar__content table tr:nth-child(even) td,
.entry-content table tr:nth-child(even) td {
  background: #fcfaf3 !important;
}
#postContent table tr:last-child td,
.bm-pillar__content table tr:last-child td,
.entry-content table tr:last-child td {
  border-bottom: none !important;
}

/* blockquote */
#postContent blockquote,
.bm-pillar__content blockquote,
.entry-content blockquote {
  background: var(--bm-cream-2) !important;
  border-left: 4px solid var(--bm-accent) !important;
  padding: 18px 24px !important;
  margin: 24px 0 !important;
  font-size: 14px !important;
  color: var(--bm-ink-soft) !important;
  border-radius: 0 8px 8px 0 !important;
  font-style: normal !important;
}
#postContent blockquote p:last-child,
.bm-pillar__content blockquote p:last-child,
.entry-content blockquote p:last-child { margin-bottom: 0; }

/* インラインstrong/em */
#postContent strong,
.bm-pillar__content strong,
.entry-content strong {
  background: linear-gradient(transparent 62%, var(--bm-accent-light) 62%);
  padding: 0 3px;
  font-weight: 700;
}
#postContent em,
.bm-pillar__content em,
.entry-content em {
  font-style: italic;
  color: var(--bm-accent-dark);
}

/* 記事本文の段落リンク */
#postContent a:not(.bm-cta):not(.bm-card),
.bm-pillar__content a,
.entry-content a {
  color: var(--bm-accent-dark);
  text-decoration: underline;
  text-decoration-color: var(--bm-accent);
  text-underline-offset: 3px;
}
#postContent a:hover,
.bm-pillar__content a:hover,
.entry-content a:hover {
  color: var(--bm-ink);
}

/* 固定ページのコンテナをきれいに */
.page #postContent,
body.page #postContent {
  max-width: 880px;
  margin: 0 auto;
  padding: 40px 24px 80px;
}

/* ============================================================
   v16: AIっぽい上端カラー帯を撤回＋本文をダイナミックに
   ============================================================ */

/* === 4カード上端の色付き帯を完全撤回 === */
.bm-card::before {
  display: none !important;
}
.bm-card--acne::before,
.bm-card--diet::before,
.bm-card--spots::before,
.bm-card--aga::before {
  display: none !important;
}

/* 代替：ホバー時に下から黄緑のラインが伸びる、より「物作りっぽい」サブトル動き */
.bm-card {
  position: relative;
  overflow: hidden;
}
.bm-card::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0;
  width: 0; height: 3px;
  background: var(--bm-accent);
  transition: width 0.35s ease;
}
.bm-card:hover::after {
  width: 100%;
}
/* アイコン背景の色分けは残す（カード自身のカラー帯ではなく、アイコン領域のみ） */

/* === 本文を両端までダイナミックに ===
   - max-widthを拡張、SPは詰める
   - h2をフルブリード（画面端まで届く帯）に
   - blockquote/table も画面の広さを使う */

.bm-pillar__content,
.page #postContent,
body.page #postContent {
  max-width: 1080px !important;
  padding: 64px clamp(20px, 4vw, 56px) 80px !important;
  margin: 0 auto !important;
  overflow-x: visible;
}

/* h2 を画面端まで届くフルブリード帯にする
   ※ ピラーcontentの場合のみフルブリード、ノーマル記事は通常通り */
.bm-pillar__content h2,
.page #postContent h2 {
  position: relative;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding: 22px clamp(20px, max(calc(50vw - 540px + 20px), 4vw), calc(50vw - 540px + 20px)) !important;
  border-radius: 0 !important;
  background: linear-gradient(90deg, var(--bm-cream-2) 0%, var(--bm-cream) 100%) !important;
  border-left: none !important;
  border-bottom: 2px solid var(--bm-accent) !important;
}
.bm-pillar__content h2::before,
.page #postContent h2::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 24px;
  background: var(--bm-accent);
  margin-right: 14px;
  vertical-align: middle;
  border-radius: 3px;
}

/* h2に左サイドバー分のオフセット（PCのみ） */
@media (min-width: 992px) {
  .bm-pillar__content h2,
  .page #postContent h2 {
    margin-left: calc(50% - 50vw + var(--bm-side-w) / 2) !important;
    padding-left: max(calc(50vw - 540px - var(--bm-side-w)/2 + 20px), 4vw) !important;
  }
}

/* PC左サイドバーがあるとき、本文を画面中央ではなくサイドバー除外の中央に置く */
@media (min-width: 992px) {
  .bm-pillar__content,
  .page #postContent {
    /* body の padding-left:200px は既存のままなので、コンテンツは自然と右側中央 */
    margin: 0 auto !important;
  }
}

/* tableを画面端付近まで広く使う + 横スクロールでスマホ対応 */
.bm-pillar__content table,
.page #postContent table,
#postContent table {
  display: block !important;
  width: 100% !important;
  overflow-x: auto !important;
  white-space: normal;
  -webkit-overflow-scrolling: touch;
}
.bm-pillar__content table thead,
.bm-pillar__content table tbody,
.page #postContent table thead,
.page #postContent table tbody { display: table; width: 100%; }
.bm-pillar__content table th,
.bm-pillar__content table td {
  min-width: 120px;
}

/* blockquote をやや左右に張り出させる */
.bm-pillar__content blockquote,
.page #postContent blockquote {
  margin-left: -20px !important;
  margin-right: -20px !important;
  padding: 22px 28px !important;
  font-size: 15px !important;
}

/* SP: h2のフルブリードは詰める（padding狭め） */
@media (max-width: 768px) {
  .bm-pillar__content,
  .page #postContent {
    padding: 40px 16px 64px !important;
  }
  .bm-pillar__content h2,
  .page #postContent h2 {
    margin-left: -16px !important;
    margin-right: -16px !important;
    padding: 18px 16px !important;
  }
  .bm-pillar__content blockquote,
  .page #postContent blockquote {
    margin-left: -8px !important;
    margin-right: -8px !important;
  }
}

/* ピラーheaderの幅もダイナミックに */
.bm-pillar__header {
  padding: 96px clamp(20px, 4vw, 56px) 72px !important;
}
.bm-pillar__title { font-size: clamp(28px, 5vw, 52px) !important; }
.bm-pillar__desc { max-width: 760px !important; }

/* ============================================================
   v17: PCのh2フルブリードを控えめに、SPテーブルを正規化
   ============================================================ */

/* === h2 フルブリード演出を撤回 → カード型に戻す === */
.bm-pillar__content h2,
.page #postContent h2,
#postContent h2,
.entry-content h2 {
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-top: 56px !important;
  margin-bottom: 20px !important;
  padding: 18px 24px !important;
  background: var(--bm-cream-2) !important;
  border-left: 6px solid var(--bm-accent) !important;
  border-bottom: none !important;
  border-radius: 0 12px 12px 0 !important;
}
.bm-pillar__content h2::before,
.page #postContent h2::before,
#postContent h2::before {
  display: none !important;
}

/* リード文の色を濃く（p:first-of-typeを強調） */
.bm-pillar__content p:first-of-type,
.page #postContent p:first-of-type {
  font-size: 17px !important;
  line-height: 1.95 !important;
  color: var(--bm-ink) !important;
  margin-bottom: 32px !important;
}

/* === SP テーブルを正規化（横スクロール禁止、お行儀良く） === */
@media (max-width: 768px) {
  .bm-pillar__content table,
  .page #postContent table,
  #postContent table,
  .entry-content table {
    display: table !important;
    width: 100% !important;
    overflow: visible !important;
    font-size: 12px !important;
    box-shadow: none !important;
    border-radius: 8px !important;
  }
  .bm-pillar__content table thead,
  .bm-pillar__content table tbody,
  .page #postContent table thead,
  .page #postContent table tbody {
    display: table-row-group !important;
    width: auto !important;
  }
  .bm-pillar__content table th,
  .bm-pillar__content table td,
  .page #postContent table th,
  .page #postContent table td,
  #postContent table th,
  #postContent table td {
    min-width: 0 !important;
    padding: 8px 8px !important;
    font-size: 12px !important;
    line-height: 1.55 !important;
    word-break: break-word !important;
  }
  .bm-pillar__content table th,
  .page #postContent table th {
    font-size: 12px !important;
    padding: 10px 8px !important;
  }
  /* SPでは偶数行ゼブラの代わりにシンプルな下罫線だけにする */
  .bm-pillar__content table tr:nth-child(even) td,
  .page #postContent table tr:nth-child(even) td {
    background: white !important;
  }
  /* SP本文paddingさらに詰める */
  .bm-pillar__content,
  .page #postContent {
    padding: 32px 16px 56px !important;
  }
  /* h2のSPでのpadding微調整 */
  .bm-pillar__content h2,
  .page #postContent h2 {
    padding: 14px 16px !important;
    font-size: 18px !important;
    margin-top: 40px !important;
  }
}

/* SP/PC共通：blockquoteのはみ出しも撤回（負margin削除） */
.bm-pillar__content blockquote,
.page #postContent blockquote,
#postContent blockquote,
.entry-content blockquote {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* === PC側でテーブルが画面外に流れないよう、コンテナを画面内に確実に収める === */
.bm-pillar__content,
.page #postContent,
body.page #postContent {
  overflow-x: hidden !important;
}

/* ============================================================
   v18: コンテンツをコンテナごとフル幅化
   PC: コンテナ max-width撤廃、内部要素別に幅制御（h2/table広め、p狭め）
   SP: ぜんぶフル幅、左右padding最小化
   ============================================================ */

.bm-pillar__content,
.page #postContent,
body.page #postContent {
  max-width: none !important;
  width: 100% !important;
  padding: 56px clamp(16px, 4vw, 48px) 80px !important;
  margin: 0 !important;
  overflow-x: hidden !important;
}

/* PC：内部要素別の幅制御 */
@media (min-width: 769px) {
  /* デフォルトは中央寄せ＋読みやすい幅 */
  .bm-pillar__content > *,
  .page #postContent > *,
  body.page #postContent > * {
    max-width: 880px;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  /* h2/h3/blockquote/table は広め、画面の存在感を出す */
  .bm-pillar__content > h2,
  .page #postContent > h2,
  body.page #postContent > h2 {
    max-width: 1180px;
    padding: 22px 28px !important;
    font-size: clamp(22px, 2.4vw, 30px) !important;
  }
  .bm-pillar__content > h3,
  .page #postContent > h3,
  body.page #postContent > h3 {
    max-width: 980px;
  }
  .bm-pillar__content > table,
  .page #postContent > table,
  body.page #postContent > table {
    max-width: 1180px;
    font-size: 15px !important;
  }
  .bm-pillar__content > table th,
  .bm-pillar__content > table td,
  .page #postContent > table th,
  .page #postContent > table td {
    padding: 16px 20px !important;
  }
  .bm-pillar__content > blockquote,
  .page #postContent > blockquote,
  body.page #postContent > blockquote {
    max-width: 980px;
    padding: 24px 32px !important;
  }
  /* p/ul/ol は読みやすい幅で中央寄せ */
  .bm-pillar__content > p,
  .bm-pillar__content > ul,
  .bm-pillar__content > ol,
  .page #postContent > p,
  .page #postContent > ul,
  .page #postContent > ol {
    max-width: 880px;
  }
}

/* SP：全要素100%幅、左右padding最小 */
@media (max-width: 768px) {
  .bm-pillar__content,
  .page #postContent,
  body.page #postContent {
    padding: 32px 14px 48px !important;
  }
  .bm-pillar__content > *,
  .page #postContent > *,
  body.page #postContent > * {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  /* h2のSPは「画面端まで届く帯」感を再導入（負margin で padding突き抜け） */
  .bm-pillar__content > h2,
  .page #postContent > h2,
  body.page #postContent > h2 {
    margin-left: -14px !important;
    margin-right: -14px !important;
    padding: 16px 20px !important;
    border-radius: 0 12px 12px 0 !important;
    font-size: 18px !important;
  }
  /* SPテーブルも端まで */
  .bm-pillar__content > table,
  .page #postContent > table,
  body.page #postContent > table {
    margin-left: -8px !important;
    margin-right: -8px !important;
    width: calc(100% + 16px) !important;
    max-width: calc(100% + 16px) !important;
  }
}

/* PC左サイドバー使用時の中央オフセット
   body { padding-left: 200px } により、コンテンツの中心は (200 + (画面-200)/2)
   要素のmargin: 0 auto がこの中で動くので、自然に中央寄せされる */

/* 念のため画像も拡張可に */
.bm-pillar__content img,
.page #postContent img,
body.page #postContent img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* ============================================================
   v18.1: JIN:R の .t--main-width (max-width:1120px) を解除
   親要素が絞ってると、内部要素の max-width 1180px 等が効かない
   ============================================================ */
/* カテゴリ：ピラー含むmainContentInnerは制限解除 */
.t--main-width:has(.bm-pillar),
#mainContentInner.t--main-width:has(.bm-pillar) {
  max-width: none !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
/* 固定ページ：制限解除 */
body.page .t--main-width,
body.page #mainContentInner.t--main-width {
  max-width: none !important;
  width: 100% !important;
}
/* :has 未対応ブラウザのフォールバック：固定ページとカテゴリを直接指定 */
body.category #mainContent,
body.page #mainContent {
  /* mainContentもwidth制約をなくす */
}
body.category #mainContent #mainContentInner,
body.page #mainContent #mainContentInner {
  max-width: none !important;
  width: 100% !important;
}

/* ピラー自身も全幅 */
.bm-pillar {
  width: 100% !important;
  max-width: none !important;
}
.bm-pillar__content {
  width: 100% !important;
  box-sizing: border-box;
}

/* ============================================================
   v18.2: :has()フォールバック - body class で確実に解除
   ============================================================ */
body.category #mainContentInner.t--main-width,
body.category .t--main-width,
body.page #mainContentInner.t--main-width,
body.page .t--main-width,
body.single #mainContentInner.t--main-width {
  max-width: none !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* mainContent側も解放 */
body.category #mainContent,
body.page #mainContent,
body.single #mainContent {
  max-width: none !important;
  width: 100% !important;
}

/* JIN:Rの jinrArticle が幅制限してたら解除 */
body.category #jinrArticle,
body.page #jinrArticle {
  max-width: none !important;
  width: 100% !important;
}

/* ============================================================
   v19: 要素別 max-width バラバラを廃止、コンテナ単位で統一
   コンテナ：max-width: 1100px 中央寄せ
   内部要素：すべてコンテナの幅をそのまま使う（max-width: none）
   ============================================================ */

/* ピラー（カテゴリ）/ 固定ページ / シングル記事 で共通 */
.bm-pillar__content,
.page #postContent,
body.page #postContent,
.single #postContent,
body.single #postContent {
  max-width: 1100px !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 48px clamp(16px, 3vw, 36px) 80px !important;
  box-sizing: border-box !important;
}

/* 内部要素はもう個別 max-width を持たない（すべてコンテナ幅 100%） */
.bm-pillar__content > *,
.page #postContent > *,
.single #postContent > * {
  max-width: 100% !important;
  width: auto !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* PC: 視覚的な揃いを優先、左右ともに均等な余白 */
@media (min-width: 769px) {
  .bm-pillar__content,
  .page #postContent,
  .single #postContent {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
}

/* SP: 上の余白を削減、padding 12px */
@media (max-width: 768px) {
  .bm-pillar__content,
  .page #postContent,
  .single #postContent {
    padding: 28px 14px 48px !important;
  }
  /* SPでもh2/tableは画面端まで負marginで突き抜け */
  .bm-pillar__content > h2,
  .page #postContent > h2,
  .single #postContent > h2 {
    margin-left: -14px !important;
    margin-right: -14px !important;
  }
  .bm-pillar__content > table,
  .page #postContent > table,
  .single #postContent > table {
    margin-left: -8px !important;
    margin-right: -8px !important;
    width: calc(100% + 16px) !important;
  }
}

/* ピラー上の白あまりを撤廃 */
.bm-pillar { margin-top: 0 !important; padding-top: 0 !important; }
.bm-pillar__header { margin-top: 0 !important; padding-top: 64px !important; }
body.category #mainContent,
body.page #mainContent,
body.single #mainContent {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* JIN:Rのシングル記事ヘッダ(postHeader)も上余白を抑える */
body.single #postHeader {
  padding-top: 32px !important;
  margin-top: 0 !important;
}

/* シングル記事の本文と同じ幅にpostHeaderも合わせる */
body.single #postHeader,
body.page #postHeader {
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding-left: 40px !important;
  padding-right: 40px !important;
}
@media (max-width: 768px) {
  body.single #postHeader,
  body.page #postHeader {
    padding-left: 14px !important;
    padding-right: 14px !important;
    padding-top: 20px !important;
  }
}

/* ============================================================
   v19.1: PC幅で右側の余りを最小化、画面ほぼ全幅活用
   1100px → 1240px に拡張、padding 40px → 20px
   ============================================================ */
@media (min-width: 992px) {
  .bm-pillar__content,
  .page #postContent,
  body.page #postContent,
  body.single #postContent {
    max-width: 1260px !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
  body.single #postHeader,
  body.page #postHeader {
    max-width: 1260px !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
}

/* 1440px以上のフルワイドでさらに広げる */
@media (min-width: 1440px) {
  .bm-pillar__content,
  .page #postContent,
  body.single #postContent {
    max-width: calc(100vw - 280px) !important;  /* サイドバー200 + 余白80 */
    padding-left: 32px !important;
    padding-right: 32px !important;
  }
}

/* ============================================================
   v20: 白い線の正体（#mainContentInner padding-top: 45px）を撤廃
        ＋ シングル記事 #postHeader をピラー風グラデに統一
   ============================================================ */

/* 白い線対策：mainContentInnerの上余白を消す */
body.category #mainContentInner,
body.page #mainContentInner,
body.single #mainContentInner {
  padding-top: 0 !important;
}

/* シングル記事のpostHeaderをピラーheaderと同じグラデーション・中央寄せに */
body.single #postHeader,
body.page #postHeader {
  background: linear-gradient(180deg, var(--bm-accent-light) 0%, var(--bm-cream) 100%) !important;
  padding: 96px clamp(20px, 4vw, 56px) 72px !important;
  text-align: center !important;
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--bm-cream-2) !important;
}
body.single #postHeader::after,
body.page #postHeader::after {
  display: none !important;
}
body.single #postHeaderInner,
body.page #postHeaderInner {
  max-width: 880px !important;
  margin: 0 auto !important;
  text-align: center !important;
  padding: 0 !important;
}
body.single #jinrPostMeta {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 16px !important;
  margin-bottom: 16px !important;
  flex-wrap: wrap;
}
body.single #jinrPostMeta .c--jinr-post-date,
body.single #jinrPostMeta .a--post-cat {
  font-family: "Roboto", sans-serif !important;
  font-size: 12px !important;
  letter-spacing: 0.1em !important;
  color: var(--bm-ink-soft) !important;
}
body.single #jinrPostMeta .a--post-cat a,
body.single #jinrPostMeta a {
  color: var(--bm-accent-dark) !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}
body.single #jinrPostMeta .c--jinr-post-date i,
body.single #jinrPostMeta .a--post-cat i {
  margin-right: 4px !important;
  font-size: 12px !important;
}
body.single #jinrPostTitle,
body.single h1.c--entry-title,
body.page #jinrPostTitle,
body.page h1.c--entry-title {
  font-family: "Zen Maru Gothic", sans-serif !important;
  font-size: clamp(24px, 3.4vw, 40px) !important;
  font-weight: 700 !important;
  text-align: center !important;
  line-height: 1.5 !important;
  color: var(--bm-ink) !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
}

/* SP調整 */
@media (max-width: 768px) {
  body.single #postHeader,
  body.page #postHeader {
    padding: 60px 20px 48px !important;
  }
  body.single #jinrPostMeta {
    gap: 8px !important;
    font-size: 11px !important;
  }
}

/* postContentがheaderと密着しすぎないように上余白 */
body.single #postContent,
body.page #postContent {
  padding-top: 56px !important;
}
@media (max-width: 768px) {
  body.single #postContent,
  body.page #postContent {
    padding-top: 36px !important;
  }
}

/* ============================================================
   v21: まつげ治療(のびくり)訴求セクション
   ============================================================ */
.bm-eyelash {
  background:
    radial-gradient(ellipse at 90% 10%, rgba(246, 200, 211, 0.25) 0%, transparent 50%),
    linear-gradient(180deg, var(--bm-cream) 0%, #faf3e8 100%);
  padding: 96px 32px;
  position: relative;
  overflow: hidden;
}
.bm-eyelash::before {
  content: "";
  position: absolute;
  bottom: -120px; left: -60px;
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(203, 211, 74, 0.18) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.bm-eyelash__inner {
  position: relative;
  z-index: 1;
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 48px;
  align-items: center;
}
.bm-eyelash__text {
  /* テキスト側 */
}
.bm-eyelash__badge {
  display: inline-block;
  padding: 4px 14px;
  background: rgba(45, 42, 38, 0.85);
  color: var(--bm-accent);
  border-radius: 100px;
  font-family: "Roboto", "Inter", sans-serif;
  font-size: 11px;
  letter-spacing: 0.32em;
  font-weight: 700;
  margin-bottom: 16px;
}
.bm-eyelash__title {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 700;
  color: var(--bm-ink);
  line-height: 1.45;
  margin: 0 0 16px;
}
.bm-eyelash__desc {
  font-size: 15px;
  line-height: 1.95;
  color: var(--bm-ink-soft);
  margin: 0 0 28px;
}
.bm-eyelash__ctas {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.bm-eyelash__visual {
  color: var(--bm-ink);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.bm-eyelash__visual svg {
  width: 100%;
  max-width: 280px;
  height: auto;
  filter: drop-shadow(0 12px 24px rgba(168, 176, 51, 0.2));
}

@media (max-width: 768px) {
  .bm-eyelash { padding: 64px 24px; }
  .bm-eyelash__inner {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 32px;
  }
  .bm-eyelash__visual { order: -1; }
  .bm-eyelash__visual svg { max-width: 200px; }
  .bm-eyelash__ctas { justify-content: center; }
}

/* ============================================================
   v21.1: 左サイドナビに「まつ育」(外部リンク)追加用スタイル
   ============================================================ */
.beauty-nav-ext a {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
}
.beauty-nav-ext-arrow {
  font-family: "Roboto", sans-serif;
  font-size: 11px;
  opacity: 0.6;
  margin-left: 6px;
  transition: opacity 0.18s ease, transform 0.18s ease;
}
.beauty-nav-ext a:hover .beauty-nav-ext-arrow {
  opacity: 1;
  transform: translate(2px, -2px);
}
/* まつ育は他のカテゴリと視覚的に区別するため、下に細い区切り線 */
.beauty-nav-ext {
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px dashed rgba(0,0,0,0.15);
}
