/*
Theme Name: Tanaka Theme Child
Description: 田中産婦人科専用子テーマ。親テーマ「twentytwentyfive」をベースに、医療機関向けのカスタマイズを最小限で実装します。
Author: Tanaka Ladies Clinic
Template: twentytwentyfive
Version: 1.0.0
Text Domain: tanaka-theme-child
*/

/* ========================================
   基本方針
   ========================================
   - 親テーマ twentytwentyfive のデザインを尊重
   - 最小限の上書きでカスタマイズ
   - 医療機関として必要な機能のみ追加
   ======================================== */

/* 親テーマのスタイルを読み込み */
@import url('../twentytwentyfive/style.css');

/* ========================================
   基本カラーの設定
   ======================================== */

:root {
	--wp--preset--color--background: #ffe8f4;
	--tanaka-bg-color: #ffe8f4;
	--tanaka-text-color: #676767; /* サイト全体のテキストカラー */
}

/* サイト全体の黒色を#676767に上書き */
body,
body * {
	color: inherit;
}

body {
	color: var(--tanaka-text-color, #676767);
}

/* 旧デフォルトヘッダーの非表示（blockテーマと二重表示防止） */
#header,
#headerimg {
	display: none !important;
}
#header + hr,
#headerimg + hr {
	display: none !important;
}

/* 旧デフォルトフッターの非表示 */
hr + #footer,
#footer,
#footer * {
	display: none !important;
}

/* 親テーマの黒色指定を上書き */
p, h1, h2, h3, h4, h5, h6, 
.wp-block-post-title,
.wp-block-post-title a,
.wp-block-post-content,
.wp-block-post-content p,
.wp-block-post-content a:not(.wp-block-button__link),
.site-title a,
.site-description,
.entry-title,
.entry-content,
.entry-content p,
.entry-content a:not(.wp-block-button__link),
.wp-block-heading,
.wp-block-paragraph,
.wp-block-list,
.wp-block-list li {
	color: var(--tanaka-text-color, #676767) !important;
}

body {
	background-color: var(--tanaka-bg-color);
	position: relative;
	overflow-x: hidden;
	width: 100%;
}

/* ========================================
   背景画像の設定
   ======================================== */

body::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 50%;
	height: 50%;
	background-image: url('/wp-content/themes/tanaka-theme-child/templates/img/back001.png');
	background-position: left top;
	background-repeat: no-repeat;
	background-size: contain;
	opacity: 0.5;
	z-index: -1;
	pointer-events: none;
}

@media (max-width: 768px) {
	body::before {
		width: 50%;
		height: 50%;
	}
}

/* ========================================
   トップページ用スタイル
   ======================================== */

.tanaka-hero-section {
	text-align: center;
}

.tanaka-cta-section {
	text-align: center;
}

/* ヒーロー画像セクション（編集不可） - スライドショー */
.tanaka-hero-image-section {
	width: 100%;
	margin: 0;
	padding: 0;
	overflow: hidden;
	position: relative;
	display: flex;
	justify-content: flex-end;
	min-height: 400px;
}

/* 診療時間表の親要素に余白を確保（モバイル表示時） */
.tanaka-hero-image-section::after {
	content: '';
	display: none;
}

/* キャッチコピー（スライドショーの上に重ねる） */
.tanaka-hero-catchcopy {
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	padding: var(--wp--preset--spacing--60);
	display: flex;
	align-items: center;
	justify-content: flex-start;
	box-sizing: border-box;
	z-index: 10;
	pointer-events: none;
	background-color: transparent;
    font-family: "M PLUS Rounded 1c";
}

.tanaka-hero-catchcopy-content {
	text-align: left;
	pointer-events: auto;
	width: 100%;
	position: relative;
	z-index: 11;
}

.tanaka-hero-catchcopy-main {
	font-size: clamp(1.5rem, 4vw, 2.5rem); /* 画面サイズに応じて可変、比率を維持 */
	font-weight: 600;
	color: #cc6e6e;
	margin: 0 0 clamp(1rem, 3vw, 1.875rem) 0; /* 間隔も比率を維持 */
	line-height: 0;
	letter-spacing: 0.05em;
	-webkit-text-stroke: 8px #ffffff; /* 白枠 */
	paint-order: stroke fill; /* ストロークを先に描画してからテキストを描画 */
}

.tanaka-hero-catchcopy-sub {
	font-size: clamp(1.2rem, 3vw, 1.8rem); /* 画面サイズに応じて可変、比率を維持 */
	font-weight: 400;
	color: #cc6e6e;
	margin: 0;
	line-height: 1.8;
	letter-spacing: 0.08em;
	padding-left: 0;
	-webkit-text-stroke: 6px #ffffff; /* 白枠（細めに調整） */
	paint-order: stroke fill; /* ストロークを先に描画してからテキストを描画 */
}


.tanaka-hero-slider {
    width: 70%;
    position: relative;
    overflow: hidden;
    height: 400px;
    border-radius: 10rem 0 0 0; /* 左上のみ角丸 */
    z-index: 1;
}

.tanaka-hero-slides {
	width: 100%;
	height: 100%;
	position: relative;
	z-index: 1;
}

.tanaka-hero-slide {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	transition: opacity 1.5s ease-in-out;
	z-index: 1;
	pointer-events: none;
}

.tanaka-hero-slide.active {
	opacity: 1;
	z-index: 1;
	pointer-events: auto;
}

.tanaka-hero-image {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

.tanaka-hero-image-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #ffe8f4 0%, #ffd4eb 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #626262;
	font-size: 1.5rem;
	font-weight: 400;
}

/* スライドインジケーター */
.tanaka-hero-indicators {
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 10px;
	z-index: 15;
}

.tanaka-hero-indicator {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	border: 2px solid #ffffff;
	background-color: transparent;
	cursor: pointer;
	padding: 0;
	transition: background-color 0.3s ease;
}

.tanaka-hero-indicator.active {
	background-color: #ffffff;
}

.tanaka-hero-indicator:hover {
	background-color: rgba(255, 255, 255, 0.7);
}


@media (max-width: 768px) {
	.tanaka-hero-image-section {
		min-height: 280px;
		justify-content: flex-end ; /* スライドショーを右寄せに維持 */
		flex-direction: row ; /* 横並びを維持 */
	}
	
	.tanaka-hero-catchcopy {
		top: 80px ;
		position: absolute ; /* 絶対配置を維持 */
		width: auto ;
		height: auto;
        padding: 3%;
	}
	
	.tanaka-hero-catchcopy-content {
		text-align: left ; /* 左寄せを維持 */
	}
	
	.tanaka-hero-catchcopy-main {
		-webkit-text-stroke: 6px #ffffff; /* レスポンシブでも白枠を維持 */
		paint-order: stroke fill;
	}
	
	.tanaka-hero-catchcopy-sub {
		-webkit-text-stroke: 4px #ffffff; /* レスポンシブでも白枠を維持 */
		paint-order: stroke fill;
	}
	
	.tanaka-hero-image-section .tanaka-hero-slider {
		width: 80%;
		height: 280px;
		order: 0 ; 
		flex: 0 0 80%; 
		max-width: 80%; 
	}
	
	.tanaka-hero-image-placeholder {
		font-size: 1.2rem;
	}
	
	.tanaka-hero-indicators {
		bottom: 10px;
		gap: 8px;
	}
	
	.tanaka-hero-indicator {
		width: 10px;
		height: 10px;
	}
}

/* ========================================
   特徴ブロック（女性医師・アクセス・駐車場）
   ======================================== */

.tanaka-features-section {
	position: absolute;
	top: 400px;
	right: -80px;
	width: 35%;
	max-width: 100%;
	box-sizing: border-box;
	padding: 0 var(--wp--preset--spacing--60);
	z-index: 100;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20);
}

.tanaka-feature-item {
	background-color: #ffffff;
	border: 2px solid #ffffff;
	border-radius: 0.5rem;
	padding: var(--wp--preset--spacing--20) var(--wp--preset--spacing--30);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	box-sizing: border-box;
}

.tanaka-feature-text {
	margin: 0;
	color: #676767;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.6;
	text-align: center;
}

@media (max-width: 768px) {
	.tanaka-features-section {
		position: absolute;
        top: 200px;
        right: 0; /* 画面右端に貼り付ける */
        width: 30%;
        padding: var(--wp--preset--spacing--30) 0 var(--wp--preset--spacing--30) var(--wp--preset--spacing--25); /* 右側余白をなくす */
        margin-top: var(--wp--preset--spacing--30);
	}
	
	.tanaka-feature-item {
		padding: var(--wp--preset--spacing--15) var(--wp--preset--spacing--20);
		border-radius: 0.5rem 0 0 0.5rem; /* 右側だけ角丸をなくす */
	}
	
	.tanaka-feature-text {
		font-size: 0.9rem;
	}
}

/* ========================================
   NEWS一覧セクション
   ======================================== */

.tanaka-news-section {
	width: 70%;
	margin: 100px auto 0;
	padding: 0;
	clear: both;
	box-sizing: border-box;
}

.tanaka-news-title {
	margin: 0 0 var(--wp--preset--spacing--30) 0;
	text-align: left;
	width: 30%;
}

.tanaka-news-title-img {
	max-width: 100%;
	height: auto;
	display: block;
}

.tanaka-news-list {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--15);
}

.tanaka-news-item {
		border-bottom: 1px solid #e0e0e0;
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		gap: var(--wp--preset--spacing--20);
		padding-bottom: 0.5rem;
		margin-bottom: 0.5rem;
}

.tanaka-news-date-title {
	flex: 1;
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: var(--wp--preset--spacing--20);
	min-width: 0;
}

.tanaka-news-date {
	font-size: 0.85rem;
	color: #676767;
	font-weight: 400;
	flex-shrink: 0;
	white-space: nowrap;
}

.tanaka-news-title-link {
	flex: 1;
	min-width: 0; /* テキストのオーバーフローを防ぐ */
}

.tanaka-news-post-title {
	margin: 0;
	font-weight: 500;
	line-height: 1.5;
}

.tanaka-news-post-title a {
	color: #676767;
	text-decoration: none;
}

.tanaka-news-more {
	flex-shrink: 0;
}

.tanaka-news-more-btn {
	display: inline-block;
	background-color: #eb85a8;
	color: #ffffff;
	border-radius: 3rem;
	padding: 0.4rem 1.2rem;
	text-decoration: none;
	font-size: 0.85rem;
	font-weight: 500;
	white-space: nowrap;
}

.tanaka-news-empty {
	color: #676767;
	font-size: 1rem;
	text-align: center;
	padding: var(--wp--preset--spacing--40) 0;
}

.tanaka-news-more-link {
	text-align: center;
	margin-top: var(--wp--preset--spacing--30);
}

.tanaka-news-more-link-btn {
	display: inline-block;
	color: #676767;
	text-decoration: underline;
	font-weight: 500;
	transition: opacity 0.3s ease;
}

.tanaka-news-more-link-btn:hover {
	opacity: 0.7;
}

@media (max-width: 768px) {
	.tanaka-news-section {
		width: 90%;
		margin: 60px auto 0;
		padding: 0 var(--wp--preset--spacing--20);
		clear: both;
		box-sizing: border-box;
	}
	
	.tanaka-news-title {
		margin-bottom: var(--wp--preset--spacing--25);
	}
	
	.tanaka-news-title-img {
		max-width: 100%;
		height: auto;
	}
	
	.tanaka-news-item {
		gap: var(--wp--preset--spacing--15);
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}
	
	.tanaka-news-date-title {
		flex: 1;
		flex-direction: row;
		align-items: center;
		gap: var(--wp--preset--spacing--15);
		min-width: 0;
	}
	
	.tanaka-news-date {
		font-size: 0.8rem;
		flex-shrink: 0;
		white-space: nowrap;
	}
	
	.tanaka-news-title-link {
		flex: 1;
		min-width: 0;
	}
	
	.tanaka-news-post-title {
		font-size: 0.9rem;
		margin-left: 1rem;
	}
	
	.tanaka-news-more {
		flex-shrink: 0;
		text-align: right;
	}
	
	.tanaka-news-more-btn {
		padding: 0.35rem 1rem;
		font-size: 0.8rem;
	}
	
	.tanaka-news-more-link {
		margin-top: var(--wp--preset--spacing--20);
	}
	
	.tanaka-news-more-link-btn {
		font-size: 0.85rem;
	}
}

/* ========================================
   MENU一覧セクション
   ======================================== */

.tanaka-menu-section {
	/* width: 70%; */
	margin: 100px auto 0;
	padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--60);
	clear: both;
	box-sizing: border-box;
	background-color: #ffffff;
	border-radius: 0.5rem;
}

.tanaka-menu-title {
	margin: 0 auto var(--wp--preset--spacing--30) auto;
	text-align: center;
	width: 30%;
	background-color: #ffffff;
	padding: var(--wp--preset--spacing--20);
	border-radius: 0.5rem;
	box-sizing: border-box;
}

.tanaka-menu-title-img {
	max-width: 100%;
	height: auto;
	display: block;
}

.tanaka-menu-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--wp--preset--spacing--30);
	width: 100%;
}

.tanaka-menu-item {
	background-color: #ffffff;
	border: 2px solid #ffe8f5;
	border-radius: 0.5rem;
	padding: 10px;
	overflow: hidden;
	transition: box-shadow 0.3s ease;
	aspect-ratio: 3 / 4; /* 縦長にしてイラストを収める */
	display: flex;
	flex-direction: column;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.tanaka-menu-item:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.tanaka-menu-item-link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
}

.tanaka-menu-item-image {
	width: 100%;
	height: 60%;
	overflow: hidden;
	background-color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
}

.tanaka-menu-item-image-link {
	display: block;
	height: 100%;
	text-decoration: none;
}

.tanaka-menu-img {
	width: 100%;
	height: 100%;
	object-fit: contain; /* イラストをトリミングせず表示 */
	display: block;
}

.tanaka-menu-item-content {
	padding: var(--wp--preset--spacing--20);
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: #ffffff;
	gap: 0.5rem;
}

.tanaka-menu-item-title {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 600;
	color: #676767;
	text-align: center;
	line-height: 1.4;
}

.tanaka-menu-item-text {
	margin: 0;
	font-size: 0.85rem;
	font-weight: 400;
	color: #676767;
	text-align: center;
	line-height: 1.4;
	opacity: 0.8;
}

.tanaka-menu-more-btn {
	display: inline-block;
	background-color: #eb85a8;
	color: #ffffff;
	border-radius: 3rem;
	padding: 0.4rem 1.2rem;
	text-decoration: none;
	font-size: 0.85rem;
	font-weight: 500;
	white-space: nowrap;
}

.tanaka-menu-empty {
	color: #676767;
	font-size: 1rem;
	text-align: center;
	padding: var(--wp--preset--spacing--40) 0;
	grid-column: 1 / -1;
}

@media (max-width: 768px) {
	.tanaka-menu-section {
        margin: 60px auto 0;
		padding: 2rem;
		clear: both;
        box-sizing: border-box;
        background-color: #ffffff;
        border-radius: 0;
	}
	
	.tanaka-menu-item {
		aspect-ratio: 2 / 3; /* モバイルも縦長でトリミング防止 */
	}
	
	.tanaka-menu-title {
		width: 30%;
        text-align: center;
        background-color: #ffffff;
        padding: var(--wp--preset--spacing--15);
        border-radius: 0.5rem;
        box-sizing: border-box;
	}
	
	.tanaka-menu-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--wp--preset--spacing--20);
	}
	
	.tanaka-menu-item-title {
		font-size: 0.9rem;
	}
	
	.tanaka-menu-item-text {
		font-size: 0.75rem;
	}
	
	.tanaka-menu-more-btn {
		padding: 0.35rem 1rem;
		font-size: 0.8rem;
		margin-top: 0.4rem;
	}
	
	.tanaka-menu-item-content {
		padding: var(--wp--preset--spacing--15);
		gap: 0.4rem;
	}
	
	.tanaka-menu-item-image {
		height: 50%;
	}
}

@media (min-width: 769px) and (max-width: 1024px) {
	.tanaka-menu-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 1025px) {
	.tanaka-menu-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* ========================================
   カテゴリーアーカイブページ
   ======================================== */

/* カテゴリーページで親テーマのヘッダーテンプレートパーツを非表示 */
.wp-block-template-part {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	overflow: hidden !important;
	margin: 0 !important;
	padding: 0 !important;
}

.tanaka-category-archive {
	margin: 0 auto;
    padding: 0;
}

.tanaka-category-wrapper {
	width: 100%;
}

.tanaka-category-header {
	margin-bottom: var(--wp--preset--spacing--60);
    text-align: center;
    width: 100vw;
    background: #e84c8f6e;
    padding: 0.2rem;
}

.tanaka-category-title {
    font-size: 1.5rem;
    color: #ffffff !important;
}

.tanaka-category-description {
	color: #676767;
	font-size: 1rem;
	line-height: 1.6;
}

.tanaka-category-posts {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--40);
    padding: 0 0.5rem;
}

.tanaka-category-post {
	background-color: #ffffff;
	border-radius: 0.5rem;
	padding: var(--wp--preset--spacing--30);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.tanaka-category-post-content {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20);
}

.tanaka-category-post-thumbnail {
	width: 100%;
	overflow: hidden;
	border-radius: 0.5rem;
}

.tanaka-category-post-img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
}

.tanaka-category-post-text {
	flex: 1;
}

.tanaka-category-post-header {
	margin-bottom: var(--wp--preset--spacing--15);
}

.tanaka-category-post-title {
	font-size: 1.2rem;
	font-weight: 600;
	color: #676767;
	margin: 0 0 var(--wp--preset--spacing--10) 0;
}

.tanaka-category-post-title a {
	color: #676767;
	text-decoration: none;
	transition: color 0.3s ease;
}

.tanaka-category-post-title a:hover {
	color: #eb85a8;
}

.tanaka-category-post-meta {
	margin-top: var(--wp--preset--spacing--10);
}

.tanaka-category-post-date {
	color: #676767;
	font-size: 0.9rem;
	opacity: 0.7;
}

.tanaka-category-post-excerpt {
	color: #676767;
	font-size: 0.95rem;
	line-height: 1.6;
	margin-bottom: var(--wp--preset--spacing--15);
}

.tanaka-category-post-more {
	margin-top: var(--wp--preset--spacing--15);
}

.tanaka-category-post-link {
	display: inline-block;
	background-color: #eb85a8;
	color: #ffffff;
	border-radius: 3rem;
	padding: 0.4rem 1.2rem;
	text-decoration: none;
	font-size: 0.85rem;
	font-weight: 500;
	white-space: nowrap;
}

.tanaka-category-empty {
	text-align: center;
	padding: var(--wp--preset--spacing--60) 0;
	color: #676767;
}

/* カテゴリー「news」専用スタイル */
.category-news .wp-block-group.has-global-padding.is-layout-constrained,
.category-news .wp-block-group.has-global-padding.wp-block-group-is-layout-constrained,
.category-news main.wp-block-group.has-global-padding.is-layout-constrained,
.category-news main.wp-block-group.has-global-padding.wp-block-group-is-layout-constrained,
.category-news main[class*="wp-block-group"],
.category-news .wp-site-blocks > main.wp-block-group {
	margin-top: 0 !important;
	padding-top: 0 !important;
}
.tanaka-single-post-content{
	padding: 0 2rem;
}
.tanaka-single-post-news-header{
	background: #e8468ca1;
    padding: 0.5rem 2rem;
    color: #ffffff !important;
}

.tanaka-single-post-news-header h1{
	color: #ffffff !important;
	font-size: 1.5rem;
	padding: 0;
	margin: 0;
}

.tanaka-breadcrumb {
	margin: 1rem 0 1.5rem;
	font-size: 0.95rem;
	color: #676767;
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
}

.tanaka-breadcrumb a {
	color: #676767;
	text-decoration: none;
}

.tanaka-breadcrumb a:hover {
	color: #eb85a8;
}

.tanaka-breadcrumb-sep {
	color: #b0b0b0;
}

.tanaka-breadcrumb-current {
	color: #676767;
}

.tanaka-single-news-nav ,.tanaka-single-contents-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin: 0;
    padding: 0;
}

.tanaka-news-nav-btn ,.tanaka-contents-nav-btn { 
    padding: 0.25rem 1.4rem;
    border-radius: 999px;
    color: #ffffff !important;
    text-decoration: none;
    font-size: 0.8rem;
    background: #ffa3cb;
}

.tanaka-contents-nav-title {
	display: block;
	font-size: 0.9rem;
	font-weight: 600;
	color: #ffffff;
	margin-top: 0.1rem;
	white-space: normal;
}

/* Pattern: responsive 4-column grid */
.tanaka-4col-section {
	max-width: var(--wp--style--global--content-size);
	margin: 0 auto;
}

.tanaka-4col-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--wp--preset--spacing--30, 1.5rem);
}

.tanaka-4col-card {
	height: 100%;
	padding: var(--wp--preset--spacing--30, 1.5rem);
	border: 2px solid #1a1a1a;
	border-radius: 18px;
	background: #ffffff;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.tanaka-4col-card h3,
.tanaka-4col-card h4 {
	margin: 0;
	font-weight: 800;
	line-height: 1.2;
	font-size: clamp(1.4rem, 1vw + 1rem, 1.9rem);
}

.tanaka-4col-card p {
	margin: 0;
	line-height: 1.7;
}

.tanaka-4col-cta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 0.75rem;
}

.tanaka-4col-cta-label {
	font-weight: 700;
	margin: 0;
	font-size: 1rem;
}

.tanaka-4col-chip {
	margin: 0;
	padding: 0.65rem 1.8rem;
	border-radius: 999px;
	background: #e782a9;
	color: #111111;
	font-weight: 700;
	line-height: 1.2;
	font-size: 1rem;
	white-space: nowrap;
	flex: 0 0 auto;
}

@media (max-width: 480px) {
	.tanaka-4col-cta {
		flex-direction: column;
		align-items: flex-start;
	}
	.tanaka-4col-chip {
		white-space: normal;
		width: 100%;
		text-align: center;
	}
}

@media (max-width: 1024px) {
	.tanaka-4col-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.tanaka-4col-grid {
		grid-template-columns: 1fr;
	}
}

/* FAQ */
.tanaka-faq {
	max-width: var(--wp--style--global--content-size);
	margin: 0 auto;
}

.tanaka-faq-list {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20, 1rem);
}

.tanaka-faq-item {
	padding: 1.2rem 1.4rem;
	border: 1px solid #d9d9d9;
	border-radius: 14px;
	background: #ffffff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.03);
}

.tanaka-faq-item summary {
	font-weight: 700;
	font-size: 1.05rem;
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.5rem;
}

.tanaka-faq-item summary::-webkit-details-marker {
	display: none;
}

.tanaka-faq-item summary::after {
	content: '+';
	font-weight: 700;
}

.tanaka-faq-item[open] summary::after {
	content: '−';
}

.tanaka-faq-item p {
	margin: 0.75rem 0 0;
	line-height: 1.7;
}

@media (max-width: 640px) {
	.tanaka-faq-item {
		padding: 1rem 1rem;
	}
	.tanaka-faq-item summary {
		font-size: 1rem;
	}
}

/* Footer */
.tanaka-footer {
	max-width: var(--wp--style--global--content-size);
	margin: 0 auto;
	border-top: 1px solid #e6e6e6;
}

.tanaka-footer h4 {
	margin: 0 0 0.5rem;
	font-weight: 700;
}

.tanaka-footer-nav .wp-block-navigation__container,
.tanaka-footer-services .wp-block-navigation__container {
	flex-direction: column;
	gap: 0.4rem;
}

.tanaka-footer a {
	color: inherit;
	text-decoration: none;
}

.tanaka-footer a:hover {
	text-decoration: underline;
}

@media (max-width: 640px) {
	.tanaka-footer .wp-block-columns {
		gap: 1.5rem;
	}
	.tanaka-footer-right {
		flex-direction: column;
	}
	.tanaka-footer-inline-nav,
	.tanaka-footer-services-line {
		gap: 0.25rem;
	}
}

.tanaka-single-contents-hero {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	padding: 1rem 1.25rem;
	border: 1px solid #e5e5e5;
	border-radius: 0.75rem;
	background: #ffffff;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
}

.tanaka-single-contents-thumb {
	width: 90px;
	min-width: 90px;
	height: 90px;
	overflow: hidden;
	border-radius: 50%;
	background: #f8f8f8;
	display: flex;
	align-items: center;
	justify-content: center;
}

.tanaka-single-contents-thumb img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

.tanaka-single-contents-titlewrap {
	flex: 0 1 auto;
	text-align: center;
}

.tanaka-single-contents-titlewrap .tanaka-single-post-title {
	margin: 0;
	font-size: 1.6rem;
	color: #676767;
}


/* レスポンシブ */
@media (max-width: 768px) {
	body.category-news.single-post .tanaka-single-post {
		margin: 0;
        padding: 0;
	}
	.tanaka-single-contents-hero {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}
	.tanaka-single-contents-thumb {
		width: 110px;
		min-width: 110px;
		height: 110px;
	}
	.tanaka-single-contents-titlewrap .tanaka-single-post-title {
		font-size: 1.4rem;
	}
	body.category-news.single-post .tanaka-single-post-article {
		margin: 0;
        padding: 0;
	}
	body.category-news.single-post .tanaka-single-news-date-title {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--wp--preset--spacing--10);
	}
	body.category-news.single-post .tanaka-single-news-date {
		font-size: 0.85rem;
	}
	body.category-news.single-post .tanaka-single-post-title {
		font-size: 1.4rem;
		width: 100%;
	}
	body.category-news.single-post .tanaka-single-post-body {
		margin: var(--wp--preset--spacing--20) 0;
	}
}

.category-news .tanaka-category-post-content {
	flex-direction: row;
	align-items: center;
	gap: var(--wp--preset--spacing--30);
}

.category-news .tanaka-news-post-content {
	width: 100%;
}

.category-news .tanaka-category-post-text {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	gap: var(--wp--preset--spacing--20);
}

.category-news .tanaka-news-date-title {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: var(--wp--preset--spacing--20);
	flex: 1;
}

.category-news .tanaka-news-date {
	color: #676767;
	font-size: 0.9rem;
	white-space: nowrap;
}

.category-news .tanaka-news-title-link {
	flex: 1;
}

.category-news .tanaka-category-post-title {
	margin: 0;
}

/* カテゴリー「contents」専用スタイル（最小限: フロントMENUと揃える） */
.category-contents .tanaka-category-post {
	background: transparent;
	box-shadow: none;
	border: none;
	padding: 0;
}

/* contentsカテゴリでもフロントMENUと同じグリッド挙動を保証 */
.category-contents .tanaka-menu-grid {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--wp--preset--spacing--30);
	width: 100%;
}
@media (max-width: 768px) {
	.category-contents .tanaka-menu-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--wp--preset--spacing--20);
	}
}
@media (min-width: 769px) and (max-width: 1024px) {
	.category-contents .tanaka-menu-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
@media (min-width: 1025px) {
	.category-contents .tanaka-menu-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
	.tanaka-category-archive {
		padding: 0;
        margin: 0;
	}
	
	.tanaka-category-title {
		font-size: 1.5rem;
	}
	
	.category-news .tanaka-category-post-content,
	.category-contents .tanaka-category-post-content {
		flex-direction: column;
	}
	
	.category-news .tanaka-category-post-text {
		flex-direction: column;
		align-items: flex-start;
	}
	
	.category-news .tanaka-news-date-title {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--wp--preset--spacing--10);
	}
	
	.category-contents .tanaka-category-post-thumbnail {
		width: 100%;
	}
	
	.tanaka-category-post-link {
		padding: 0.35rem 1rem;
		font-size: 0.8rem;
	}
}

/* ========================================
   RESERVE項目セクション
   ======================================== */

.tanaka-reserve-section {
	margin: 100px auto 0;
	padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--60);
	clear: both;
	box-sizing: border-box;
	background-color: #ffffff;
	border-radius: 0.5rem;
	max-width: 1200px;
	width: 90%;
}

.tanaka-reserve-content {
	flex-direction: row;
	align-items: center;
	gap: var(--wp--preset--spacing--40);
	width: 100%;
}

.tanaka-reserve-image {
	flex: 1;
	max-width: 50%;
	overflow: hidden;
	border-radius: 0.5rem;
}

.tanaka-reserve-img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
}



.tanaka-reserve-title {
	margin: 0 0 var(--wp--preset--spacing--20) 0;
	text-align: center;
	width: 30%;
}

.tanaka-reserve-title-img {
	max-width: 100%;
	height: auto;
	display: block;
}



.tanaka-reserve-content p {
	margin: 0 0 1rem 0;
}

.tanaka-reserve-content p:last-child {
	margin-bottom: 0;
}

.tanaka-reserve-content * {
	column-count: 1 !important;
	column-width: auto !important;
	columns: 1 !important;
}

.tanaka-reserve-link {
	margin-top: var(--wp--preset--spacing--20);
}

.tanaka-reserve-btn {
	display: inline-block;
	background-color: #eb85a8;
	color: #ffffff;
	border-radius: 3rem;
	padding: 0.6rem 2rem;
	text-decoration: none;
	font-size: 1rem;
	font-weight: 500;
	transition: opacity 0.3s ease;
}

.tanaka-reserve-btn:hover {
	opacity: 0.8;
}

.tanaka-reserve-empty {
	color: #676767;
	font-size: 1rem;
	text-align: center;
	padding: var(--wp--preset--spacing--40) 0;
}

@media (max-width: 768px) {
	.tanaka-reserve-section {
		margin: 60px auto 0;
		padding: 2rem;
		width: 90%;
		border-radius: 0;
	}
	
	.tanaka-reserve-content {
		flex-direction: column;
		gap: var(--wp--preset--spacing--30);
	}
	
	.tanaka-reserve-image {
		max-width: 100%;
		width: 100%;
	}
	
	.tanaka-reserve-text {
		max-width: 100%;
		width: 100%;
	}
	
	.tanaka-reserve-title {
		margin-bottom: var(--wp--preset--spacing--15);
	}
	
	.tanaka-reserve-title-img {
		max-width: 100%;
		height: auto;
	}
	
	.tanaka-reserve-content {
		font-size: 0.9rem;
	}
	
	.tanaka-reserve-btn {
		padding: 0.5rem 1.5rem;
		font-size: 0.9rem;
	}
}

/* ========================================
   カスタムヘッダー（全ページ共通）
   ======================================== */

.tanaka-custom-header {
	width: 100%;
	max-width: 100%;
	background-color: transparent;
	position: relative;
	z-index: 100;
	overflow-x: hidden;
	box-sizing: border-box;
}

.tanaka-header-container {
	max-width: 100%;
	margin: 0;
	padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--60);
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20);
	width: 100%;
	box-sizing: border-box;
	overflow-x: hidden;
}

/* 1行目: ロゴ（左）と電話番号・WEBボタン（右） */
.tanaka-header-top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: nowrap;
	gap: var(--wp--preset--spacing--30);
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	overflow-x: hidden;
}

.tanaka-header-left {
	padding-left: var(--wp--preset--spacing--40);
	flex-shrink: 0;
	box-sizing: border-box;
}

.tanaka-header-right {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--30);
	flex-wrap: nowrap;
	flex-shrink: 0;
	box-sizing: border-box;
}

.tanaka-header-logo {
	flex-shrink: 0;
}

.tanaka-logo-img {
	max-width: 300px;
	height: auto;
	display: block;
}

/* 電話番号セクション */
.tanaka-phone {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--10);
}

.tanaka-phone-label {
	font-size: 0.75rem;
	font-weight: 400;
	color: #626262;
	letter-spacing: 0.05rem;
	margin-right: 0.5rem;
}

.tanaka-phone-number {
	margin: 0;
	font-size: 1.35rem;
	font-weight: 400;
	letter-spacing: 0.1rem;
	color: #626262;
}

/* WEB予約ボタン */
.tanaka-web-reservation-btn {
	flex-shrink: 0;
}

.tanaka-reservation-link {
	display: inline-block;
	background-color: #fa7cbea1;
	color: #ffffff;
	border-radius: 3rem;
	padding: 0.5rem 1rem;
	text-decoration: none;
	transition: opacity 0.3s ease;
	font-size: 1.1rem;
	text-align: center;
}

.tanaka-reservation-link:hover {
	opacity: 0.8;
}

/* ブロックエディター用のスタイル（互換性のため） */
.tanaka-web-reservation .wp-block-button__link {
	display: inline-block;
	background-color: var(--tanaka-bg-color, #ffe8f4);
	color: #676767;
	border: 1px solid #ffffff;
	border-radius: 0;
	padding: var(--wp--preset--spacing--20) var(--wp--preset--spacing--30);
	text-decoration: none;
	transition: opacity 0.3s ease;
	text-align: center;
}

.tanaka-web-reservation .wp-block-button__link:hover {
	opacity: 0.8;
}

/* 2行目: ナビゲーション（右寄せ） */
.tanaka-header-bottom {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	padding-right: var(--wp--preset--spacing--40);
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	overflow-x: hidden;
}

.tanaka-header-nav {
	display: flex;
	gap: 1rem;
	align-items: center;
	flex-wrap: wrap;
}

.tanaka-header-nav a {
    color: #5c5c5c;
    text-decoration: none;
    font-size: 0.9rem;
    letter-spacing: 0.02rem;
    transition: opacity 0.3s ease;
}

.tanaka-header-nav a:hover {
	opacity: 0.7;
}

/* ========================================
   レスポンシブ対応
   ======================================== */

/* モバイルフッターは769px以下でのみ表示 */
.tanaka-mobile-footer {
	display: none;
}

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

.tanaka-custom-footer {
	background-color: #f5f5f5;
	margin-top: var(--wp--preset--spacing--60);
	border-top: 1px solid #e0e0e0;
}

/* Googleマップの右上・左上の名称案内を非表示 */
.tanaka-footer-map {
	width: 100%;
	margin: 0;
	padding: 0;
	overflow: hidden;
	position: relative;
	height: 400px;
	background-color: #f5f5f5;
}

.tanaka-google-map {
	position: absolute;
	top: -100px;
	left: -300px;
	width: calc(100% + 600px);
	height: 600px;
	border: none;
	margin: 0;
	padding: 0;
	transform: scale(1.35);
	transform-origin: center center;
}

.tanaka-footer-container {
	max-width: 100%;
	margin: 0;
	width: 100%;
	box-sizing: border-box;
}

.tanaka-footer-content {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--wp--preset--spacing--40);
	margin-bottom: var(--wp--preset--spacing--20);
	padding: 2.5rem;
}

.tanaka-footer-left {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20);
}

.tanaka-footer-logo {
	margin-bottom: var(--wp--preset--spacing--20);
}

.tanaka-footer-clinic-info {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--10);
}

.tanaka-footer-clinic-type {
	margin: 0;
	color: #676767;
	font-size: 1.1rem;
	font-weight: 600;
}

.tanaka-footer-address,
.tanaka-footer-phone {
	margin: 0;
	color: #676767;
	font-size: 0.9rem;
	line-height: 1.6;
}

.tanaka-footer-right {
	flex: 1;
	flex-direction: column;
	flex-wrap: nowrap;
	align-items: flex-start;
	gap: 1.5rem;
}

.tanaka-footer-business-hours {
	flex: 1 1 320px;
	width: 100%;
}

.tanaka-footer-links {
	flex: 1 1 320px;
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
	margin: 0 0 var(--wp--preset--spacing--30);
}

.tanaka-footer-inline-nav,
.tanaka-footer-services-line {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem;
	margin: 0.4rem 0 0.2rem;
}

.tanaka-footer-inline-wrap {
	width: 100vw;
	margin-left: calc(-50vw + 50%);
	padding: 0 var(--wp--preset--spacing--40, 24px);
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.35rem;
	text-align: center;
}

/* Floating actions (Instagram + Back to top) */
.tanaka-floating-actions {
	position: fixed;
	left: 1.25rem;
	bottom: 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0.9rem;
	align-items: flex-start;
	z-index: 9999;
}

.tanaka-instagram-link,
.tanaka-back-to-top {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 20px rgba(0,0,0,0.12);
	cursor: pointer;
	position: relative;
}

.tanaka-instagram-link {
	background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
	color: #ffffff;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.tanaka-instagram-link:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 22px rgba(0,0,0,0.16);
}

.tanaka-instagram-link:active {
	transform: translateY(0);
}

.tanaka-instagram-icon {
	width: 22px;
	height: 22px;
	border: 2px solid #ffffff;
	border-radius: 6px;
	box-sizing: border-box;
	position: relative;
	display: block;
}

.tanaka-instagram-icon::before {
	content: '';
	position: absolute;
	inset: 5px;
	border: 2px solid #ffffff;
	border-radius: 50%;
}

.tanaka-instagram-icon::after {
	content: '';
	position: absolute;
	top: 3px;
	right: 3px;
	width: 4px;
	height: 4px;
	background: #ffffff;
	border-radius: 50%;
}

.tanaka-instagram-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

.tanaka-back-to-top {
	border: none;
	background: #e782a9;
	color: #ffffff;
	/* gapフォールバック用の軽い余白（古いブラウザでflex-gap未対応対策） */
	margin-top: 0.1rem;
	transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease, box-shadow 0.25s ease;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
}

.tanaka-back-to-top::before {
	content: '';
	width: 0;
	height: 0;
	border-left: 9px solid transparent;
	border-right: 9px solid transparent;
	border-bottom: 14px solid #ffffff;
	transform: translateY(-2px);
}

.tanaka-back-to-top.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.tanaka-back-to-top:hover {
	background: #ed94b6;
}

.tanaka-back-to-top:active {
	transform: translateY(1px);
}

.tanaka-floating-actions a:focus-visible,
.tanaka-floating-actions button:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 2px;
	box-shadow: 0 8px 20px rgba(0,0,0,0.12), 0 0 0 2px rgba(0,0,0,0.15);
}

@media (max-width: 768px) {
	.tanaka-floating-actions {
		/* モバイル固定フッターバーと重ならないように下余白を拡大 */
		bottom: calc(1.25rem + 72px);
	}
}

@media (max-width: 640px) {
	.tanaka-floating-actions {
		left: 1rem;
		bottom: calc(1rem + 72px);
		gap: 0.8rem;
	}
}

.tanaka-footer-inline-nav,
.tanaka-footer-inline-services {
	width: 100%;
	justify-content: center;
	text-align: center;
}

.tanaka-footer-services-line {
	justify-content: center;
}

.tanaka-footer-inline-services {
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}

.tanaka-footer-services-label {
	font-weight: 700;
}

.tanaka-footer-sep {
	color: #999;
}

.tanaka-footer-link-group h4 {
	margin: 0 0 0.4rem;
	font-weight: 700;
}

.tanaka-footer-link-group ul {
	margin: 0;
	padding-left: 1rem;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 0.35rem 1.2rem;
	list-style: disc;
}

.tanaka-footer-link-group li {
	line-height: 1.5;
}

.tanaka-footer-link-group a {
	color: inherit;
	text-decoration: none;
}

.tanaka-footer-link-group a:hover {
	text-decoration: underline;
}

.tanaka-footer-business-hours .tanaka-business-hours-table {
	margin: 0;
	width: 100%;
	position: relative !important; /* フッター内ではrelativeに */
	top: auto !important;
	left: auto !important;
	right: auto !important;
	padding: 0 !important;
	z-index: auto !important;
	max-width: 100% !important;
	box-sizing: border-box !important;
}

/* フッター内の診療時間表のスタイル調整（上部のスタイルと競合しないように） */
.tanaka-footer-business-hours .tanaka-business-hours-table table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	border-radius: 1rem;
	overflow: hidden;
}

.tanaka-footer-business-hours .tanaka-business-hours-table thead {
	background-color: #EA85A7;
	color: #ffffff;
}

.tanaka-footer-business-hours .tanaka-business-hours-table thead th {
	padding: 0.8rem 0.5rem;
	text-align: center;
	border: 1px solid #d0d0d0;
	font-weight: 600;
	font-size: 0.9rem;
}

.tanaka-footer-business-hours .tanaka-business-hours-table thead th:first-child {
	padding-right: 0.5rem;
	border-top-left-radius: 1rem;
}

.tanaka-footer-business-hours .tanaka-business-hours-table thead th:last-child {
	border-top-right-radius: 1rem;
}

.tanaka-footer-business-hours .tanaka-business-hours-table tbody td {
	padding: 0.8rem 0.5rem;
	text-align: center;
	border: 1px solid #d0d0d0;
	color: #676767;
	font-size: 0.9rem;
}

.tanaka-footer-business-hours .tanaka-business-hours-table tbody td:first-child {
	padding-right: 0.5rem;
	white-space: nowrap;
}

.tanaka-footer-business-hours .tanaka-business-hours-table tbody tr:last-child td:first-child {
	border-bottom-left-radius: 1rem;
}

.tanaka-footer-business-hours .tanaka-business-hours-table tbody tr:last-child td:last-child {
	border-bottom-right-radius: 1rem;
}

.tanaka-footer-business-hours .tanaka-hours-open {
	color: #eb85a8;
	font-size: 1.2rem;
	font-weight: 600;
}

.tanaka-footer-business-hours .tanaka-hours-closed {
	color: #676767;
	font-size: 1rem;
}

.tanaka-footer-business-hours .tanaka-business-hours-info {
	margin-top: var(--wp--preset--spacing--20);
}

.tanaka-footer-business-hours .tanaka-address {
	font-size: 0.9rem;
	color: #676767;
	margin: 0.4rem 0;
}

.tanaka-footer-logo {
	flex-shrink: 0;
}

.tanaka-footer-logo-img {
	width: 100%;
	height: auto;
	display: block;
}

.tanaka-footer-info {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--10);
}

.tanaka-footer-address,
.tanaka-footer-phone {
	margin: 0;
	color: #676767;
	font-size: 0.9rem;
	line-height: 1.6;
}

.tanaka-footer-nav {
	display: flex;
	flex-direction: row;
	gap: var(--wp--preset--spacing--20);
	flex-wrap: wrap;
}

.tanaka-footer-nav a {
	color: #676767;
	text-decoration: none;
	font-size: 0.9rem;
	transition: color 0.3s ease;
}

.tanaka-footer-nav a:hover {
	color: #eb85a8;
}

.tanaka-footer-copyright {
	text-align: center;
	padding-top: var(--wp--preset--spacing--30);
	border-top: 1px solid #e0e0e0;
}

.tanaka-footer-copyright p {
	margin: 0;
	color: #676767;
	font-size: 0.85rem;
}

@media (max-width: 768px) {
	.tanaka-custom-footer {
		margin-top: var(--wp--preset--spacing--40);
	}
	
	.tanaka-footer-container {
		padding: var(--wp--preset--spacing--40) 0;
	}
	
	.tanaka-footer-map {
		height: 300px;
	}
	
	.tanaka-google-map {
		height: 500px;
		top: -80px;
		left: -150px;
		width: calc(100% + 300px);
		transform: scale(1.4);
		transform-origin: center center;
	}
	
	.tanaka-footer-content {
		flex-direction: column;
		gap: var(--wp--preset--spacing--30);
		margin-bottom: var(--wp--preset--spacing--30);
		padding: 0 var(--wp--preset--spacing--20);
	}
	
	.tanaka-footer-left {
		width: 100%;
		text-align: center;
		order: 1;
	}
	
	.tanaka-footer-logo {
		text-align: center;
        margin-bottom: var(--wp--preset--spacing--20);
        width: 64%;
        margin: 2rem auto;
	}
	
	.tanaka-footer-clinic-info {
		text-align: center;
		margin-bottom: var(--wp--preset--spacing--30);
	}
	
	.tanaka-footer-right {
		width: 100%;
		order: 2;
	}
	
	.tanaka-footer-business-hours {
		width: 100%;
		overflow-x: auto;
	}
	
	/* フッター内の診療時間表のモバイルスタイル（上部のスタイルと競合しないように） */
	.tanaka-footer-business-hours .tanaka-business-hours-table {
		position: relative !important;
		top: auto !important;
		left: auto !important;
		right: auto !important;
		padding: 0 !important;
		margin: 0 !important;
		width: 100% !important;
		z-index: auto !important;
	}
	
	.tanaka-footer-business-hours .tanaka-business-hours-table tbody td:first-child {
		white-space: normal;
		font-size: 0.85rem;
		padding-right: 0.1rem;
	}
	
	.tanaka-footer-business-hours .tanaka-business-hours-table thead th:first-child {
		padding-right: 0.1rem;
	}
	
	.tanaka-footer-business-hours .tanaka-business-hours-table tbody td:first-child br {
		display: block;
	}
	
	.tanaka-footer-copyright {
		padding-top: var(--wp--preset--spacing--20);
		padding-left: var(--wp--preset--spacing--20);
		padding-right: var(--wp--preset--spacing--20);
	}
}

@media (max-width: 768px) {
	.tanaka-header-container {
		padding: 0.6rem 0rem;
		width: 100%;
	}
	
	.tanaka-header-left {
		padding-left: var(--wp--preset--spacing--20);
		flex-shrink: 0;
	}
	
	.tanaka-header-top {
		justify-content: space-between;
		align-items: center;
		flex-wrap: nowrap;
		width: 100%;
	}
	
	.tanaka-header-right {
		display: flex;
		align-items: center;
		gap: var(--wp--preset--spacing--15);
		flex-wrap: nowrap;
		flex-shrink: 0;
	}
	
	.tanaka-header-bottom {
		padding-right: var(--wp--preset--spacing--20);
		justify-content: flex-end;
		width: 100%;
	}

	/* モバイルは下部固定バーに電話・WEB予約を表示するためヘッダー内は非表示 */
	.tanaka-phone,
	.tanaka-web-reservation-btn {
		display: none !important;
	}
	
	.tanaka-header-nav {
		display: flex;
		gap: 0.5rem;
		align-items: center;
		flex-wrap: wrap;
		justify-content: flex-end;
	}
	
	.tanaka-phone-number {
		font-size: 0.9rem;
		font-weight: 600;
		white-space: nowrap;
	}
	
	.tanaka-reservation-link {
		padding: 0.2rem 0.6rem;
        font-size: 0.9rem;
        white-space: nowrap;
        margin-left: 1rem;
	}
	
	.tanaka-web-reservation .wp-block-button__link {
		padding: var(--wp--preset--spacing--15) var(--wp--preset--spacing--20);
		font-size: 0.9rem;
	}
	
	.tanaka-logo-img {
		max-width: 200px;
	}
	
	/* モバイル用固定フッターバー（電話番号とWEB予約ボタン） */
	.tanaka-mobile-footer {
		display: block !important;
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100%;
		background-color: #ffffff;
		border-top: 1px solid #e0e0e0;
		box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
		z-index: 1000;
		padding: 0.8rem 1rem;
		box-sizing: border-box;
	}
	
	.tanaka-mobile-footer-content {
		display: flex;
		justify-content: space-between;
		align-items: center;
		gap: 1rem;
		max-width: 100%;
		margin: 0 auto;
	}
	
	.tanaka-mobile-logo {
		display: flex;
		align-items: center;
		flex: 1;
	}
	
	.tanaka-mobile-logo-img {
		max-width: 120px;
		height: auto;
		display: block;
	}
	
	.tanaka-mobile-buttons {
		display: flex;
		gap: 0.8rem;
		flex-shrink: 0;
	}
	
	.tanaka-mobile-call-link,
	.tanaka-mobile-reservation-link {
		display: inline-block;
		background-color: #fa7cbea1;
		color: #ffffff;
		border-radius: 3rem;
		padding: 0.6rem 1.2rem;
		text-decoration: none;
		transition: opacity 0.3s ease;
		font-size: 1rem;
		text-align: center;
		white-space: nowrap;
	}
	
	.tanaka-mobile-call-link:hover,
	.tanaka-mobile-reservation-link:hover {
		opacity: 0.8;
	}
	
	/* モバイルフッターの下に余白を追加（コンテンツが隠れないように） */
	body {
		padding-bottom: 70px !important; /* モバイルフッターの高さ分の余白 */
	}
}

/* ========================================
   ロゴ用スタイル
   ======================================== */

.tanaka-logo {
	max-width: 200px;
	height: auto;
	display: block;
}

.tanaka-logo img {
	max-width: 100%;
	height: auto;
}

.tanaka-logo-hero {
	text-align: center;
	margin-bottom: var(--wp--preset--spacing--40);
}

.tanaka-logo-hero .tanaka-logo {
	max-width: 300px;
	width: 100%;
	height: auto;
}

/* サイトタイトルをロゴに置き換え */
.wp-block-site-title a {
	display: block;
	width: 100%;
	height: 0;
	padding-bottom: 26.5%;
	background-image: url('/wp-content/themes/tanaka-theme-child/templates/img/tanaka-rogo.png');
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	text-indent: -9999px;
	overflow: hidden;
}

/* ========================================
   診療時間表（営業情報）
   ======================================== */

/* 上部の診療時間表（フッター内ではない場合） */
.tanaka-business-hours-table:not(.tanaka-footer-business-hours .tanaka-business-hours-table) {
	position: absolute;
    top: 400px;
    width: 60%;
    margin: var(--wp--preset--spacing--40) 0;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0 var(--wp--preset--spacing--60);
    z-index: 100;
}

/* 上部の診療時間表のスタイル（フッター内ではない場合）を明示的に指定 */
body > .tanaka-business-hours-table,
.tanaka-hero-image-section ~ .tanaka-business-hours-table,
.tanaka-hero-image-section + .tanaka-business-hours-table {
	position: absolute !important;
    top: 400px !important;
    width: 60% !important;
    margin: var(--wp--preset--spacing--40) 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: 0 var(--wp--preset--spacing--60) !important;
    z-index: 100 !important;
}

.tanaka-business-hours-table table {
	width: 100%;
	border-collapse: separate; /* border-radiusを適用するためにseparateに変更 */
	border-spacing: 0; /* セル間の余白を0に */
	background-color: #ffffff;
	font-size: 0.8rem;
	border-radius: 1rem; /* 角丸 */
	overflow: hidden; /* 角丸を適用するために必要 */
}

.tanaka-business-hours-table thead {
	background-color: #EA85A7; /* ティール色のヘッダー */
}

.tanaka-business-hours-table thead th {
	padding: 1rem;
	text-align: center;
	font-weight: 600;
	color: #ffffff;
	border: 1px solid #eb85a8;
}

.tanaka-business-hours-table thead th:first-child {
	text-align: left;
	padding-right: 0.5rem; /* 右側の余白を減らす */
	border-top-left-radius: 1rem; /* 左上の角丸 */
}

.tanaka-business-hours-table thead th:last-child {
	border-top-right-radius: 1rem; /* 右上の角丸 */
}

/* 日曜日列の「・」を詰める */
.tanaka-business-hours-table thead th:last-child,
.tanaka-business-hours-table tbody td:last-child {
	letter-spacing: -0.05em; /* 「・」を詰める */
}

.tanaka-business-hours-table tbody td {
	padding: 0.4rem 0.3rem;
    text-align: center;
    color: #676767;
    border: 1px solid #e0e0e0;
    background-color: #ffffff;
}

.tanaka-business-hours-table tbody td:first-child {
	text-align: left;
	font-weight: 500;
	color: #676767;
	background-color: #ffffff;
	line-height: 1.4;
	white-space: nowrap; /* デスクトップでは1行表示 */
	padding-right: 0.5rem; /* 右側の余白を減らす */
}

/* デスクトップ表示時は<br>を非表示にして1行表示 */
.tanaka-business-hours-table tbody td:first-child br {
	display: none;
}

.tanaka-business-hours-table .tanaka-hours-open {
	color: #eb85a8;
	font-size: 1rem;
	font-weight: 600;
}

.tanaka-business-hours-table .tanaka-hours-closed {
	color: #676767;
	font-size: 1rem;
}

/* テーブルの角丸（最後の行の最初と最後のセル） */
.tanaka-business-hours-table tbody tr:last-child td:first-child {
	border-bottom-left-radius: 1rem; /* 左下の角丸 */
}

.tanaka-business-hours-table tbody tr:last-child td:last-child {
	border-bottom-right-radius: 1rem; /* 右下の角丸 */
}

/* 診療時間表の下の情報（受付時間・住所） */
.tanaka-business-hours-info {
	padding: 0;
    text-align: left;
    margin-top: 0.5rem;
}

.tanaka-reception-time,
.tanaka-address {
	margin: 0;
	color: #676767;
	font-size: 0.95rem;
	line-height: 1.6;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
	/* 上部の診療時間表（フッター内ではない） */
	.tanaka-business-hours-table:not(.tanaka-footer-business-hours .tanaka-business-hours-table),
	body > .tanaka-business-hours-table,
	.tanaka-hero-image-section ~ .tanaka-business-hours-table,
	.tanaka-hero-image-section + .tanaka-business-hours-table {
		margin: var(--wp--preset--spacing--30) 0;
        overflow-x: visible;
        width: 100% !important;
        /* padding: 0 var(--wp--preset--spacing--20); */
	}
	
	/* フッター内の診療時間表は除外（既存のスタイルを維持） */
	.tanaka-footer-business-hours .tanaka-business-hours-table {
		width: 100% !important;
	}
	
	/* 診療時間表の親要素に余白を確保 */
	.tanaka-hero-image-section {
		margin-bottom: 200px; /* 診療時間表の高さ分の余白を確保 */
		padding-bottom: var(--wp--preset--spacing--40);
	}
	
	.tanaka-business-hours-table table {
		width: 100%;
		max-width: 100%;
	}
	
	.tanaka-business-hours-table thead th {
		padding: 0.6rem 0.3rem;
		font-size: 0.75rem;
	}
	
	.tanaka-business-hours-table thead th:first-child {
		padding-left: 1rem;
	}
	
	.tanaka-business-hours-table tbody td {
		padding: 0.6rem 0.3rem;
		font-size: 0.7rem;
	}
	
	.tanaka-business-hours-table tbody td:first-child {
		font-size: 0.85rem; /* 少し大きくする（0.7rem → 0.85rem） */
		white-space: normal; /* モバイルでは2行表示可能 */
		line-height: 1.3;
		padding-left: 1rem;
	}
	
	/* モバイル表示時は<br>を表示して2行表示 */
	.tanaka-business-hours-table tbody td:first-child br {
		display: block;
	}
	
	/* モバイルでも画面幅に余裕がある場合（480px以上）は1行表示 */
	@media (min-width: 480px) {
		.tanaka-business-hours-table tbody td:first-child {
			white-space: nowrap; /* 1行表示 */
		}
		
		.tanaka-business-hours-table tbody td:first-child br {
			display: none; /* <br>を非表示 */
		}
	}
	
	.tanaka-business-hours-table .tanaka-hours-open {
		font-size: 0.9rem;
	}
	
	.tanaka-business-hours-table .tanaka-hours-closed {
		font-size: 0.7rem;
	}
	
	/* モバイル表示時の受付時間・住所 */
	.tanaka-business-hours-info {
		margin-top: var(--wp--preset--spacing--20);
	}
	
	.tanaka-reception-time,
	.tanaka-address {
		font-size: 0.85rem;
		margin: 0.4rem 0;
	}
}

.clinic-article{
	max-width:1100px;
	margin:0 auto;
	padding:24px 16px;
}

.clinic-card{
	background:#fff;
	border-radius:16px;
	padding:22px;
	box-shadow:0 6px 18px rgba(0,0,0,.06);
	margin:0 0 22px;
}

.clinic-card--muted{
	box-shadow:none;
	background:#f9f9f9;
}

.clinic-title{
	font-size: 1.2rem;
	font-weight:800;
	margin:0 0 8px;
}

.clinic-lead{
	font-size:16px;
	line-height:1.8;
	margin:0;
	color:#444;
}

.clinic-section-title{
	font-size:18px;
	font-weight:800;
	margin:0 0 10px;
	color:#2c3e50;
}

.clinic-section-desc{
	font-size:15px;
	line-height:1.9;
	margin:0 0 16px;
	color:#34495e;
}

.clinic-note{
	font-size:13px;
	line-height:1.8;
	color:#555;
	margin:8px 0 0;
}

.clinic-note strong{
	font-weight:800;
}

.clinic-small{
	font-size:13px;
	line-height:1.8;
	color:#555;
	margin:0;
}

/* grid: 4 → 3 → 2 → 1 */
.clinic-symptom-grid{
	display:grid;
	gap:14px;
	margin:12px 0 0;
	padding:0;
	list-style:none;
}

@media (min-width:1200px){
	.clinic-symptom-grid{ grid-template-columns:repeat(4, minmax(0, 1fr)); }
}
@media (min-width:900px) and (max-width:1199.98px){
	.clinic-symptom-grid{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
}
@media (min-width:600px) and (max-width:899.98px){
	.clinic-symptom-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width:599.98px){
	.clinic-symptom-grid{ grid-template-columns:1fr; }
}

.clinic-symptom-item{
	background:#f9f9f9;
	border-radius:12px;
	padding:12px 12px 10px;
	display:flex;
	flex-direction:column;
	gap:6px;
}

.clinic-symptom-name{
	font-weight:800;
	line-height:1.5;
}

/* label + pill row */
.clinic-symptom-row{
	display:flex;
	gap:10px;
	align-items:baseline;
	flex-wrap:wrap;
}

.clinic-symptom-label{
	font-size:0.85rem;
	font-weight:800;
	color:#555;
	white-space:nowrap;
	margin:0;
}

.clinic-symptom-pill{
	background-color:#f8bbd0;
	color:#1f1f1f;
	font-size:13px;
	padding:4px 8px;
	border-radius:6px;
	display:inline-block;
	margin:0;
}

.clinic-bullet{
	margin:0;
	padding-left:18px;
	line-height:1.9;
	color:#34495e;
}

/* price list (responsive) */
.clinic-price-list{
	margin:12px 0 0;
	padding:0;
	list-style:none;
	display:grid;
	gap:12px;
}
@media (min-width:900px){.clinic-price-list{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:899.98px){.clinic-price-list{grid-template-columns:1fr}}

.clinic-price-item{
	background:#f9f9f9;
	border-radius:14px;
	padding:14px;
	display:flex;
	flex-direction:column;
	gap:10px;
}

.clinic-price-head{display:flex;justify-content:space-between;align-items:baseline;gap:14px}
.clinic-price-name{font-weight:900;line-height:1.5;color:#2c3e50}
.clinic-price-value{font-weight:900;color:#1f1f1f;white-space:nowrap}
.clinic-pill{
	background: #f8bbd03d;
	color:#1f1f1f;
	font-size:0.8rem;
	font-weight:900;
	padding:4px 10px;
	border-radius:999px;
	display:inline-block;
	width:fit-content;
}

/* price box */
.clinic-price{
	background:#fff;
	border-radius:10px;
	padding:10px;
	border:1px solid rgba(0,0,0,.06);
	display:flex;
	flex-direction:column;
	gap:8px;
}

.clinic-price-row{
	display:flex;
	justify-content:space-between;
	align-items:baseline;
	gap:12px;
}

.clinic-price-label{
	font-size:12px;
	font-weight:800;
	color:#555;
	white-space:nowrap;
}
.clinic-price-label--large{
	font-size:14px;
}

.clinic-tag{
	background:#f8bbd0;
	color:#1f1f1f;
	font-size:12px;
	font-weight:800;
	padding:4px 10px;
	border-radius:999px;
	display:inline-block;
	width:fit-content;
}

.clinic-muted{
	background:#f9f9f9;
	border-radius:12px;
	padding:14px;
	box-shadow:none;
	margin-top:12px;
}

.clinic-muted--callout{
	margin-top:14px;
	background:#fff;
	border:1px solid rgba(0,0,0,.06);
	border-left:6px solid #f8bbd0;
	border-radius:14px;
	padding:14px;
}

/* cards grid (4→3→2→1) */
.clinic-grid{
	display:grid;
	gap:14px;
	margin:12px 0 0;
	padding:0;
	list-style:none;
}
@media (min-width:1200px){.clinic-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (min-width:900px) and (max-width:1199.98px){.clinic-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (min-width:600px) and (max-width:899.98px){.clinic-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:599.98px){.clinic-grid{grid-template-columns:1fr}}

.clinic-item{
	background:#f9f9f9;
	border-radius:12px;
	padding:12px 12px 10px;
	display:flex;
	flex-direction:column;
	gap:10px;
}

.clinic-item-title{font-weight:900;line-height:1.5}

.clinic-muted .clinic-bullet{padding-left:18px;}

/* Slider Tabs (CSS-only / :target) */
.clinic-target{display:block;height:0;overflow:hidden;position:relative;top:-10px}
.clinic-switcher{
	background:#fff;
	border-radius:999px;
	padding:6px;
	box-shadow:0 6px 18px rgba(0,0,0,.06);
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:6px;
	position:relative;
	margin:0 0 14px;
	overflow:hidden;
	border:1px solid rgba(0,0,0,.06);
}
.clinic-switcher .clinic-pill{
	width:100%;
	justify-content:center;
	text-align:center;
}
.clinic-pill{
	cursor:pointer;
	user-select:none;
	display:flex;
	align-items:center;
	justify-content:center;
	gap:8px;
    padding: 11px 0px;
	border-radius:999px;
	font-weight:900;
	color:#2c3e50;
	text-decoration:none;
	position:relative;
	z-index:2;
	text-align:center;
}
.clinic-pill small{font-weight:800;color:#667}

.clinic-switcher::after{
	content:"";
	position:absolute;
	top:6px;
	bottom:6px;
	left:6px;
	width:calc((100% - 18px)/2);
	border-radius:999px;
	background:#f8bbd0;
	box-shadow:0 6px 14px rgba(0,0,0,.10);
	transform:translateX(0%);
	transition:transform .28s ease;
	z-index:1;
}

/* デフォルトは左（tab-iv）をON */
.clinic-switcher a[href="#tab-iv"]{color:#1f1f1f}

/* 右（tab-oral）がtargetのとき */
#tab-oral:target ~ .clinic-switcher::after{transform:translateX(100%)}
#tab-oral:target ~ .clinic-switcher a{color:#2c3e50}
#tab-oral:target ~ .clinic-switcher a[href="#tab-oral"]{color:#1f1f1f}

/* 左（tab-iv）がtargetのとき */
#tab-iv:target ~ .clinic-switcher::after{transform:translateX(0%)}
#tab-iv:target ~ .clinic-switcher a{color:#2c3e50}
#tab-iv:target ~ .clinic-switcher a[href="#tab-iv"]{color:#1f1f1f}

.clinic-panels{overflow:hidden;border-radius:18px}
.clinic-panels-track{
	display:flex;
	width:200%;
	transform:translateX(0%);
	transition:transform .35s ease;
	will-change:transform;
}
#tab-oral:target ~ .clinic-panels .clinic-panels-track{transform:translateX(-50%)}
#tab-iv:target ~ .clinic-panels .clinic-panels-track{transform:translateX(0%)}
.clinic-panel{width:50%;padding:0}

/* 3-tab slider (予防接種/ブライダルチェック/検査) */
#tab-vaccine ~ .clinic-switcher{
	grid-template-columns:repeat(3,1fr);
	gap:0;
}
#tab-vaccine ~ .clinic-switcher::after{
	width:calc((100% - 12px)/3);
}
#tab-bridal:target ~ .clinic-switcher::after{transform:translateX(100%)}
#tab-test:target ~ .clinic-switcher::after{transform:translateX(200%)}
#tab-vaccine:target ~ .clinic-switcher::after{transform:translateX(0%)}
#tab-bridal:target ~ .clinic-switcher a,
#tab-test:target ~ .clinic-switcher a,
#tab-vaccine:target ~ .clinic-switcher a{color:#2c3e50}
#tab-vaccine:target ~ .clinic-switcher a[href="#tab-vaccine"],
#tab-bridal:target ~ .clinic-switcher a[href="#tab-bridal"],
#tab-test:target ~ .clinic-switcher a[href="#tab-test"]{color:#1f1f1f}

#tab-vaccine ~ .clinic-panels .clinic-panels-track{
	width:300%;
}
#tab-bridal:target ~ .clinic-panels .clinic-panels-track{transform:translateX(-33.333%)}
#tab-test:target ~ .clinic-panels .clinic-panels-track{transform:translateX(-66.666%)}
#tab-vaccine:target ~ .clinic-panels .clinic-panels-track{transform:translateX(0%)}
#tab-vaccine ~ .clinic-panels .clinic-panel{width:33.333%}

/* callout */
.clinic-callout{
	margin-top:14px;
	background:#fff;
	border:1px solid rgba(0,0,0,.06);
	border-left:6px solid #f8bbd0;
	border-radius:14px;
	padding:14px;
}

.clinic-link{
	color:#2c3e50;
	font-weight:900;
	text-decoration:underline;
	text-underline-offset:2px;
}
.clinic-link--button{
	display:inline-flex;
	align-items:center;
	justify-content:center;
	gap:8px;
	padding:10px 14px;
	border-radius:12px;
	background:#7ea75c;
	color:#fff;
	text-decoration:none;
	font-weight:900;
	box-shadow:0 6px 14px rgba(0,0,0,.12);
}
.clinic-link--button:hover{color:#fff;opacity:.92}
.clinic-link--button:focus{outline:2px solid rgba(248,187,208,.8);outline-offset:2px}

.clinic-link--accent{
	color:#1f4aa8;
}

/* vaccine / bridal / test blocks */
.clinic-list{margin:10px 0 0;padding-left:18px;line-height:1.9;color:#34495e}
.clinic-badge{
	background:#f8bbd0;
	color:#1f1f1f;
	font-size:0.9rem;
	padding:4px 10px;
	border-radius:999px;
	display:inline-block;
	width:fit-content;
}
.clinic-badge2{
	background:#ead8de;
	color:#6f6e6e;
	font-size:0.9rem;
	padding:4px 10px;
	border-radius:999px;
	display:inline-block;
	width:fit-content;
}
.clinic-row{display:flex;justify-content:space-between;gap:14px;align-items:baseline}
.clinic-row--stack{
	flex-direction:column;
	align-items:flex-start;
	gap:6px;
}
.clinic-row-title{font-weight:900;color:#2c3e50;line-height:1.5}
.clinic-grid2{display:grid;gap:12px;margin-top:12px}
@media (min-width:900px){.clinic-grid2{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:899.98px){.clinic-grid2{grid-template-columns:1fr}}
.clinic-box{background:#f9f9f9;border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:10px}