@charset "UTF-8";
/*
Theme Name: Political-General-Purpose
Author: 合同会社千駄谷企画制作所
Version: 3
Description: 政治家や政治団体向けの汎用テーマです。
*/


/* ==========================================================================
   1. BASE STYLES (style.css)
   ========================================================================== */

/* ----- 印刷時の調整 ----- */
 @media print{
	.archive-header,.entry-header { margin-top: 4em; }
	}

/* ----- スキップリンク -------------------- */
/* .screen-reader-text は SR 用の汎用「視覚的非表示」ユーティリティ。
   フォーム label などで使われ、Tab フォーカスは想定しない */
.screen-reader-text { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
/* スキップリンク：position:fixed で常に viewport に固定し、
   非フォーカス時は top:-100px で画面外に退避。:focus で top:0 に移動して表示。
   position の型を変えない方式により Firefox / Chrome / Safari で安定動作。 */
.skip-link {
	position: fixed; top: -100px; left: 0;
	padding: 8px; white-space: nowrap;
	background: var(--color-black); color: var(--color-white);
	text-decoration: none;
	z-index: 9999;
}
.skip-link:focus {
	top: 0;
}

/* ************************************************************
全体レイアウト
************************************************************ */

body { 
	font-feature-settings: "palt";
	font-family: var(--font-base);
	font-size: 1.1em; letter-spacing: .04em; font-weight: 400; line-height: 1.6; -webkit-text-size-adjust: 100%;
	color: var(--color-text); background-color: var(--color-bg);
	height: 100%; margin: 0;
	overflow-x: hidden;
	/* scroll-behavior: smooth;
	scroll-padding-top: 80px; /* ヘッダーの高さ分設定 */
	}

body * { box-sizing: border-box; }
section { position: relative; }
.site-content { width:100%; }
.wrapper { width: 90%; max-width: 1120px; margin-left: auto; margin-right: auto; }

img { image-rendering: -webkit-optimize-contrast; }
/* text-wrap: balance は日本語の禁則処理と競合するため使用しない */

/* ----- アンカーリンクスクロール時の位置を調整 ----- */

.anchor-offset { position: absolute; height: 1px; top: 0; visibility: hidden; }
h2>span, h3>span, h4>span { padding-top: 80px; margin-top: -80px; } /* TOC+用設定 */
.join-content h2>span, .join-content h3>span, .join-content h4>span { padding-top: 0px; margin-top: 0px; }

/* ----- PCで電話のクリック・タッチイベントを無効化 ----- */

@media (min-width: 769px){ a[href^="tel:"] { pointer-events: none; }}

/* ----- パンくず ----- */

.breadcrumbs { padding-top: 0; font-size: .9em; line-height: 1.4em; }

/* ************************************************************
リンク
************************************************************ */

a { color:var(--color-primary); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: .25em; text-decoration-thickness: 2px; cursor: pointer; }
u { text-underline-offset: .25em; text-decoration-thickness: 2px; }
/* 包括的な「リンク画像をホバーで半透過」ルールは廃止。
   ホバー演出は対象要素ごとに個別に定義する */

/* ----- 画像ホバー時にボーダーを表示しない ----- */
.header-ttl a img:hover, 
.slick-slider-container a img:hover, 
.account-list-item a img:hover,
.member-account-list-item a img:hover,
.header-party-logo-tagline a img:hover,
.mark-party-logo a img:hover
	{ border:none; }

/* ----- 外部リンクアイコン ----- */
a[target="_blank"]::after { padding-left: .2em; padding-right: 0.2em; content: "\f08b" / ""; 
	font-family: "Font Awesome 5 Free"; color: var(--color-primary); font-weight: 900;
}

/* ----- 外部リンクアイコンを表示しない ----- */
.slick-slider-container a[target="_blank"]::after,
.banner-card-container a[target="_blank"]::after,
.account-list-item a[target="_blank"]::after,
.top-timeline a[target="_blank"]::after,
.member-account-list-item a[target="_blank"]::after,
.card-img a[target="_blank"]::after,
.card-text a[target="_blank"]::after,
.feed-blog-meta a[target="_blank"]::after,
/* .feed-post-title a[target="_blank"]::after, */
.wp-block-file a[target="_blank"]::after,
.header-party-logo-tagline a[target="_blank"]::after,
.bigbanner a[target="_blank"]::after,
.banner-dpfp-policy a[target="_blank"]::after,
.section-head .section-exp a[target="_blank"]::after,
.video-slide__item a[target="_blank"]::after,
.podcast-player__transcript[target="_blank"]::after
{ content: none; }

/* ************************************************************
大きなバナー
************************************************************ */

.bigbanner { margin-top: 30px; margin-bottom: 30px; }
.bigbanner img { width: 100%; }
@media (max-width: 768px){
.bigbanner { margin-top: 30px; margin-bottom: 30px; }
}

/* ************************************************************
ボタン
************************************************************ */

.more a,
.return a,
.wp-block-button a,
.wp-block-button .wp-block-button__link,
.page-index-btn a,
.page-index-btn2 a,
.page-index-btn span,
.default-all,
button, input[type="submit"], input[type="reset"], input[type="button"] {
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	width: 100%; padding: .5em; font-size: 1em; font-weight: 700; text-align: center;
	text-decoration: none !important; box-sizing: border-box;
	transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease, transform 0.1s ease;
	border-radius: 0 !important;
}

/* --- アクティブ（押下感）：少し沈み込む --- */
/* slick の矢印は独自 transform（translate(0,-50%)）で中央寄せしているため除外。
   transform が上書きされるとボタン位置がジャンプし、mousedown と mouseup が
   別位置になってクリックが成立しない不具合になる */
.more a:active,
.return a:active,
.wp-block-button a:active,
.page-index-btn a:active,
.page-index-btn2 a:active,
.spread-btn-card-container a:active,
button:not(.slick-arrow):not(.header-handle):not(.drawer__button):not(.lightbox-nav):not(.podcast-player__rate):active, input[type="submit"]:active, input[type="reset"]:active, input[type="button"]:active {
	transform: translateY(2px);
}

/* --- フォーカス可視化のベースライン（全要素）---
   キーボード操作（:focus-visible）時のみリングを表示。個別ルールが無い汎用リンク・
   ナビ・カード等もここで必ず可視化され、Tab 移動でフォーカス位置を見失わない。
   マウス操作時は表示されない。個別ルール（下記）はより詳細度が高く優先される。 */
:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

/* --- フォーカス可視化（キーボード操作）：白+紺の二重リング --- */
.more a:focus-visible,
.return a:focus-visible,
.wp-block-button a:focus-visible,
.page-index-btn a:focus-visible,
.page-index-btn2 a:focus-visible,
button:focus-visible, input[type="submit"]:focus-visible, input[type="reset"]:focus-visible, input[type="button"]:focus-visible {
	outline: 3px solid var(--color-primary);
	outline-offset: 2px;
	box-shadow: 0 0 0 2px var(--color-white);
}

/* --- フォーカス可視化（キーボード操作）：フォーム入力要素 --- */
input[type="text"]:focus-visible,
input[type="email"]:focus-visible,
input[type="tel"]:focus-visible,
input[type="url"]:focus-visible,
input[type="number"]:focus-visible,
input[type="password"]:focus-visible,
input[type="search"]:focus-visible,
textarea:focus-visible,
select:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 1px;
}

/* 既定：紺ベタ・文字白 */
.more a, .return a, .wp-block-button a, .page-index-btn a, .page-index-btn2 a,
button, input[type="submit"], input[type="reset"], input[type="button"] {
  color: var(--color-white); background: var(--color-primary); border: 2px solid var(--color-primary); cursor: pointer;
}

/* .entry-content a（gdoc.css）によるリンク色の上書きを、ボタンラッパ内のみ打ち消す */
.entry-content .more a,
.entry-content .return a,
.entry-content .wp-block-button a,
.entry-content .page-index-btn a,
.entry-content .page-index-btn2 a { color: var(--color-white); }

/* グレー（無効・アクティブ） */
/* グレー（無効・アクティブ）の基本スタイルとホバー時の固定 */
.page-index-btn a.is-active, 
.page-index-btn span, 
.default-all,
.page-index-btn a.is-active:hover, 
.page-index-btn span:hover, 
.default-all:hover {
	color: var(--color-black) !important; background: var(--color-accent) !important; border: 2px solid var(--color-accent) !important; 
	cursor: default; text-decoration: none !important;
}
/* --- ホバー設定（黄ベタ・文字紺） --- */
.more a:hover,
.return a:hover,
.wp-block-button a:hover,
.page-index-btn a:hover,
.page-index-btn2 a:hover,
button:hover, input[type="submit"]:hover, input[type="reset"]:hover, input[type="button"]:hover {
	background: var(--color-accent); color: var(--color-primary) !important; border-color: var(--color-accent); text-decoration: none !important;
}

/* ボタン内の外部リンクアイコン：既定は白（紺ベタ上）、hover は紺（黄ベタ上） */
.more a[target="_blank"]::after,
.return a[target="_blank"]::after,
.wp-block-button a[target="_blank"]::after,
.page-index-btn a[target="_blank"]::after,
.page-index-btn2 a[target="_blank"]::after { color: var(--color-white); }

.more a[target="_blank"]:hover::after,
.return a[target="_blank"]:hover::after,
.wp-block-button a[target="_blank"]:hover::after,
.page-index-btn a[target="_blank"]:hover::after,
.page-index-btn2 a[target="_blank"]:hover::after {
  color: var(--color-primary) !important;
}

/* アイコン定義 */
.more a:not([target="_blank"])::after,
.wp-block-button .wp-block-button__link:not([target="_blank"])::after { content: '\f105' / ''; font-family: "Font Awesome 5 Free"; font-weight: 900; margin-left: .3em; }
.return a:not([target="_blank"])::before { content: '\f104' / ''; font-family: "Font Awesome 5 Free"; font-weight: 900; margin-right: .5em; }

/* レイアウト設定 */
.more { display: block; margin: 20px auto; text-align: center; }
.return { display: block; margin: 60px auto 0; text-align: center; }
.more a, .return a { width: 50%; }

/* ブロックエディタのカラム内 p は上マージンを 0 にする */
.wp-block-column p { margin-top: 0; }

/* 2カラムブロックを縦に積んだ際のブロック間隔（PC 20px / SP 32px） */
.wp-block-columns { margin-bottom: 0; }
.wp-block-columns + .wp-block-columns { margin-top: 20px; }
@media (max-width: 768px) {
	.wp-block-columns + .wp-block-columns { margin-top: 32px; }
}

.wp-block-buttons { display: block; }
.wp-block-button { display: block; padding: 0; margin: 20px auto; width: 100%; text-align: center; }
.wp-block-button__link { display: block; margin: 0 auto; width: 50% !important; }
/* ブロックエディタで「追加 CSS クラス」に "button-full-pc" を入力すると
   PC のときだけ親（カラム等）の幅いっぱいになる */
@media (min-width: 769px) {
	.wp-block-button.button-full-pc .wp-block-button__link { width: 100% !important; }
}

.page-index-btn-container, .page-index-btn2-container {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: 10px; row-gap: 10px;
  list-style: none; padding-left: 0; margin: 0;
}
.page-index-btn-card-container { white-space: nowrap; }

.align-left a { text-align: left !important; justify-content: flex-start; }

/* レスポンシブ */
@media (max-width: 1120px) {
  .page-index-btn a, .page-index-btn2 a, .page-index-btn span { font-size: .9em; }
}

@media (max-width: 1024px) {
  .page-index-btn-container, .page-index-btn2-container { grid-template-columns: 48.5% 48.5%; column-gap: 10px; }
  .page-index-btn a, .page-index-btn2 a, .page-index-btn span { padding: .1em .2em !important; }
}

@media (max-width: 768px) {
  .more a, .return a { width: 80%; }
  .more a, .return a, .wp-block-button a, .page-index-btn a, .page-index-btn2 a, .page-index-btn span, .default-all,
  button, input[type="submit"], input[type="reset"], input[type="button"] { padding: 2px; }
  .more a, .return a { padding: 4px; }
  .align-left-sp a { text-align: left !important; justify-content: flex-start; }
  .page-index-btn a, .page-index-btn2 a, .page-index-btn span { padding: .1em .2em .2em .2em !important; }
  .wp-block-button .wp-block-button__link { width: 80% !important; padding: 4px !important; }
}

/* ----- ページトップに戻るボタン（スクロールで出現） ----- */
.pagetop {
    position: fixed;
    z-index: 999;
    right: 0;
    bottom: 100px;
}
.pagetop__btn {
    display: block; width: 45px; height: 45px;
    background-color: var(--color-primary);
    filter: drop-shadow(var(--shadow));
    position: relative;
    transition: background-color 0.2s ease;
}
.pagetop__btn::before {
    content: "" / "";
    position: absolute; top: 55%; left: 50%;
    width: 14px; height: 14px;
    border-top: 3px solid var(--color-white);
    border-right: 3px solid var(--color-white);
    transform: translate(-50%, -50%) rotate(-45deg);
    transition: border-color 0.2s ease;
}
.pagetop__btn:hover { background-color: var(--color-accent); }
.pagetop__btn:hover::before { border-top-color: var(--color-primary); border-right-color: var(--color-primary); }

/* ----- ページトップに戻るボタン（ページ下部固定） ----- */
.to-top-wrap { padding-top: 80px; }
.to-top { display: block; margin-left: auto; margin-right: auto; text-align: center; }
.to-top a { 
	font-size: 1.1em; font-weight: 700; text-decoration: none; padding: .5em; color: var(--color-white); background: var(--color-primary); 
	border: 1px solid var(--color-primary); display:inline-block; width: 100%;
	}
.to-top a:hover { 
	background: var(--color-primary); color: var(--color-white); text-decoration: underline; 
	text-underline-offset: .25em; text-decoration-thickness: 2px; 
	cursor: pointer;
	}
@media (max-width: 768px) {
	.to-top a { font-size: 1em; } 
	}
.triangle-to-top {
	width: 0; height: 0; border-style: solid;
	border-right: 10px solid transparent; border-left: 10px solid transparent; border-bottom: 10px solid var(--color-primary);
	border-top: 0; text-align:center; display: flex; margin-right: auto; margin-left: auto;
}
/* ----- ファイルダウンロードボタン（ブロック要素） ----- */
.wp-block-file:not(.wp-element-button) { font-size: 1em; }
.wp-block-file {
	box-sizing: border-box; text-align: center; padding-top: 1em; padding-bottom: 1em; 	margin-bottom: 0em;
	}
.wp-block-file a { 
	padding: .5em; border: 1px solid var(--color-primary); width:100%; font-weight: 700;
	align-items: center; display: inline-flex; -webkit-box-align: center; -webkit-box-pack: center; justify-content: center;
	}
.wp-block-file a::before {
	font-family: "FontAwesome"; content: "\f019" / ""; font-size: inherit; margin-right: .3em; color: var(--color-primary);
	}
.wp-block-file a:hover {
	text-decoration:none;
	}
@media (max-width: 768px) {
	.wp-block-file a { display:block; padding: .5em .5em; text-align: center; align-items: initial; }
	}
.wp-block-file a:hover, .wp-block-file a:hover::before { background: var(--color-primary); color: var(--color-white); }
.wp-block-file__button { display: none; }

/* ----- トップページの大ボタン ----- */
.card-container-index { display: flex; gap: 20px; align-items: stretch; /* 高さを揃える設定 */ }
.card {
  flex: 1; /* 2枚なら50%、3枚なら33%、4枚なら25%と自動で幅を確保 */
  position: relative;  display: block; text-decoration: none;
  aspect-ratio: 4/3;
  /* --- ここが重要：高さの設定 --- */
   /* aspect-ratio: 16 / 9; /* 横16:縦9の比率で高さを固定。4/3などお好みで調整 */
  /* もし「比率」ではなく「絶対的な高さ」にしたい場合は、
     aspect-ratio の代わりに height: 250px; と指定 */
  border: 1px solid var(--color-border-image);
  overflow: hidden;
}
.card .card-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
  transition: transform 0.4s ease;
}
@media (hover: hover) {
  .card:hover .card-bg { transform: scale(1.04); }
}
.overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 10px 10px 10px 10px;
  background-color: color-mix(in srgb, var(--color-primary) 95%, transparent); color: var(--color-white);
  font-size: 1.5em; font-weight: 800; text-align: center; transition: background-color 0.3s ease, color 0.3s ease;
}
.overlay .overlay-txt { font-size: .7em; font-weight: 400; line-height: 1.4em; margin-top: 5px; }
.card:hover .overlay { background-color: color-mix(in srgb, var(--color-accent) 90%, transparent); color: var(--color-primary); }

/* スマホ対応 */
@media (max-width: 768px) { 
	.card-container-index { flex-direction: column; margin-top: 20px; gap: 10px; }
	.overlay { font-size: 1.2em; }
	.card { aspect-ratio: 2 / 1; width: 100%; }
}

/* ************************************************************
その他
************************************************************ */

/* ----- ReCAPCHA v3 ----- */

.recaptcha-msg { margin-top: 1em; }
.recaptcha-msg p { font-size: .8em; line-height: 1.3em; }
.grecaptcha-badge { visibility: hidden; }

/* ----- <sup></sup>をつけたときのline-heightの変化を抑止 ----- */

sup {
  vertical-align: baseline; /* 一旦リセット */
  position: relative;
  top: -0.5em;              /* 上にずらす */
  line-height: 0;           /* 行間への影響をゼロにする */
  font-size: 75%;           /* お好みのサイズに */
}

/* ----- その他 ----- */

.bold, strong { font-weight:500; }
.dpfp-blue { color: var(--color-primary); }
.red { color: var(--color-warning); }
.text-aign-right { text-align:right; }
.justify { text-align:justify; }
sup { color: var(--color-warning); }
.bigger { font-size: 1.6em; line-height: 1.6em; }
.smaller { font-size: .8em; }
hr, .wp-block-separator { height: 1px; border: none; border-top: 1px solid var(--color-border) ; }
.newmerk-text { font-weight: 500; color: var(--color-warning); }
@media (max-width: 768px) {
	.bigger { font-size: 1.3em; }
	}

.marker1 { background:linear-gradient(transparent 70%, var(--color-accent) 30%); display: inline; padding: 0 1px 0px; }
.marker2 { background:linear-gradient(transparent 70%, var(--color-marker) 30%); display: inline; padding: 0 1px 0px; }

.underline-dpfpy {
	text-decoration: underline; text-decoration-color: var(--color-accent);
	text-underline-offset: .25em; text-decoration-thickness: 2px;
	}

.indext1 { padding-left: 1em; }
.indent2 { padding-left: 2em; }
@media (max-width: 768px) {
	.indext1 { padding-left: .5em; }
	.indent2 { padding-left: 1em; }
	}

/* ************************************************************
リスト
************************************************************ */

/* ------ ベーシックなリストのスタイル ----- */
.list-def { list-style: none; margin-top: 0px; margin-bottom:0px; }
.list-def li::before { content: "●" / ""; color: var(--color-accent); margin-right: .3em; }
.list-def li { text-indent: -1.3em; margin-left: -1em; text-align: justify; }
.list-def2 { list-style: none; margin-top: 0px; margin-bottom:0px; }
.list-def2 li::before { content: "●" / ""; color: var(--color-accent); margin-right: .3em; }
.list-def2 li { text-indent: -1.3em; margin-left: -1em; text-align: justify; }
@media (max-width: 768px) {
	.list-def { list-style: none; padding-left: 0; }
	.list-def li::before { content: "●" / ""; color: var(--color-accent); margin-right: .3em; }
	.list-def li { text-indent: -1.2em; margin-left: 1.2em; text-align: justify; }
	.list-def2 { list-style: none; padding-left: 0; }
	.list-def2 li::before { content: "●" / ""; color: var(--color-accent); margin-right: .3em; }
	.list-def2 li { text-indent: -1.2em; margin-left: 1.2em; text-align: justify; }
	}

/* ----- ●ビュレット標準リスト -------------------- */
.list-def ul { list-style: none; padding-left: 1.3em; }
.list-def ul li { font-size: 1em; text-indent: -1.3em; }
.list-def ul li::before { content: "●" / ""; color: var(--color-accent); margin-right: .3em; }
@media (max-width: 768px) {
	.list-def ul  { padding-left: 0em; }
	.list-def ul li { padding-left: 1.3em; text-indent: -1.3em; }
	}

/* ----- 注意書きリスト -------------------- */
.caution-list ul { list-style-type: none; margin: 0; padding-left: 0; box-sizing: border-box; }
.caution-list ul li { margin-left:1.2em; text-indent: -1.2em; text-align: justify;}
.caution-list ul li::before { padding-right: .2em; content: "※" / ""; color: var(--color-warning); font-weight: 900; }

/* ----- 表組風リスト -------------------- */

.border-list-wrap { list-style: none; margin: 0; padding: 0; padding-left: 0em !important; margin-bottom:20px; }
.border-list li { display:flex; justify-content:flex-start; border-top:1px solid var(--color-border); padding: .5em; text-align:justify; }
.border-list li:last-child { border-bottom:1px solid var(--color-border); }
.item { width: 8em; }

@media (max-width: 768px){
	.border-list li { padding: .5em 0em .2em .2em; }
	.item { width: 140px; }
	.value { flex-grow: 1; flex-shrink: 1; flex-basis: 0%; }
	}

/* ----- ニュースリスト -------------------- */

.top-newslist { padding-bottom: 50px; }
.update-list { padding: 0; margin-top: 0; margin-bottom: 0; }

.update-list-wrap { margin-bottom: 0; }

/* ************************************************************
アコーディオンのベース
************************************************************ */

/* 1. マウス・キーボード両方の標準フォーカス線を一旦消す（または控えめにする） */
.accordion__head:focus,
.image-thumbnail:focus,
.mushimegane:focus,
.close-button:focus {
    outline: none;
}

/* 2. キーボード操作（Tabキー）でフォーカスした時だけ線を表示する */
.accordion__head:focus-visible,
.image-thumbnail:focus-visible,
.mushimegane:focus-visible,
.close-button:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* ライトボックス（モーダル）内はキーボード操作時に操作位置を明示する。
   :focus ではなく :focus-visible を使うことで、マウスで開いた直後に JS の .focus() で
   閉じるボタンへフォーカスが移ったときは枠を出さず（白枠が出る問題を回避）、
   キーボードで開いた／Tab 移動したときだけ白リング＋紺ハロー（紺ボタン＋暗幕上ではっきり視認可）を出す。 */
.lightbox.active :is(a[href], button, input, [tabindex]):focus-visible {
    outline: 3px solid var(--color-white);
    outline-offset: 2px;
    box-shadow: 0 0 0 2px var(--color-primary);
}

/* button風の挙動 */
.accordion__head {
    user-select: none; /* テキスト選択を防止 */
}

.accordion__item.accordion__item-last { /* border-bottom: 2px solid var(--color-primary); */ }

/* .accordion__content の max-height ルールは line 515 付近に集約済み（旧 2s/3000px ルールを撤去） */

.accordion__body p { font-size: 1em; margin-top: 0px; margin-bottom:0px; text-align: justify; }
.accordion__body ul, ol { padding-left: 2em; }
.accordion__body ul { list-style:disc; }
.accordion__body ul li, .accordion__body ol li:last-child { border-bottom: none!important; }

/* アコーディオンそのものの横幅と余白を指定。開閉動作に影響なし。 */
.accordion__list { list-style: none; padding-top: 1.5em; padding-left: 0em; }
/* .accordion__list li:last-child { border-bottom: 1px solid var(--color-border); } */

/* アコーディオンの開閉ボタンの装飾。position: relative;が無いと「+」「-」の位置がずれるので注意。 */
.accordion__head { position: relative; /* width: 100%; */ padding-top: 11px; cursor: pointer; border-top: 1px solid var(--color-border); }

/* アコーディオンの開閉ボタンの右側に「+」を表示。 */
.accordion__head::after { font-family: "FontAwesome"; content: "\f13a" / ""; position: absolute; top: 25px; right: 10px; font-size:1.6em; color: var(--color-primary); display: inline-block; transform-origin: center; transition: transform 0.5s ease; }
/* アコーディオンが開いた際にアイコンを 180° 回転（icon の差替えではなく回転アニメ） */
.accordion__item.active .accordion__head::after { transform: rotate(180deg); }

/* アコーディオンの閉じている部分の装飾。height: 0; overflow: hidden;にすることで通常時は表示されないようにする。 */
/* アコーディオン展開：max-height transition（実コンテンツ高さは JS が scrollHeight を渡す） */
.accordion__content { overflow: hidden; max-height: 0; transition: max-height 0.55s ease-out; }
.accordion__body { overflow: hidden; width: 100%; padding: 0 0 30px 10px; /* border-top: 1px solid #ddd; */ }

.accordion__list li:last-child { border-bottom: 1px solid var(--color-border); }
.accordion__body ul { list-style:none; padding-bottom:1em; padding-left:1em; padding-right:.5em; margin-top:1em; }
.accordion__body ul li { text-indent: -1.2em; padding-left: 1.2em; }
.accordion__body ul li::before { content: "●" / ""; color: var(--color-accent); margin-right: .2em; }

@media (max-width: 768px) {
	/* アコーディオンの開閉ボタンの右側に「+」を表示。 */
	.accordion__head { padding-left: 5px; padding-right: 5px; }
	.accordion__head::after { position: absolute; top: 12px; right: 10px; font-size:1.3em; color:var(--color-primary);}
	/* アコーディオンが開いた際に、開閉ボタンの右側に「+」を「-」に変更する。 */
	.accordion__item.active .accordion__head::after { right: 10px; font-size:1.3em; }
	}

/* ************************************************************
画像とテキストのコンテナ
************************************************************ */

.media-container {
  display: flex; flex-direction: row; align-items: stretch; /* 右のテキストに合わせて高さを伸ばす */
  gap: 20px; margin-bottom: 20px;
}

/* 画像エリア：幅を固定（例として300px） */
.image-area { display: flex; flex-direction: column;
  width: 30%; /* ここを希望の固定幅に変更 */ flex-shrink: 0; /* 幅が圧縮されないように固定 */
}
.text-area { flex-grow: 1; /* 残りの幅をすべて使う */ }
.image-area:empty { display: none; /* 画像がない場合はエリアごと非表示 */ }

/* 画像自体の設定 */
.image-area img {
  width: 100%;        /* 親(300px)に対して100% */
  height: 100%;       /* テキストエリアの高さまで伸ばす */
  min-height: 300px;  /* ★固定幅と同じ数値を指定することで、最低でも正方形を維持 */
  object-fit: cover;  /* 縦長になっても画像が歪まないようにする */
  border: 1px solid var(--color-border-image);
  vertical-align: bottom;
}

/* スマホ対応 */
@media (max-width: 768px) {
  .media-container { flex-direction: column; gap:1em; }
  .image-area { width: 100%; }
  .image-area img { height: auto; min-height: 0; aspect-ratio: 1/1; }
}

/* ************************************************************
一覧系グリッド（PCで2カラム）
************************************************************ */

/* ----- グリッド本体 -------------------- */
.grid-container { display: grid; grid-template-columns: 49% 49%; padding-left: 0px; margin-top: 0px; column-gap: 2%; }

/* デフォルトのli（ボーダーあり） */
.grid-container li { display: flex; padding-top: 30px; padding-bottom: 30px; border-top: 1px solid var(--color-border-image); }

/* youtube-b（動画埋込版）のみ li にボーダーなし・余白調整 */
.module--youtube-b .grid-container li { display: flex; padding-top: 0px; padding-bottom: 30px; border-top: none; }

/* 下線の制御 */
.grid-container li:nth-last-of-type(2),
.grid-container li:last-child { border-bottom: 1px solid var(--color-border-image); }

.module--youtube-b .grid-container li:nth-last-of-type(2),
.module--youtube-b .grid-container li:last-child { border-bottom: none; }

/* ----- カード・パーツ要素 -------------------- */
.card-img img { width: 260px; object-fit: cover; }
.feed-eyecatch-youtube,.feed-eyecatch-senkyo,.feed-eyecatch-blog,.feed-eyecatch-dpfp { width: 260px; height: 145px; aspect-ratio: auto; }
.archive-thumb img { width: 200px; height: 200px; object-fit: cover; border: 1px solid var(--color-border-image); }
.card-text { width: 100%; margin-left: 15px; }

.feed-post-title, .entry__ttl { font-size: 1em; line-height: 1.5em; margin-top: 0em; font-weight: 500; margin-bottom: .2em; }
/* フィード読込中／読込失敗時の中央寄せフォールバックメッセージ */
.feed-fallback-message { text-align: center; }
.newslist-date, .newslist-title { font-size: 1em; margin-top: 0em; }
.newslist-date { font-weight: 400; }
.newslist-title { font-weight: 700; }

.feed-post-date, .feed-blog-meta, .archive-meta, .feed-post-meta { font-size: .9em; line-height: 1.8em; margin-top:0; margin-bottom: 0em; }
.archive-meta .archive-entry-cat { line-height: 1.8em; }
.feed-post-meta { display: flex; align-items: center; gap: .6em; flex-wrap: wrap; }
.feed-post-meta .feed-post-date { font-size: 1em; }
.feed-post-source { position: relative; z-index: 11; color: var(--color-text-muted); text-decoration: underline; text-underline-offset: .2em; }
.feed-post-source:hover { color: var(--color-primary); }
.feed-blog-meta { text-indent: 0em; margin-left: 0em; }

/* ----- メディアクエリ -------------------- */

/* タブレット・中間サイズ */
@media (max-width: 1024px) {
    .card-img img { width: 100px; height: 100px; }
}

/* スマートフォンサイズ */
@media (max-width: 768px) {
    .grid-container { display: block; }
    .grid-container li { padding-top: 15px; padding-bottom: 15px; }
    .grid-container li:nth-last-of-type(2) { border-bottom: none; }
    /* youtube は SP でも 2 カラムを維持するので nth-last-of-type(2) に border-bottom を残す */
    .module-feed-youtube .grid-container li:nth-last-of-type(2) { border-bottom: 1px solid var(--color-border-image); }
    .card-img img, .archive-thumb img { width: 100px; height: 100px; }
    .feed-eyecatch.feed-eyecatch-youtube { background: var(--color-black); }
    .card-text { margin-left: 15px; }
    .feed-post-title, .entry__ttl { font-size: 1em; line-height: 1.5em; margin-bottom: .25em; }
    .newslist-date, .newslist-title { margin-bottom: .25em; }
    .newslist-date { letter-spacing: -.05em; }
    .feed-post-date, .feed-blog-meta { font-size: .9em; line-height: 1.3em !important; }
    .archive-meta, .feed-post-meta { font-size: .85em; line-height: 1.3em !important; }
    .archive-entry-cat { margin-top: .3em; }
}

/* ********** カード全体をhover対象にする ****************************** /

/* --- カード全体リンクの基本設定 --- */
.card-container {
    position: relative; /* 親を基準にする */
    z-index: 1;
}

/* リンクを疑似要素でカード全体に広げる */
.main-link::before,
.full-range-link::before {
    content: "";
    position: absolute;
    /* 上下左右0に固定することで画像エリアも完全にカバー */
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10; /* 画像(デフォルト)より上、カテゴリ(11以上)より下 */
    display: block;
}

/* --- 干渉要素の整理 --- */

/* NEWマークなどはクリックを透過させる */
.archive-new, 
.newmark-label, 
.newmark-text {
    position: relative;
    z-index: 11;
    pointer-events: none; /* 指のタッチを下のリンクへ通す */
}

/* カテゴリーリンクだけは膜の上に置いてクリック可能にする */
.archive-entry-cat {
    position: relative;
    z-index: 12;
}
.archive-entry-cat a {
    position: relative;
    z-index: 13;
}

/* 外部リンクアイコンの表示位置修正 */
.main-link[target="_blank"]::after,
.full-range-link[target="_blank"]::after {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    margin-left: 0.3em;
}

/* --- ホバー演出（PCのみ） --- */
@media (hover: hover) {
    .card-container:hover .card-img img { transform: scale(1.04); opacity: 1; }
    .card-container:hover .main-link { text-decoration: underline; text-underline-offset: .25em; text-decoration-thickness: 2px; }
}

/* --- スマホ特有の調整 --- */
@media (max-width: 768px) {
    /* 画像エリアで確実にリンクを反応させるための補強 */
    .card-img { position: relative; z-index: 1; }
    /* 1タップ目で遷移するようにホバーを無効化 */
    .card-container:hover .card-img img { transform: none; }
}

/* ************************************************************
スマホ/PC別表示非表示
************************************************************ */

@media (min-width: 769px) {
  .sp-only { display: none!important; }
  .pc-only { display: inline!important; }
  .sp-only-block { display: none!important; }
  .pc-only-block { display: block!important; }
  .sp_br { display:none!important; }
}
@media (max-width: 768px) { 
  .sp-only { display: inline!important; }
  .pc-only { display: none!important; }
  .sp-only-block { display: block!important; }
  .pc-only-block { display: none!important; }
  .sp_br { display:inline!important; }
}

/* ----- スマホでTABLEを横スクロール ----- */
table { display: block; overflow-x: scroll; white-space: nowrap; -webkit-overflow-scrolling: touch; }

/* ************************************************************
サイトトップのモジュール
************************************************************ */

/* ------ モジュールの基底ルール（Phase 1：新しい .module クラス） -----
   各セクションが最外要素に .module（＋必要に応じ .module--<slug>）を付与すると、
   上下間隔がトークンに基づいて自動で揃う。ページ側での微調整は不要にする方針。
   .module__inner は中身を中央寄せする共通ラッパー（= 旧 .wrapper 相当）。
   Phase 2 で sections/*.php を順次この構造に移行。Phase 3 で下の旧ルールを削除予定。 */
.module { padding-block: var(--space-section) 0; }
.module__inner { width: 90%; max-width: 1120px; margin-inline: auto; }

/* account-area のみ例外的に上下狭い padding */
.module-account-area { padding-top: 40px!important; padding-bottom: 40px!important; }

/* 緊急のお知らせは常にヒーロー直下に位置するため padding-top を打ち消す */
.module--emergency-notice { padding-top: 0 !important; }

/* スペーサー：余白調整用の空セクション */
.module--spacer { padding: 0 !important; height: 120px; }
@media (max-width: 768px) {
  .module--spacer { height: 80px; }
}

/* SP のみ：big-index は padding-top を 0、news-multi は半分に */
@media (max-width: 768px) {
	.module--big-index { padding-top: 0 !important; }
	.module--news-multi { padding-top: 40px !important; }
}

/* ------ セクション見出し（template-parts/section-head.php） ------ */
.section-head { text-align: center; margin-bottom: 60px; line-height: 1.6em; }
.section-head .top-section-title { font-size: 2.2em; margin: 0; font-weight: 700; }

/*
 * セクション見出しの下線は ::after 擬似要素で描画する。
 * letter-spacing を効かせたいサイトは custom.css で:
 *   .section-head .top-section-title__text { --section-title-ls: .4em; }
 * と書くだけで、text-indent と下線の左右オフセットが連動して
 * 中央寄せ・下線末尾はみ出し問題を起こさずに字間を広げられる。
 */
.section-head .top-section-title__text {
	--section-title-ls: 0;
	letter-spacing: var(--section-title-ls);
	text-indent: var(--section-title-ls);
	display: inline-block;
	position: relative;
	text-decoration: none;
	}
.section-head .top-section-title__text::after {
	content: "";
	position: absolute;
	left: var(--section-title-ls);
	right: var(--section-title-ls);
	bottom: -.5em;
	height: 6px;
	background: var(--color-accent);
	}
.section-head .top-section-title + .section-exp { font-size: 1em; margin: 40px 0 0; }
@media (max-width: 768px) {
	.section-head { margin-bottom: 30px; }
	.section-head .top-section-title { font-size: 1.5em; }
	.section-head .top-section-title + .section-exp { font-size: .9em; margin-top: 25px; line-height: 1.4em; }
}

/* ------ キャッチフレーズなど ------ */
.catchphrase,
.is-style-catchphrase { font-size: 2.2em !important; font-weight: 900 !important; text-align: center !important;
	line-height: 1.6em; margin-top: 0; margin-bottom: 1em; }
.subtitle { font-weight:900 !important; font-size:1.6em !important; text-align:center !important; line-height:1.6em;
	margin-top: 0; }
@media (max-width: 768px) {
	.catchphrase,
	.is-style-catchphrase { font-size: 1.6em!important; line-height: 1.6em; margin-top: 10px; margin-bottom: 25px; }
	.subtitle { font-size:1.2em !important; margin-top:10px;}
	}

/* ----- 緊急のお知らせ ----- */
.introduction-wrap, .emergency-notice-wrap {
	border: 1px solid var(--color-black); padding-top: 0; padding-left: 2em; padding-right: 2em;
	padding-bottom: 0; margin-top: 60px; margin-bottom: 60px; text-align: justify;
}
@media (max-width: 768px) {
.introduction-wrap, .emergency-notice-wrap {
	border: 1px solid var(--color-black); padding-top: 0em; padding-left: 1em; padding-right: 1em; padding-bottom: 0; 
	margin-top: 20px; margin-bottom: 20px; }
}

/* ----- サイトトップのお知らせモジュール ----- */
.top-newslist,.update-list { padding-top:0; padding-bottom:0; }
.newslist-date { width: 160px!important; }
@media (max-width: 768px){
	.top-newslist,.update-list { padding-top: 5px; }
	.newslist-date { width: 120px!important; }
	}

/* ----- サイトトップのお知らせモジュール2 ----- */
.update-list-wrap { list-style: none; margin: 0; padding: 0; padding-left: 0em !important; margin-bottom:20px; }
.update-list li { display:flex; justify-content:flex-start; border-top:1px solid var(--color-border-image); padding: .5em; }
.update-list li:last-child { border-bottom: 1px solid var(--color-border-image); }

.item1 { width: 6em; }
.item2 { width: 9em; }

.label-blog,.label-news,.label-plog,.label-press {
	display: inline; padding: 0em .2em .1em .2em; margin-top: 1px; margin-left: 1px; font-size: .8em; line-height:1em; }
.label-blog { color: var(--color-white); background: var(--color-label-blog); }
.label-press { color: var(--color-white); background: var(--color-primary); white-space: nowrap; }
.label-news { color: var(--color-white); background: var(--color-label-news); }
.value0 { font-weight: 500; flex-grow: 1; flex-shrink: 1; flex-basis: 0%; overflow-wrap: anywhere; word-break:break-all; }

@media (max-width: 768px){
.update-list li { display:block; padding-left: .25em; padding-right: .25em; }
.value0 { display:block; margin-top:.3em; }
}

/* ----- サイトトップのバナーモジュール ----- */

.banner-container {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	column-gap: 14px;
	list-style: none; padding-left: 0;
}
.banner-card-container { padding-bottom: 14px; }
.banner-card-container img { width:100%; border: 1px solid var(--color-border-image); object-fit:cover; /* aspect-ratio: 4/5;*/ }
@media (max-width: 768px) {
	.banner-container { grid-template-columns: repeat(2, 1fr); column-gap: 2%; }
	.banner-card-container { padding-bottom: 4px; }
	}

/* ----- モジュール内のボタン（.more）上マージン統一 -----
   「もっと見る」「もっと観る」「もっとくわしく」「PDFで表示する」「バックナンバー」等、
   モジュール内の .more ボタンは直前要素の種類に関わらず一定の上部スペースを確保する。 */
.module .more { margin-top: 50px; }
@media (max-width: 768px){
	.module .more { margin-top: 40px; }
	}

/* ----- サイトトップのブログ（リスト形式）モジュール ----- */
.module-blog .update-list { margin-bottom: 50px; }
@media (max-width: 768px){
	.module-blog .update-list { margin-bottom: 40px; }
	}

/* ----- サイトトップのブログ（リスト形式マルチ）モジュール ----- */
.module-blog-multi ul, .top-newslist ul { list-style:	none; margin: 0; padding: 0; }
.module-blog-multi ul li {
	border-top:1px solid var(--color-border); padding-top: .5em; padding-bottom: .5em;
	padding-left: 1.7em; text-indent: -1.5em;
	}
.module-blog-multi ul li:last-child { border-bottom:1px solid var(--color-border); }
.module-blog-multi ul li .headline:before { content: "●" / ""; color: var(--color-accent); }

/* ----- サイトトップの事務所のご案内モジュール ----- */

.office-body { background: var(--color-bg-subtle); border: none;
	padding-left: 4em; padding-right: 4em; padding-top: 1em; padding-bottom: 4em; }
@media (max-width: 768px) {
	.office-body { padding-left: 1em; padding-right: 1em; padding-top: 1em; padding-bottom: 1em; }
	.office-body p { margin-top: 0; }
	}
.office-name { border-bottom: 1px solid var(--color-border); padding-bottom: 10px; }
.office-name h3 { font-size: 1.3em; margin-bottom: 0px; margin-top: 0; }
.gmap-iframe { width: 100%; height: 400px; border: 1px solid var(--color-border-image); }
.gmap-iframe iframe {
  width: 100% !important;   /* !importantでHTML属性を強制上書き */
  height: 100% !important;  /* !importantでHTML属性を強制上書き */
}
.gmap-link a {
	font-size:.9em; font-weight: 700; text-decoration: none;
	padding-top: .5em; padding-bottom: .5em;
	color: var(--color-primary); background: var(--color-white); border: 2px solid var(--color-primary);
	width: 100%; display: block; text-align: center;
	}
.gmap-link a:hover, .gmap-link a[target="_blank"]:hover::after { 
	background: var(--color-primary); color: var(--color-white); text-decoration: none;
	}
/* ----- 事務所のご案内（2か所版・office-b） --------------------
   左右のグレーボックスを1つに統合。
   subgrid により、住所テキスト量に関わらず左右のマップ上端が揃う。 */
.module-office--multi .office-multi-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto auto auto;
	column-gap: 30px;
	background: var(--color-bg-subtle);
	padding: 1em 4em 4em;
}
.module-office--multi .office-body {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 3;
	background: none;
	padding: 0;
	min-width: 0;
}
@media (max-width: 768px) {
	.module-office--multi .office-multi-grid {
		display: flex; flex-direction: column; gap: 20px;
		padding: 1em;
	}
	.module-office--multi .office-body { display: block; }
}

/* office-a：左に所在地テキスト、右に地図の2カラム */
.module-office--single .office-single-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 30px;
	background: var(--color-bg-subtle);
	padding: 2em;
}
.module-office--single .office-body {
	background: none;
	padding: 0;
}
.module-office--single .gmap-iframe {
	height: 100%;
	min-height: 300px;
}
@media (max-width: 768px) {
	.module-office--single .office-single-grid {
		display: flex; flex-direction: column; gap: 20px;
		padding: 1em;
	}
	.module-office--single .gmap-iframe { height: 300px; }
}

/* ************************************************************
ヘッダーとハンバーガーメニュー
************************************************************ */

.header {
    position: fixed; /* fixed：フロー外でヒーロー上に浮かせる */
    top: 20px; left: 2%; right: 2%;
    background-color: var(--color-white); box-shadow: var(--shadow); z-index: 1000;
    transform-origin: top center;
    transition: opacity 0.3s ease, transform 0.3s ease;
}
.header.is-peek { opacity: 0; transform: scaleY(0.2); pointer-events: none; }
.header.no-anim, .header-handle.no-anim { transition: none; }
@media (max-width: 768px) {
    .header { top: 15px; left: 15px; right: 15px; }
}

.header-handle {
    position: fixed; top: 20px; left: 50%;
    width: 240px; height: 24px;
    transform: translateX(-50%) scaleY(0.2);
    transform-origin: top center;
    display: flex; align-items: center; justify-content: center;
    background: var(--color-primary); color: var(--color-white);
    border: 0; border-radius: 0;
    cursor: pointer; z-index: 1001;
    box-shadow: var(--shadow);
    opacity: 0; pointer-events: none;
    transition: opacity 0.3s ease, transform 0.3s ease, background-color 0.2s ease, color 0.2s ease;
    font-size: 14px; line-height: 1; padding: 0;
}
.header-handle.is-visible { opacity: 1; transform: translateX(-50%) scaleY(1); pointer-events: auto; }
.header-handle:hover { background: var(--color-accent); color: var(--color-primary); }
@media (max-width: 768px) {
    .header-handle { top: 15px; width: calc(100% - 30px); height: 28px; font-size: 13px; }
}
.header__inner { display: flex; justify-content: space-between; align-items: center; padding: 0.3em 5rem 0.3em 0.5rem; min-height: 80px; box-sizing: border-box; }
@media (max-width: 768px) {
    .header__inner { min-height: 60px; }
}
.header .header-ttl { display: flex; box-sizing: border-box; margin: 5px; }
.header .header-link { display: flex; align-items: center; }
.header .header-party-logo-box { display: block; margin-right: 10px; }
.header .header-party-logo { display: block; width: 110px; }
.header .header-ttl-big { display: block; font-size: 2.2rem; line-height: 1; font-weight: 900; }
.header .header-ttl-small { display: block; font-size: .9rem; line-height: 1; margin-top: 5px; font-weight: 700; }
.header .header-ttl,.header .header-ttl-big,.header .header-ttl-small { color: var(--color-primary); }
.sub-header { padding-top: 120px; padding-bottom: 0; margin-bottom: 30px; background: var(--color-bg-subtle); }
@media (max-width: 768px) { .sub-header { padding-top: 80px; } }

@media (max-width: 768px) {
    .header .header-ttl { display: flex; box-sizing: border-box; margin: 0px; }
    .header .header-link { display: flex; align-items: center; }
    .header .header-party-logo-box { display: block; margin-right: 10px; }
    .header .header-party-logo { width: 85px; }
    .header .header-ttl-big { display: block; font-size: 1.8rem; line-height: 1; }
    .header .header-ttl-small { display: block; font-size: .8rem; line-height: 1; margin-top: 3px; font-weight: 500; }
}

/* ************************************************************
   ハンバーガーボタン
   ************************************************************ */

.drawer__button {
    position: absolute; top: 0; right: 0;
    width: 80px; height: 80px;
    background-color: var(--color-white); border: none; cursor: pointer; z-index: 1001 !important;
    transition: background-color 0.2s ease; }
@media (max-width: 768px) {
    .drawer__button { width: 60px; height: 60px; }
}
.drawer__button:hover,
.drawer__button.active { background-color: var(--color-primary) !important; }
.drawer__button:hover > span,
.drawer__button.active > span { background-color: var(--color-white); }

/* ボタン内の線 */
.drawer__button > span {
    display: block; position: absolute; top: 50%; left: 50%; width: 55%; height: 5px;
    background-color: var(--color-primary); transform: translateX(-50%);
    transition: background-color 0.2s ease; }

.drawer__button > span:first-child { transform: translate(-50%, calc(-50% - 0.7rem)); transition: transform 0.3s ease; }
.drawer__button > span:nth-child(2) { transform: translate(-50%, -50%); transition: opacity 0.3s ease; }
.drawer__button > span:last-child { transform: translate(-50%, calc(-50% + 0.7rem)); transition: transform 0.3s ease; }
.drawer__button.active > span:first-child { transform: translate(-50%, -50%) rotate(-45deg); }
.drawer__button.active > span:nth-child(2) { opacity: 0; }
.drawer__button.active > span:last-child { transform: translate(-50%, -50%) rotate(45deg); }

/* ************************************************************
   メニューのデザイン（ナビゲーション本体）
   ************************************************************ */

/* メニュー展開時の背景オーバーレイ（半透過黒）
   ヘッダーの z-index: 1000 より下に配置して、ヘッダーは暗くならないようにする */
body::before {
    content: '';
    position: fixed; inset: 0;
    background-color: var(--color-overlay);
    z-index: 998;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.35s ease, visibility 0.35s ease;
}
body:has(.drawer__button.active)::before {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

/* ヘッダーバー直下に浮かぶドロワーメニュー
   position: fixed で上下左右 15px のマージンを確保、PC は右半分のみ */
.drawer__nav {
    position: fixed;
    top: 100px; /* PC: 20px + ヘッダーバー80px */
    right: 2%;
    bottom: 20px;
    z-index: 999;
    background-color: var(--color-white);
    overflow-y: auto;
    /* 閉時は visibility: hidden で tab フォーカス順からも外す。
       transform の閉アニメ完了後（0.35s）に visibility を hidden へ遅延切替 */
    visibility: hidden;
    transform: scaleY(0);
    transform-origin: top;
    transition: transform 0.35s cubic-bezier(0.25, 1, 0.5, 1), visibility 0s 0.35s;
    pointer-events: none;
    box-shadow: var(--shadow);
    /* 上方向にだけ影をはみ出させたくないので clip-path で上端をクリップ。
       左右下は 50px 余裕を持たせて影を見せる */
    clip-path: inset(0 -50px -50px -50px);
}
.drawer__nav.active {
    transform: scaleY(1);
    pointer-events: auto;
    visibility: visible;
    transition: transform 0.35s cubic-bezier(0.25, 1, 0.5, 1), visibility 0s 0s;
}

.drawer__nav { left: 2%; }

@media (min-width: 769px) {
    .drawer__nav { max-height: 600px; }
}

/* SP：マージン15px＋ヘッダーバー60px */
@media (max-width: 768px) {
    .drawer__nav { top: 75px; left: 15px; right: 15px; bottom: 15px; }
}

.drawer__nav__inner {
    padding: 1rem 1.5rem;
}

/* PC：ドロワーを左右2カラムに。左半分は .drawer__nav__media、右半分が .drawer__nav__inner */
@media (min-width: 769px) {
    .drawer__nav { display: flex; overflow: hidden; }
    /* contain: コンテナ幅が画像幅より狭くなったら全体が収まるよう縮小（広い間は高さ100%でフィット） */
    .drawer__nav__media { width: 50%; flex-shrink: 0; background: url('../img/drawervisual.webp') left bottom / contain no-repeat; }
    .drawer__nav__inner { width: 50%; flex-shrink: 0; overflow-y: auto; }
}

/* SP：左半分の枠は不要なので非表示 */
@media (max-width: 768px) {
    .drawer__nav__media { display: none; }
    .drawer__nav__inner { padding: 1rem; }
}

/* ************************************************************
   メニュー内部リンク・リスト
   ************************************************************ */

.drawer__nav__menu { list-style: none; padding-left: 0; margin-top: 15px; }
/* 最初のアイテムのボーダー */
.drawer__nav__menu .drawer__nav__item:first-child { border-top: 1px solid lightgray; }

@media (max-width: 768px) { 
    .drawer__nav__menu { margin-top: 5px; }
}

/* 1. メニュー項目を Flexbox にして、テキストとアイコンを両端に配置 */
.drawer__nav__menu .drawer__nav__link {
    display: flex;
    justify-content: space-between; /* テキストとアイコンを左右に分ける */
    align-items: center;
    padding: 15px 20px; /* デザインに合わせて調整 */
    font-size: 1.1em; font-weight: 700; color: var(--color-primary);
    text-decoration: none; padding: .7rem .7rem; border-bottom: solid 1px lightgray;
}
.drawer__nav__menu .drawer__nav__link:hover {
    text-decoration: underline; text-underline-offset: .25em; text-decoration-thickness: 2px;
}
@media (max-width: 768px) {
    .drawer__nav__menu .drawer__nav__link { font-size: 1em; }
}

/* 1-b. キーボード操作時のフォーカス表示 */
.drawer__nav__menu .drawer__nav__link:focus-visible,
.menu-account-area a:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

/* 2. 右端の矢印アイコンを追加 */
.drawer__nav__menu .drawer__nav__link::after {
    content: '\f105' / ''; /* Font Awesomeの矢印 */
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: .9em;
    color: var(--color-primary);
    margin-left: 10px;
	padding: 0 !important;
}

/* 3. 外部リンク（一番下の国民民主党）の処理 */
/* target="_blank" のときは、既に設定されている \f08b アイコンを生かす設定 */
.drawer__nav__menu .drawer__nav__link[target="_blank"]::after {
    content: "\f08b" / ""; /* もし既存の設定と重複して2つ出るなら、ここを調整 */
}

/* 4. SNSアカウントリスト内のアイコンには矢印を出さない */
.drawer__nav__menu .menu-account-area .drawer__nav__link::after,
.drawer__nav__menu .menu-account-area a::after {
    display: none !important;
}

.drawer__nav__link .navi-nolink { color: var(--color-text-muted) !important; }

/* メニュー展開時の背景固定 */
/* scrollbar-gutter: stable でスクロールバー消失によるレイアウトシフトを防ぎ、ボタン位置がずれないようにする */
html { scrollbar-gutter: stable; }
body.active { height: 100%; overflow: hidden; }

/* ************************************************************
   フッター
   ************************************************************ */

footer { padding-top: 20px; }

.footer-navi .menu-account-area { display: none; } 
.footer-nav-area { padding-top: 20px; background: var(--color-bg-subtle); /* 後者：var(--color-bg-subtle)（共通） */ }
/* フッターメイン要素のレイアウト */
.footer-elements { display: flex; justify-content: space-between; padding-bottom: 20px; }
.header-party-logo-tagline { display: block; text-align: right; }
.header-party-logo-tagline img { width: 160px; }
/* スマホ対応：メディアクエリ */
@media (max-width: 768px) {
    .footer-elements { display: flex; padding-bottom: 20px; }
    .header-party-logo-tagline { display: block; text-align: center; padding-bottom: 20px; }
    .header-party-logo-tagline img { width: 120px; margin-top: 0; }
}
/* ナビゲーション */
.footer-navi { list-style: none; padding-left: 0px; margin: 0px; column-count: 2; width: fit-content; column-gap: 1em; }
@media (max-width: 768px) {
    .footer-navi { column-count: 1; }
}
.footer-navi .drawer__nav__link {
    display: block; font-size: .9em; color: var(--color-primary);
    padding: 0em; border-bottom: 0px; margin-bottom: .25em; letter-spacing: 0em;
}
.footer-navi .drawer__nav__link::before {
	content: '\f105' / ''; font-family: "Font Awesome 5 Free";
	font-weight: 900; font-size: .9em; color: var(--color-primary); margin-right: .5em;
	/* hover 下線を行頭アイコンには適用しない（inline-block で親の装飾を継がせない） */
	display: inline-block; text-decoration: none;
}
/* ヘッダー内のテキストリンクは hover 下線を外す。ただしハンバーガー内（.drawer__nav__link）は現状維持 */
.header a:not(.drawer__nav__link):hover { text-decoration: none; }

/* コピーライト・クレジット */
.footer-copy { font-size: .8em; text-align: left; padding-top: 10px; padding-bottom: 30px; }
.footer-credit { background: var(--color-accent) !important; color: var(--color-black) !important; }

/* ************************************************************
404、サンキュー
************************************************************ */

.notfound .media-container, .thankyou .media-container {
	display: flex; flex-direction: row;
	align-items: center; width: 80%; margin-left: auto; margin-right: auto; gap: 30px; 
	margin-bottom: 20px; padding-top: 30px;
}
.notfound .media-container .image-area, .thankyou .media-container .image-area {
	display: flex; flex-direction: column; width: 10%; flex-shrink: 0;
}
.notfound .media-container .image-area:empty, .thankyou .media-container .image-area:empty {
	display: none;
}
.notfound .image-area img, .thankyou .image-area img {
  width: 100%; height: auto; min-height: 10px; object-fit: cover; border:0;
}

.notfound .media-container p, .thankyou .media-container p { margin-top: 0; text-align: justify; }

@media (max-width: 768px) {
  .notfound .media-container, .thankyou .media-container { flex-direction: column; gap:1em; width: 100%; }
  .notfound .media-container .image-area { 
	  width: 30% !important; align-content: center; margin-left: auto; margin-right: auto; }
  .thankyou .media-container .image-area { 
	  width: 25%; align-content: center; margin-left: auto; margin-right: auto; }
  .notfound .image-area img, .thankyou .image-area img  { width: 100%; height: 160px; min-height: 0;
	  aspect-ratio: auto; object-fit: contain; }
}

/* ************************************************************
オリジナルカラーパレット
************************************************************ */

.has-dpfp-blue-color { color: var(--color-primary); }
.has-dpfp-blue-background-color { background-color: var(--color-primary); }
.has-dpfp-blue-border-color { border-color: var(--color-primary); }

.has-dpfp-yellow-color { color: var(--color-accent); }
.has-dpfp-yellow-background-color { background-color: var(--color-accent); }
.has-dpfp-yellow-border-color { border-color: var(--color-accent); }

.has-yellow-color { color: var(--color-yellow-block); }
.has-yellow-background-color { background-color: var(--color-yellow-block); }
.has-yellow-border-color { border-color: var(--color-yellow-block); }

.has-red-color { color: var(--color-warning); }
.has-red-background-color { background-color: var(--color-warning); }
.has-red-border-color { border-color: var(--color-warning); }

.has-white-color { color: var(--color-white); }
.has-white-background-color { background-color: var(--color-white); }
.has-white-border-color { border-color: var(--color-white); }

.has-black-color { color: var(--color-black); }
.has-black-background-color { background-color: var(--color-black); }
.has-black-border-color { border-color: var(--color-black); }

.has-light-gray-color { color: var(--color-bg-subtle); }
.has-light-gray-background-color { background-color: var(--color-bg-subtle); }
.has-light-gray-border-color { border-color: var(--color-bg-subtle); }

/* ********** メッセージ ****************************** */

.message-body, .general-body { background: var(--color-bg-subtle); border: none;
	padding-left: 4em; padding-right: 4em; padding-top: 3em; padding-bottom: 3em; }
.general-body { padding-top: 2em; }
.message-body .video, .general-body .video { padding-top: .5em; }
.message-body p { font-weight: 500; text-align:justify; }
.general-body p { text-align:justify; }
/* ブロックエディタの B（strong / b）の太さは 500 にする */
.general-body strong, .general-body b { font-weight: 500; }
@media (max-width: 768px) {
	.message-body, .general-body { padding-left: 1em; padding-right: 1em; padding-top: 1em; padding-bottom: 2em; }
	.message-body .video, .general-body .video { margin-top: 1em; }
	}

/* ********** 広報紙 ****************************** */

.press-col a img:hover, .press-images a img:hover, a.press-images:hover img { text-decoration: none; }
.press-body {
	background: var(--color-bg-subtle); border: none;
	padding-left: 4em; padding-right: 4em; padding-top: 3em; padding-bottom: 4em;
}
.press-col a[target="_blank"]::after,
a.press-images[target="_blank"]::after { content: none; }
.press-title { text-align:center; margin-top: 0; }
.press-images { display: flex; gap: 20px; }
.press-col { flex: 1; overflow: hidden; border: 1px solid var(--color-border-image); }
.press-col img { width: 100%; height: auto; display: block; /* aspect-ratio: 1.4/1 !important; ヨコ版の場合 */ }
/* トップ広報紙セクションのボタン余白（.module .more の既定に勝つよう .more 併記で詳細度を上げる） */
.more.press-pdf-view { margin-top: 20px; margin-bottom: 0; }
.more.press-archive { margin-top: 20px; margin-bottom: 0; }
.bigBanner a[target="_blank"]::after { content: none; }

@media (max-width: 768px) {
.press-body { padding-left: 1em; padding-right: 1em; padding-top: 1em; padding-bottom: 1.5em; }
.press-images { display: flex; gap: 5px; }
/* .press-col--right { display: none; } */
}

/* ----- 広報紙用一覧設定 -------------------- */

.card-img-press img { width: 150px; height: 212.14px; object-fit: fill; }
.press-txt {
	font-size: .9em;
	line-height: 1.5em;
}
@media (max-width: 768px) {
	.card-img-press img { width: 100px; height: 141.53px; object-fit: fill !important; }
	.press-txt { font-size:.9em; }
	}

/* ----- A3横版 -------------------- */

/* セクション：1枚表示・A3横比率 */
.press-images--a3 { display: block; }
.press-col--a3 img { aspect-ratio: 420 / 297; object-fit: contain; }

/* 一覧：A3横比率サムネ（420:297 ≒ 1.414:1）、幅はA4の2倍 */
.card-img-press--a3 img { width: 300px; height: 212px; }
@media (max-width: 768px) {
	.card-img-press--a3 img { width: 200px; height: 141px; }
	}

/* ----- gallery-loop：ミニギャラリー画像の全幅エンドレスマーキー ----- */
/* .module 直下（.module__inner の外）に置く。overflow:hidden で見切れを隠す。
   幅は --gallery-loop-width で変更可（既定 100%＝全幅）。狭めたいときは
   例）custom.css に .gallery-loop { --gallery-loop-width: 80% } と書くだけ（自動でセンタリング）。
   自動送り・手動ドラッグ/スワイプ・継ぎ目なしループは js/common.js が transform で制御する。 */
.gallery-loop {
	overflow: hidden; width: var(--gallery-loop-width, 100%); margin: 30px auto 0;
	touch-action: pan-y;            /* 縦はページスクロール、横はドラッグ操作に回す */
	cursor: grab; user-select: none; -webkit-user-select: none;
}
.gallery-loop.is-dragging, .gallery-loop.is-dragging .gallery-loop__img { cursor: grabbing; }
/* トラックは実セット＋複製セットを横並び。transform は JS が設定（CSS アニメは使わない）。 */
.gallery-loop__track { display: flex; width: max-content; will-change: transform; }
/* 画像のフォーカス枠は .image-wrapper の overflow:hidden で外側が見切れる。
   gallery-loop 内は内側(inset)に描いて確実に見せる（色・太さは共通ルールを継承）。 */
.gallery-loop .image-thumbnail:focus-visible { outline-offset: -3px; }
/* JS のライトボックス走査用に .photo-container を流用するが、grid を flex で上書き */
.gallery-loop .photo-container {
	display: flex; flex-wrap: nowrap; gap: 0;
	width: max-content; margin: 0; padding: 0;
}
.gallery-loop__item { list-style: none; flex: 0 0 auto; }
.gallery-loop .image-wrapper { border: 0; }
/* 高さは --gallery-loop-height（PC）/ --gallery-loop-height-sp（SP）で変更可。
   例）custom.css に .gallery-loop { --gallery-loop-height: 260px; --gallery-loop-height-sp: 160px } */
.gallery-loop__img { height: var(--gallery-loop-height, 260px); width: auto; display: block; -webkit-user-drag: none; }
@media (max-width: 768px) {
	.gallery-loop__img { height: var(--gallery-loop-height-sp, 220px); }
}

/* ************************************************************
投稿ページと固定ページ（ブロックのスタイル）
************************************************************ */

/* ----- 目次（TOC+） -------------------- */

#toc_container { border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); 
	padding-left: 0em; padding-right:1em; padding-bottom: .5em; margin-bottom: 40px; }
.toc_title { font-weight: 700; }
.toc_list { padding-left: 1.5em; }
.toc_list ul li { margin-bottom: .25em; }
.toc_list ul li:first-child { margin-top: .25em; }

/* ----- 主要要素 -------------------- */

h1.has-background, h2.has-background, h3.has-background, h4.has-background, h5.has-background, h6.has-background {
	padding: 0em 0.1em;
}
:root :where(p.has-background) {
	padding: 0.01em 0.3em;
}

.entry-header h1, .archive-header h1, .archive-header-no-exp h1
	{ font-size: 2.2em; text-align:left; margin-bottom:20px; font-weight:700;
	text-decoration:underline; text-decoration-color: var(--color-accent);
	text-underline-offset: .3em; text-decoration-thickness: 6px;
	}
@media (max-width: 768px) {
	.entry-header h1, .archive-header h1, .archive-header-no-exp h1 {
		padding-top: 0; font-size: 1.8em; line-height: 1.7em; }
	}

/* sub-header 直後の wrapper 内の「視覚的に先頭の要素」は margin-top を打ち消す。
   wrapper > entry-content > section > p/h2... のような入れ子構造でも、
   子孫方向のどの深さにある first-child も対象にする。
   コンテンツ種別ごとに個別対応しなくても、見出し上の余白は
   sub-header 側の padding だけで決まる */
.sub-header + .wrapper :first-child { margin-top: 0; }

.entry-header,.entry-header-w-post-date,.archive-header { padding-top: 20px; }
.entry-header, .archive-header { padding-bottom: 80px; }
.entry-header-w-post-date { padding-bottom: 40px; }
.entry-header .post-date { font-size: .9em; text-align:left; padding-top:20px; }
@media (max-width: 768px) {
.entry-header,.entry-header-w-post-date,.archive-header { padding-top: 10px; }
.entry-header, .archive-header { padding-bottom: 50px; }
.entry-header-w-post-date { padding-bottom: 30px; }
.entry-header .post-date { padding-top: 0; padding-bottom: 0; }
}

.entry-content h2, .has-large-font-size { 
	font-size: 2em; line-height:1.6em; font-weight: 700; overflow-wrap: anywhere; line-break: strict;
	border-left:10px solid var(--color-accent); padding-left: 10px; margin-top: 2em; 
	}
.entry-content h3 { font-size: 1.6em; font-weight: 700; }
.entry-content h4, .has-medium-font-size { font-size: 1.4em; font-weight: 600; }
.entry-content h5 { font-size: 1.3em; ; font-weight: 600; }
.entry-content h6 { font-size: 1.2em;  font-weight: 500; }
.has-small-font-size { font-size: .9em; }
@media (max-width: 768px) {
	.entry-content h2, .has-large-font-size { font-size: 1.3em; }
	.entry-content h3 { font-size: 1.2em; line-height: 1.5em; }
	.entry-content h4, .has-medium-font-size { font-size: 1.1em; }
	.entry-content h5 { font-size: 1em; }
	.entry-content h6 { font-size: 1em; }
	.wp-block-media-text__content p { margin-top: 1em; }
	.wp-block-media-text > .wp-block-media-text__content { padding: 0 0; }
	.has-small-font-size { font-size: .9em; }
	}

.post-meta { font-size: .9em; margin-top: 60px; }
.entry-content { overflow-wrap: anywhere; }

.wp-block-image img, .wp-block-media-text__media img { border: 1px solid var(--color-border-soft); }
.wp-element-caption { font-size: .9em; font-weight: 700; } /* 写真のキャプション */
.wp-block-image :where(figcaption) { margin-bottom: 1em; margin-top: .25em; }
.has-text-align-center { text-align: center !important; }
.has-text-align-right { text-align: right !important; }
.wp-block-list li { margin-bottom: 0; }

/* ----- Googleドキュメント連携の際のTABLEのスタイル -------------------- */
.gdoc-table {
  border-collapse: collapse;
  width: 100%;
  margin: 1em 0;
}
.gdoc-td {
  border: 1px solid var(--color-border);
  padding: 8px 12px;
  vertical-align: top;
  line-height: 1.6;
}

/* ----- 動画埋め込み（video）の調整 -------------------- */
.wp-block-video video { border: 1px solid var(--color-border); }

/* ----- ギャラリーブロックの調整 -------------------- */
.testpage .wp-block-gallery.has-nested-images figure.wp-block-image img {
	display: block;
	width: 100%;
	max-width: 100% !important;
	height: auto;
	object-fit: cover;
	aspect-ratio: 1/1;
	}

/* ----- ギャラリーブロックのキャプション調整 -------------------- */
.wp-block-gallery.has-nested-images figure.wp-block-image figcaption, .wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption)::before {
	bottom: 0;
	left: 0;
	position: initial!important;
	right: 0;
}
.wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption)::before {
	-webkit-backdrop-filter: none;
	backdrop-filter: none;
	content: "";
	height: 100%;
	-webkit-mask-image: linear-gradient(0deg,var(--color-black) 20%,#0000);
	mask-image: linear-gradient(0deg,var(--color-black) 20%,#0000);
	max-height: 0%;
}
.wp-block-gallery.has-nested-images figcaption {
	flex-basis: 0%;
}
.wp-block-gallery.has-nested-images figure.wp-block-image figcaption {
	overflow: unset!important;
	background: none;
	box-sizing: border-box;
	color: var(--color-black);
	font-size: .9em;
	font-weight: 700;
	text-align: left;
	text-shadow: none;
	margin: 0;
	will-change: transform;
	padding-left: 0em;
	padding-right: 0em;
	padding-top: .5em;
	padding-bottom: 2em;
	height: 1em;
	max-height: 2em;
}

/* ----- 前の記事・次の記事 -------------------- */

.navigation.post-navigation { margin-top: 60px; }
.nav-links { font-size: .9em; display: flex; }
.nav-links div[class^="nav-"] { width: 50%; }
.nav-links .nav-next { margin-left: auto; }
.nav-links .nav-previous + .nav-next { margin-left: -1px; }
.nav-links a {
	position: relative; display: flex; align-items: center; justify-content: center; overflow-wrap: anywhere;
	width: 100%; height: 4em; border: 1px solid var(--color-primary); padding: .5em;
	}
.nav-links a:hover { background: var(--color-primary); color: var(--color-white); text-decoration: none; }
@media (max-width: 768px) {
	.nav-links a { height: 8em; line-height: 1.3em; }
	}
.nav-previous a { padding-left: 2em; }
.nav-next a { padding-right: 2em; }
.nav-previous a::before { content: "＜" / ""; position: absolute; left: .75em; top: 50%; transform: translateY(-50%); }
.nav-next a::after { content: "＞" / ""; position: absolute; right: .75em; top: 50%; transform: translateY(-50%); }

/* ************************************************************
アーカイブ
************************************************************ */

.list-exp { margin-bottom: 60px; text-align:justify; } /* アーカイブタイトル下の説明文 */
.blog-cat-list { padding-bottom:30px; }
.archive-list { list-style:none; padding-left: 0px;}
@media (max-width: 768px) {
	.blog-cat-list { padding-top:10px; padding-bottom:30px; }
}

/* ----- NEWラベル -------------------- */

/* .card-img は flex item として縮むと中の固定幅 IMG をはみ出させていた。
   overflow: hidden でズーム時の枠外を抑えつつ、flex-shrink: 0 で従来 IMG が
   見えていた幅を維持する */
/* .card-img は flex item として縮むと中の固定幅 IMG をはみ出させていた。
   overflow: hidden でズーム時の枠外を抑えつつ、flex-shrink: 0 で従来 IMG が
   見えていた幅を維持する。display: block は IMG 下に発生する inline baseline 由来
   の余白を消し、ホバー時のクリップ枠と IMG 寸法を一致させる */
.card-img { position: relative; width: auto; overflow: hidden; flex-shrink: 0; align-self: flex-start; border: 1px solid var(--color-border-image); }
.card-img img { transition: transform 0.4s ease; display: block; }
.archive-new { 
	position: absolute; top: 0; left: 0; color: var(--color-white); background: var(--color-warning);
	padding: 0 .4em; margin-top: 1px; margin-left: 1px; font-size: .9em; font-weight: 700;
}
@media (max-width: 768px) {
	.archive-new  { font-size: .8em; line-height: 1.6em; padding: 0 .2em; }
}

/* ----- ページネーション -------------------- */

.archive-pagenation { margin-top:60px; 	line-height: 31px; }
.archive-pagenation ul {
	display: flex; list-style: none; justify-content: center; padding-left: 0em; gap: .5em; margin-bottom: 0px;
}
.archive-pagenation li .page-numbers { display: inline-block; min-width: 2em; height: 2em; padding-top: .1em; text-align:center; font-size:1em; letter-spacing: 0em; text-align: center; }
.archive-pagenation li a { -webkit-transition: background-color .3s,color .3s; transition: background-color .3s,color .3s; text-decoration: none; background-color: var(--color-white); color: var(--color-primary); border:1px solid var(--color-primary) }
.archive-pagenation li a:hover { color:var(--color-white); background:var(--color-primary); text-decoration:none; }
.archive-pagenation .current { padding-top: .15em !important; background-color: var(--color-primary); color: var(--color-white); }

@media (max-width: 768px) {
	.archive-pagenation { margin-top:80px; 	margin-bottom:80px; line-height: 28px; }
	.archive-pagenation ul { display: flex; list-style: none; justify-content: center; font-size:.9em; letter-spacing: 0em; padding-left: 0em; gap: .5em; }
	.archive-pagenation li .page-numbers { display: inline-block; min-width: 2em; height: 2em; padding-top: 0; text-align: center; }
	.archive-pagenation { margin-top:60px; margin-bottom:0px; }
	.archive-pagenation .current { padding-top: .1em !important; }
	.archive-bottom-link { width: 90%; }
	}

/* ************************************************************
トップMV
************************************************************ */

.top-mv {
	overflow: hidden;
	max-width: 100%;
	height: auto;
	margin-inline: auto;
	margin-bottom: 20px;
	padding-bottom: 45px;
	padding-left: 0px;
	margin-top:0px;
	line-height: 0px;
	list-style: none;
	margin: 0;
	padding: 0;
	touch-action: pan-y;
	-webkit-overflow-scrolling: touch;
	}
.top-mv__item {
	overflow: hidden;
}
@media (max-width: 768px) {
	.top-mv { padding-left: 0px; padding-bottom: 40px; }
	}

.top-mv__img { margin:0 auto; width: 100%; }
.top-mv .slick-dots { bottom: 0; }
.top-mv .slick-dots li {
	position: relative;
	width: 15px;
	height: 15px;
	margin: 0 8px;
	}
.top-mv .slick-dots button {
	width: 15px;
	height: 15px;
	padding: 0;
	background: var(--color-slick-dot);
	}
.top-mv .slick-active button { background: var(--color-accent) !important; }

/* ----- slickスライダー -------------------- */

.slick-slider {
	position: relative;
	display: block;
	box-sizing: border-box;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-touch-callout: none;
	-khtml-user-select: none;
	-ms-touch-action: pan-y;
	touch-action: pan-y;
	-webkit-tap-highlight-color: transparent;
	}

.slick-slider * { outline: none; }
.slick-slider *:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }
.slick-list {
	position: relative;
	display: block;
	overflow: hidden;
	margin: 0;
	padding: 0;
	margin-bottom: 40px;
	}
@media (max-width: 768px) {
	.slick-list { margin-bottom: 0; }
}
.slick-list:focus { outline: none; }
.slick-list.dragging { cursor: pointer; cursor: hand; }
.slick-slider .slick-track,.slick-slider .slick-list {
	-webkit-transform: translate3d(0, 0, 0);
	-moz-transform: translate3d(0, 0, 0);
	-ms-transform: translate3d(0, 0, 0);
	-o-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	}

.slick-track { position: relative; top: 0; left: 0; display: block; margin-left: auto; margin-right: auto; }
.slick-track:before,.slick-track:after { display: table; content: ""; }

.slick-track:after { clear: both; }
.slick-loading .slick-track { visibility: hidden; }

.slick-slide { display: none; float: left; width:100%; 	min-height: 1px; 
	-webkit-backface-visibility: hidden; -webkit-transform-style: preserve-3d; /* スライド時のチラつき対応 */
	}
[dir=rtl] .slick-slide { float: right; }
.slick-slide img { display: block; width:100%; height: auto; image-rendering: auto; }
.slick-slide.slick-loading img { display: none; }
.slick-slide.dragging img { pointer-events: none; }
.slick-initialized .slick-slide { display: block; }
.slick-loading .slick-slide { visibility: hidden; }
.slick-vertical .slick-slide { display: block; height: auto; border: 1px solid transparent; }
.slick-arrow.slick-hidden { display: none; }
.slick-dotted.slick-slider { margin-bottom: 25px; }

/* 前後の矢印 */

.slick-prev,.slick-next {
	position: absolute;
	display: block;
	height: 50px;
	width: 50px;
	line-height: 0px;
	font-size: 0px;
	cursor: pointer;
	background: transparent;
	color: transparent;
	top: 50%;
	transform: translate(0, -50%);
	padding: 0;
	border: none;
	outline: none;
	}

.slick-prev:hover, .slick-prev:focus, .slick-next:hover, .slick-next:focus {
	outline: none;
	background: transparent;
	color: transparent;
	}
.slick-prev { left: -20px; }
.slick-next { right: -20px; }
.slick-dots {
	position: absolute;
	bottom: -20px;
	list-style: none;
	display: block;
	text-align: center;
	padding: 0;
	margin: 0;
	width: 100%;
	}
.slick-dots li {
	position: relative; display: inline-block; height: 10px; width: 10px; margin: 0 5px;
	padding: 0; cursor: pointer; }
.slick-dots li button {
	border: 0; background: var(--color-slick-dot); display: block; height: 10px; width: 10px;
	outline: none; line-height: 0px; font-size: 0px; padding: 5px; cursor: pointer; }
.slick-dots li button:focus,.slick-dots li button:hover { outline: none; }
.slick-dots li.slick-active button { background: var(--color-accent); }

/* slick 操作要素のキーボードフォーカス可視化。
   上の outline:none 群（.slick-list:focus / 矢印 / ドット）を :focus-visible で上書きする。
   記述順を後ろにして同詳細度の outline:none に勝たせる。
   .slick-list は overflow:hidden で外側の枠が見切れるため outline-offset を内側(-2px)に。 */
.slick-list:focus-visible { outline: 2px solid var(--color-primary); outline-offset: -2px; }
.slick-prev:focus-visible,
.slick-next:focus-visible,
.slick-dots li button:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }

/* ********** MVが一枚固定の場合（複数の場合はこの部分をコメントアウト） ****************************** */

.slick-dots { display: none; }
.top-mv { padding-bottom: 0px!important; margin-bottom: 60px !important; }
.slick-list { margin-bottom: 0; }
.slick-dotted.slick-slider { margin-bottom: 0 !important; }
@media (max-width: 600px) {
	.top-mv { margin-bottom: 30px !important; }
	}

/* ********** スマホでのMV画像読み込み時の修正 ****************************** */

@media (max-width: 600px) {
	.top-mv__item { aspect-ratio: 1000 / 1550; width: 100%; position: relative; }
	.top-mv__img,.top-mv picture,.slick-slider-container { width: 100%; height: 100%; object-fit: cover; display: block; }
	}

/* ************************************************************
フォーム関係
************************************************************ */

/* --- CF7 確認プラスの「戻る」ボタン（独自左矢印アイコン付き） --- */
.wpcf7-form-control.wpcf7-back.wpcf7c-elm-step2.wpcf7c-btn-back {
    width: 50%;
    margin: 0 auto;
    border: 1px solid var(--color-primary);

    /* 背景アイコンの設定（左矢印） */
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 256 512"%3E%3Cpath fill="%23fff" d="M31.7 239l136-136c9.4-9.4 24.6-9.4 33.9 0l22.6 22.6c9.4 9.4 9.4 24.6 0 33.9L127.9 256l96.4 96.4c9.4 9.4 9.4 24.6 0 33.9L201.7 409c-9.4 9.4-24.6 9.4-33.9 0l-136-136c-9.5-9.4-9.5-24.6-.1-34z"/%3E%3C/svg%3E');
    background-repeat: no-repeat;
    background-size: 15px;
    background-position: calc(50% - 3em) center;
}

.wpcf7-form-control.wpcf7-back.wpcf7c-elm-step2.wpcf7c-btn-back:hover {
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 256 512"%3E%3Cpath fill="%23003f88" d="M31.7 239l136-136c9.4-9.4 24.6-9.4 33.9 0l22.6 22.6c9.4 9.4 9.4 24.6 0 33.9L127.9 256l96.4 96.4c9.4 9.4 9.4 24.6 0 33.9L201.7 409c-9.4 9.4-24.6 9.4-33.9 0l-136-136c-9.5-9.4-9.5-24.6-.1-34z"/%3E%3C/svg%3E');
}

.simplebar-content-wrapper { background: var(--color-white)!important; }

.box-atenntion { margin-bottom: 10px; }
.box-atenntion-content { padding: 50px; border: none !important; background: var(--color-bg-subtle); }
.input-label-bold { font-weight: 700; background: none !important; }
input[type="submit"] { font-size: 1.5em!important; }
@media (max-width: 768px) {
.box-atenntion-content { padding: 10px; }
input[type="submit"] { font-size: 1.2em!important; }
}

.contact-accordion .accordion__item { border: 2px solid var(--color-primary); margin-bottom: 0; }
.contact-accordion .accordion__head { border: none; padding-top: 5px; padding-bottom: 5px; }
.contact-accordion .accordion__item .accordion__head::after {
	font-family: "FontAwesome"; content: "\f107" / "";
	display: inline-block; transform-origin: center; transition: transform 0.5s ease; }
.contact-accordion .accordion__item.active .accordion__head::after {
	transform: rotate(180deg); color: var(--color-primary) !important; }
.contact-accordion .accordion__item .accordion__head::after, .contact-accordion .accordion__item.active .accordion__head::after { position: absolute; top: 25px; right: 20px; font-size: 1.6em; color: var(--color-primary); }
.contact-accordion .qah2-2 { font-size: 1.5em; color: var(--color-primary); font-weight: 700; margin-top:15px; margin-bottom: 20px; padding-left: 30px; }
.contact-accordion .accordion__body { padding: 0 30px 0 30px !important; }
@media (max-width: 600px) { 
.contact-accordion .accordion__head { padding-top: 5px; }
.contact-accordion .qah2-2 { font-size: 1.2em; color: var(--color-primary); font-weight: 700; 
	margin-bottom: 5px !important; padding-left: 15px; margin-top: 5px !important; }
.contact-accordion .accordion__item .accordion__head::after,.contact-accordion .accordion__item.active .accordion__head::after
	{ top: 12px; right: 15px; font-size: 1.2em; color: var(--color-primary); }
.contact-accordion .accordion__body { padding: 0 20px 0 20px !important; }
}

legend { font-size: 1em; font-weight: 700; padding-left: 0; }


/* ************************************************************
 検索ボックス
************************************************************ */

.searchform { display: flex; }
.searchfield {
	width: 100%; padding:0 15px;/*プレースホルダーの位置調整*/
	background: var(--color-bg-subtle); border: 1px solid var(--color-primary)!important; outline:0;/*クリック時の青い枠線消す*/
}

.searchform input[type="text"] { 
	border: 1px solid var(--color-primary) !important; padding: .6em; width: calc(100% - 50px); font-size: 1em;
}
@media (max-width: 768px) {
.searchform input[type="text"] { 
	padding: .3em;
	width: calc(100% - 40px);
	font-size: .95em;
	margin-top: 4px;
	margin-bottom: 10px;
}
}

.searchsubmit {
	width: 50px;
	background :var(--color-white);
	border:none;
	color: var(--color-primary);
	border: solid var(--color-primary) ;
	border-width: 1px 1px 1px 0;
	font-size: 1em;
	cursor: pointer;
	padding: .2em;
	margin-top: 5px;
	margin-bottom: 5px;
}
@media (max-width: 768px) {
.searchsubmit {
	width: 40px;
	padding: .4em;
	margin-top: 4px;
	margin-bottom: 10px;
}
}

.searchsubmit:hover {
	background: var(--color-primary);/*背景カラー変更*/
}
.footer-element-left .searchbox { display:none; }
.searchbox { 
	
}
.serach-result-list {
  padding-left: 0em;
  margin-left: 1.3em;
}
.serach-result-list li::before {
  content: "●" / "";
  color: var(--color-accent);
  margin-right: .3em;
}
.serach-result-list li {
  font-size: 1em;
  text-indent: -1.3em;
}


/* ----- プライバシーポリシー連絡先リスト：justify を解除 -------------------- */
.privacy-iframe .privacy-contact-list,
.page-plivacypolicy .privacy-contact-list {
	text-align: left;
}


/* ----- プロフィールヒストリー：アコーディオン内の写真は PC でも正方形＋複数枚は縦に余白 -------------------- */
@media (min-width: 769px) {
	.accordion__list_prof .image-area > * + img { margin-top: 1em; }
	.accordion__list_prof .image-area img {
		height: auto;
		min-height: 0;
		aspect-ratio: 1 / 1;
	}
}

/* ----- module--youtube-c：動画フィード横スライダー（実験版） -------------------- */
.video-slide { margin-top: 30px; visibility: hidden; overflow: hidden; }
.video-slide.slick-initialized { visibility: visible; }
.video-slide__item { padding: 0 8px; box-sizing: border-box; }
.video-slide .slick-list { margin: 0 -8px; }
.video-slide .slick-track { display: flex !important; }
.video-slide .slick-slide { height: auto !important; display: flex; flex-direction: column; }
.video-slide .slick-slide > div { flex: 1; display: flex; flex-direction: column; }
.video-slide__item { flex: 1; display: flex; flex-direction: column; }
.video-slide__thumb img { transition: transform 0.4s ease; }
@media (hover: hover) {
	.video-slide__item:hover .video-slide__thumb img { transform: scale(1.04); opacity: 1; }
}
/* clip-path で枠内クリップ。overflow: hidden だと flex item として thumb が
   IMG の content size を尊重しなくなり縮んでしまうため clip-path を使用 */
.video-slide__thumb { position: relative; clip-path: inset(0); }
/* ズーム時も罫線を維持するため::afterを img の上(z-index:1)に重ねる */
.video-slide__thumb::after { content: "" / ""; position: absolute; inset: 0; border: 1px solid var(--color-border-image); pointer-events: none; z-index: 1; }
.video-slide__thumb img {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	background-color: var(--color-bg-subtle);
	box-sizing: border-box;
	display: block;
}
.video-slide__thumb .archive-new {
	position: absolute; top: 1px; left: 1px; z-index: 1;
}
.video-slide__body {
	background-color: var(--color-bg-subtle);
	padding: 10px;
	flex: 1;
}
.video-slide .slick-prev,
.video-slide .slick-next {
	width: 36px; height: 36px; z-index: 2;
	background-color: var(--color-primary);
}
.video-slide .slick-prev:hover,
.video-slide .slick-next:hover { background-color: var(--color-accent); }
.video-slide .slick-prev::before,
.video-slide .slick-next::before {
	content: "" / "";
	position: absolute; top: 50%; left: 50%;
	width: 10px; height: 10px;
	border-top: 2px solid var(--color-white);
	border-right: 2px solid var(--color-white);
	transform: translate(-50%, -50%) rotate(45deg);
	opacity: 1;
}
.video-slide .slick-prev::before { transform: translate(-30%, -50%) rotate(-135deg); }
.video-slide .slick-prev:hover::before,
.video-slide .slick-next:hover::before {
	border-top-color: var(--color-primary);
	border-right-color: var(--color-primary);
}
.video-slide .slick-prev { left: 0; }
.video-slide .slick-next { right: 0; }

@media (max-width: 768px) {
	.video-slide__item { padding: 0 6px; }
	.video-slide .slick-prev { left: 0; }
	.video-slide .slick-next { right: 0; }
}

/* ----- module--youtube-d：埋込センタースライダー（実験版） -------------------- */
.video-embed-slide { margin-top: 30px; visibility: hidden; }
.video-embed-slide.slick-initialized { visibility: visible; }
.video-embed-slide__item { padding: 0 8px; box-sizing: border-box; }
.video-embed-slide__frame {
	position: relative;
	aspect-ratio: 16 / 9;
	background-color: var(--color-black);
}
.video-embed-slide__frame iframe {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
}
/* 中央以外のスライドは少し暗くして主従関係を示す */
.video-embed-slide .slick-slide:not(.slick-current) .video-embed-slide__frame { opacity: 0.5; transition: opacity 0.3s ease; pointer-events: none; }
.video-embed-slide .slick-slide.slick-current .video-embed-slide__frame { opacity: 1; }

.video-embed-slide .slick-prev,
.video-embed-slide .slick-next {
	width: 36px; height: 36px; z-index: 2;
	background-color: var(--color-primary);
}
.video-embed-slide .slick-prev:hover,
.video-embed-slide .slick-next:hover { background-color: var(--color-accent); }
.video-embed-slide .slick-prev::before,
.video-embed-slide .slick-next::before {
	content: "" / "";
	position: absolute; top: 50%; left: 50%;
	width: 10px; height: 10px;
	border-top: 2px solid var(--color-white);
	border-right: 2px solid var(--color-white);
	transform: translate(-50%, -50%) rotate(45deg);
	opacity: 1;
}
.video-embed-slide .slick-prev::before { transform: translate(-30%, -50%) rotate(-135deg); }
.video-embed-slide .slick-prev:hover::before,
.video-embed-slide .slick-next:hover::before {
	border-top-color: var(--color-primary);
	border-right-color: var(--color-primary);
}
.video-embed-slide .slick-prev { left: 0; }
.video-embed-slide .slick-next { right: 0; }

@media (max-width: 768px) {
	.video-embed-slide__item { padding: 0 4px; }
	.video-embed-slide .slick-prev,
	.video-embed-slide .slick-next { width: 35px; height: 35px; }
	.video-embed-slide .slick-prev::before,
	.video-embed-slide .slick-next::before { width: 6px; height: 6px; }
	.video-embed-slide .slick-prev { left: 0; }
	.video-embed-slide .slick-next { right: 0; }
}

/* ---- 動画ライトボックス（youtube-c） -------------------- */
/* viewport が小さい/低い時に close ボタンが画面外に出ないよう、
   width を「90vw / 70vh を 16:9 で換算した幅 / 960px」の min に制限する。
   結果として高さが 70vh を超えなくなり、その下の close ボタンも収まる */
.video-lightbox .video-lightbox__frame {
	width: min(960px, 90vw, calc(70vh * 16 / 9));
	max-width: 100%;
}
.video-lightbox__player {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	background: var(--color-black);
}
.video-lightbox__player iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}
.video-lightbox__caption:empty { display: none; }

@media (max-width: 768px) {
	/* SP では枠を画面幅 90%、16:9 アスペクト比は維持。
	   landscape 時に高さが足りなくなる場合のため、70vh 相当の幅で上限 */
	.video-lightbox .lightbox-content { max-width: 90%; width: 90%; }
	.video-lightbox .video-lightbox__frame { width: min(100%, calc(70vh * 16 / 9)); }
	.video-lightbox .close-button { left: calc(50% - 20px); }
}

/* ---- ポッドキャスト個別調整（podcast） --------------------------- */
/* ポッドキャスト画像は Apple/Spotify 仕様で常に正方形なのでサムネも 1:1 で出す */
.module--podcast .video-slide__thumb img { aspect-ratio: 1 / 1; }

/* 文字起こし一覧：ボタンではなくサイト標準のテキストリンク（既定 a 色＋hover 下線に委ねる）。
   外部リンクアイコンだけは出さない。 */
.module-feed-podcast .podcast-tx-link { text-align: center; margin-top: 50px; margin-bottom: 0; }
.module-feed-podcast .podcast-tx-link + .more { margin-top: 14px; }
.podcast-tx-link a[target="_blank"]::after { content: none; }

.podcast-list__duration {
	margin-left: 0.6em;
	white-space: nowrap;
}
.podcast-list__duration .podcast-list__duration-icon { margin-right: 0.2em; }

/* ---- ポッドキャストライトボックス --------------------------------- */
.podcast-lightbox .podcast-lightbox__frame {
	width: min(560px, 92vw);
	max-width: 100%;
	background: var(--color-bg);
	padding: 24px;
	box-sizing: border-box;
}
.podcast-lightbox .podcast-lightbox__caption {
	margin: 0 0 16px;
	font-weight: 700;
	line-height: 1.4;
	text-align: left;
}
.podcast-lightbox__caption:empty { display: none; }
.podcast-lightbox__player { width: 100%; }
.podcast-lightbox__audio { display: none; } /* 表示はカスタム UI（.podcast-player）に任せる */

/* カスタムオーディオプレーヤー（サムネ／タイトル／再生・スキップ・速度／シークバー） */
.podcast-player {
	display: flex;
	flex-direction: column;
	gap: 14px;
	width: 100%;
}

/* 上段：サムネ＋タイトル＋速度切替 */
.podcast-player__meta {
	display: flex;
	align-items: center;
	gap: 12px;
	min-width: 0;
}
.podcast-player__thumb {
	flex: 0 0 auto;
	width: 64px;
	height: 64px;
	object-fit: cover;
	background: var(--color-bg-subtle);
	border: 1px solid var(--color-border-image);
	display: block;
}
.podcast-player__titles {
	flex: 1 1 auto;
	min-width: 0;
}
.podcast-player__title {
	margin: 0;
	font-weight: 700;
	line-height: 1.4;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	word-break: break-word;
}
/* タイトル下の「文字起こしを読む」リンク（該当回がある時だけ表示・別タブ） */
/* MP3 ダウンロードボタン：機能は残し UI のみ隠す（再有効化はこの display 行を外す） */
.podcast-player__download { display: none; }

/* コントロール行右端の「テキスト」ボタン（旧 MP3 ダウンロードと同デザイン・同位置） */
.podcast-player__transcript {
	flex: 0 0 auto;
	min-width: 44px;
	height: 32px;
	padding: 0 10px;
	display: inline-flex; align-items: center; justify-content: center; gap: 5px;
	font-size: 0.9em;
	font-weight: 700;
	line-height: 1;
	color: var(--color-primary);
	background: transparent;
	border: 1px solid var(--color-primary);
	border-radius: 16px;
	text-decoration: none !important; /* グローバル a:hover の下線を打ち消す（タッチ含む） */
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
}
.podcast-player__controls .podcast-player__transcript {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	margin: 0;
}
.podcast-player__transcript[hidden] { display: none; }
/* ホバー効果は実マウスデバイスのみ（タッチ端末で hover が残るのを防ぐ） */
@media (hover: hover) and (pointer: fine) {
	.podcast-player__transcript:hover {
		background: var(--color-primary);
		color: var(--color-white);
		text-decoration: none;
	}
}
.podcast-player__rate {
	flex: 0 0 auto;
	width: auto !important; /* グローバル button { width:100% } 上書き */
	min-width: 44px;
	height: 32px;
	padding: 0 10px !important;
	font-size: 0.9em;
	font-weight: 700;
	background: transparent !important;
	color: var(--color-primary) !important;
	border: 1px solid var(--color-primary) !important;
	border-radius: 16px !important;
	cursor: pointer;
	line-height: 1;
	transition: background 0.2s, color 0.2s;
}
/* ホバー効果は実マウスデバイスのみ（タッチ端末で hover が残るのを防ぐ） */
@media (hover: hover) and (pointer: fine) {
	.podcast-player__rate:hover {
		background: var(--color-primary) !important;
		color: var(--color-white) !important;
	}
}

/* 中段：スキップ・再生（速度ボタンは絶対配置で左端へ。再生ボタンの中央位置は維持） */
.podcast-player__controls {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 24px;
}
.podcast-player__controls .podcast-player__rate {
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	margin: 0;
}
.podcast-player__skip {
	position: relative;
	width: 66px;
	height: 66px;
	padding: 0 !important;
	background: transparent !important;
	color: var(--color-primary) !important;
	border: 0 !important;
	border-radius: 0 !important;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 33px;
	line-height: 1;
}
@media (hover: hover) and (pointer: fine) {
	.podcast-player__skip:hover { color: var(--color-accent) !important; background: transparent !important; }
}
.podcast-player__skip-num {
	position: absolute;
	left: 0; right: 0; top: 50%;
	transform: translateY(-50%);
	font-size: 13px;
	font-weight: 700;
	text-align: center;
	pointer-events: none;
	font-family: var(--font-base, inherit);
}
/* プレーヤーの再生ボタンは機能上 円形に（border-radius:0 ルールの明示例外） */
.podcast-player__playbtn {
	width: 56px;
	height: 56px;
	border-radius: 50% !important;
	background: var(--color-primary);
	color: var(--color-white);
	border: 0;
	padding: 0 !important;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	line-height: 1;
	transition: background 0.2s;
}
@media (hover: hover) and (pointer: fine) {
	.podcast-player__playbtn:hover {
		background: var(--color-accent);
		color: var(--color-primary);
	}
}
.podcast-player__playbtn .fa-play { padding-left: 4px; } /* 三角形の視覚中央寄せ */

/* 下段：進捗 */
.podcast-player__progress {
	display: flex;
	align-items: center;
	gap: 10px;
}
.podcast-player__time {
	flex: 0 0 auto;
	min-width: 3em;
	font-size: 0.85em;
	color: var(--color-text-muted);
	font-variant-numeric: tabular-nums;
}
.podcast-player__time--current { text-align: right; }
.podcast-player__time--total { text-align: left; }
.podcast-player__seek {
	flex: 1 1 auto;
	-webkit-appearance: none;
	appearance: none;
	height: 4px;
	background: linear-gradient(to right,
		var(--color-primary) 0%,
		var(--color-primary) var(--fill, 0%),
		var(--color-border) var(--fill, 0%),
		var(--color-border) 100%);
	outline: none;
	cursor: pointer;
	margin: 0;
}
.podcast-player__seek::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--color-primary);
	border: 0;
	cursor: pointer;
}
.podcast-player__seek::-moz-range-thumb {
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--color-primary);
	border: 0;
	cursor: pointer;
}
.podcast-player__seek:focus-visible::-webkit-slider-thumb {
	box-shadow: 0 0 0 3px rgba(0, 63, 136, 0.3);
}
.podcast-player__seek:focus-visible::-moz-range-thumb {
	box-shadow: 0 0 0 3px rgba(0, 63, 136, 0.3);
}

@media (max-width: 768px) {
	/* 「テキスト」ボタンが MP3 より幅広いため、15秒スキップを左右それぞれ 20px 内側（再生ボタン側）へ寄せて重なりを防ぐ（既定 20px → 0） */
	.podcast-player__controls { gap: 0; }
	.podcast-player__playbtn { width: 52px; height: 52px; font-size: 18px; }
	.podcast-player__skip { width: 60px; height: 60px; font-size: 30px; }
	.podcast-player__skip-num { font-size: 12px; }
	.podcast-player__thumb { width: 60px; height: 60px; }
	.podcast-player__time { font-size: 0.8em; min-width: 2.6em; }
}

@media (max-width: 768px) {
	.podcast-lightbox .lightbox-content { max-width: 92%; width: 92%; }
	.podcast-lightbox .podcast-lightbox__frame { width: 100%; padding: 16px; }
	.podcast-lightbox .close-button { left: calc(50% - 20px); }
}

/* ====================================================
   prefers-reduced-motion 対応
   OS / ブラウザで「動きを減らす」設定をしている利用者向け：
   transition / animation を実質ゼロ秒に、スクロールも即座にジャンプ。
   ==================================================== */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* ====================================================
   旧 custom.css から移設（base 標準スタイル）
   custom.css は展開後の各サイト固有調整専用とし、base では空に保つ。
   ※ 元 custom.css は style.css の後に読み込まれていたため、
      末尾に置いて従来の優先順位（後勝ち）を維持する。
   ==================================================== */
.top-timeline {
  background: var(--color-bg-subtle);
  padding-left: 0; padding-right: 0; padding-top: 0;
  padding-bottom: 0; margin-top: 60px;
}
.eapps-twitter-feed .eui-widget-title {
  padding-bottom: 0;
  margin-top: 20px !important; margin-bottom: 20px !important;
  font-size: 1.2em !important;
  font-weight: 700;
  text-align: center;
  color: currentColor;
}
@media (max-width: 768px) {
	.top-timeline { margin-top: 30px; }
	.eapps-twitter-feed .eui-widget-title { margin-bottom: 14px !important; }
}
/* ********** タブ切り替え ****************************** */

.custom-tabs-container { width: 100%; margin: 20px 0; }
.tab-menu { display: flex; flex-wrap: wrap; width: 100%; list-style: none; padding: 0; margin: 0; }
.tab-item { font-size: 1.2em; text-align: center; padding: 15px 5px; cursor: pointer; background: var(--color-bg-subtle);
    border: 2px solid var(--color-border-image); box-sizing: border-box; font-weight: bold; color: var(--color-text-muted); transition: background 0.2s; }
.tab-content { display: none; }
.tab-content.active { display: block; }

/* --- PC表示 (769px以上) * アクティブタブの下線を消して、コンテンツと一体化  --- */
@media (min-width: 769px) {
    .tab-item { font-size: 1.2em; flex: 1; margin-right: -1px; position: relative; z-index: 1; }
    .tab-item.active { background: var(--color-white); color: var(--color-black); border-bottom-color: transparent; /* 下線を消す */ z-index: 3; }
    .tab-item.active::after {
        content: ""; position: absolute; bottom: -1px; left: 0; width: 100%; height: 2px; background: var(--color-white); }
    .tab-content-wrapper {
        border: 2px solid var(--color-border-image); background: var(--color-white); padding: 40px; margin-top: -2px; position: relative; z-index: 2; }
}

/* --- スマホ表示 (768px以下) * タブの罫線はすべて維持し、コンテンツと接する  --- */
@media (max-width: 768px) {
    .tab-item { font-size: 1em; flex: 0 0 50%; /* 1行に2つ */ margin-right: -2px; margin-bottom: -2px; }
    /* スマホではアクティブでも「枠線の形」は変えない */
    .tab-item.active {
        background: var(--color-white); /* 色の変化だけで状態を示す */ color: var(--color-black);
        border: 2px solid var(--color-border-image); /* 境界線を維持 */ border-bottom: 2px solid var(--color-white);
    }
    /* スマホではPC用の「線を消すための疑似要素」を無効化 */
    .tab-item.active::after { display: none; }
/*  .tab-content-wrapper { border: 1px solid var(--color-border); background: var(--color-white); padding: 20px; margin-top: -1px; } */
}

/* --- アニメーションの設定 --- */
.tab-content.active { display: block; animation: tabFadeIn 0.5s ease; /* 0.5秒かけて実行 */ }
@keyframes tabFadeIn { 0% { opacity: 0; } 100% { opacity: 1; } }

/* ========== バナー ========== */
.banner-list { display: flex; flex-wrap: wrap; gap: 14px; list-style: none; padding: 0; justify-content: center; }
.banner-item { width: 24%; }
.banner-item a { display: block; overflow: hidden; }
.banner-item img { width: 100%; aspect-ratio: 1/1; object-fit: cover; display: block; border: none; transition: transform 0.4s ease; }
@media (hover: hover) {
    .banner-item a:hover img { transform: scale(1.04); opacity: 1; }
}
.banner-item a[target="_blank"]::after { content: none; }

@media (max-width: 768px) {
    .banner-list--multiple { display: block; }
    .banner-item { width: 100%; }
    .banner-item img { width: 100%; aspect-ratio: 1/1; object-fit: cover; }
    .module-banner { padding-top: 5px; padding-bottom: 0; }
    /* SP時、複数バナーのスライダーにドットを表示（グローバルの display:none を打ち消し） */
    .banner-list--multiple.slick-dotted { margin-bottom: 0; }
    .banner-list--multiple ~ .slick-dots,
    .banner-list--multiple .slick-dots,
    .module-banner .slick-dots { display: flex; justify-content: center; gap: 8px; padding: 10px 0 0; margin: 0; position: static; }
    .module-banner .slick-dots li { margin: 0; padding: 0; width: auto; height: auto; }
    .module-banner .slick-dots li button { width: 10px; height: 10px; padding: 0; }
}
@media (min-width: 769px) {
    .module-banner { padding-top: 20px; }
}

/* ========== 広報紙アーカイブ（v1.4 追加分） ========== */
.entry__ttl.entry__ttl_press {
  font-size: 1.1em;
  font-weight:700;
}

/* 広報紙「内容説明など」(wysiwyg) のリスト：.member-prof-spec ul li と同スタイル */
/* 親の .grid-container li / .grid-container li:last-child の罫線・余白ルールを打ち消す */
.press-txt ul { list-style: none; padding-left: 0; margin: 0 0 .85em; }
.press-txt ol { list-style: decimal; padding-left: 1.5em; margin: 0 0 .85em; }
.grid-container .press-txt li,
.grid-container .press-txt li:last-child { display: list-item; padding: 0; border: 0; margin-bottom: 0; line-height: 1.5em; }
.grid-container .press-txt ul li,
.grid-container .press-txt ul li:last-child {
  position: relative;
  padding-left: 1.3em;
  font-size: 1em;
}
.press-txt ul li::before {
  content: "●" / "";
  color: var(--color-accent);
  position: absolute;
  left: 0;
  top: 0;
}

/* CTF: 引用リポストのテキスト幅を100%に */
#ctf .ctf-quoted-tweet .ctf-tc-summary-info,
#ctf .ctf-twitter-card .ctf-tc-summary-info {
  width: 100% !important;
}

/* CTF: アバター画像を円形に */
#ctf .ctf-author-avatar,
#ctf_lightbox .ctf-author-avatar {
  border-radius: 50%;
}

/* CTF: SimpleBar ラッパーで囲んでプライバシーポリシー風スクロールバーを実現 */
.ctf-simplebar-wrap {
  height: 600px;
  border: 1px solid var(--color-border-image);
}
.ctf-simplebar-wrap #ctf.ctf-fixed-height {
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}
.ctf-simplebar-wrap .simplebar-content-wrapper { background: transparent !important; }


/* CTF: 「Xで見る」リンクを太字化（hover でグローバル下線が出る） */
#ctf .ctf-twitterlink {
  color: var(--color-primary) !important;
  font-weight: 700;
}


/* Custom Twitter Feeds: スレッド展開ボタン非表示 */
.ctf-btn-show-threads {
  display: none;
}


/* CTF: リプライアイコン非表示 */
#ctf .ctf-tweet-actions .ctf-reply {
  display: none;
}

/* CTF: 日付（リンク無効化後）のスタイル */
#ctf .ctf-tweet-date {
  cursor: default;
  text-decoration: none !important;
}
#ctf .ctf-tweet-date:hover {
  text-decoration: none !important;
}


/* CTF: 引用ツイートのカード画像高さ調整 */
#ctf .ctf-tc-image {
  height: 200px;
}


/* timeline-x2: Elfsight 内部の固定高さを解除し SimpleBar に委ねる */
.module--timeline-x2 [class^="elfsight-app-"],
.module--timeline-x2 .eapps-twitter-feed-container,
.module--timeline-x2 .eapps-twitter-feed-inner,
.module--timeline-x2 .eapps-twitter-feed-posts,
.module--timeline-x2 .eapps-twitter-feed-posts-container {
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

/* timeline-x2: Elfsight「投稿をさらに表示」ボタンをテーマ標準色に */
.module--timeline-x2 .eapps-twitter-feed-posts-show-more {
  background: var(--color-primary) !important;
  color: #fff !important;
  border-color: var(--color-primary) !important;
}
.module--timeline-x2 .eapps-twitter-feed-posts-show-more:hover {
  background: var(--color-accent) !important;
  color: var(--color-primary) !important;
  border-color: var(--color-accent) !important;
}
