@charset "UTF-8";

/* ========================================
Base Variables & Reset
======================================== */
:root {
	--color-bg: #ffffff;
	--color-bg-sub: #f9f9f9;
	--color-text-main: #1a1a1c;
	--color-text-sub: #6c757d;
	--color-accent: #ab8667;
	--color-pink: #eb2f5b;
	--color-border: #e9ecef;

	--font-sans: 'Noto Sans JP', sans-serif;
	--font-serif: 'Shippori Mincho', serif;
	--font-eng: 'Playfair Display', serif;

	--header-height: 60px;
	--transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ★追加: 画面外へのはみ出しをカットし、横スクロールを完全に防止 */
html, body {
	overflow-x: hidden;
}

body {
	font-family: var(--font-sans);
	background-color: var(--color-bg);
	color: var(--color-text-main);
	line-height: 1.8;
	-webkit-font-smoothing: antialiased;
}

a { text-decoration: none; color: inherit; transition: var(--transition); }
ul { list-style: none; }
img { max-width: 100%; height: auto; display: block; object-fit: cover; }

/* ========================================
Header
======================================== */
.site-header {
	position: fixed;
	top: 0; left: 0; width: 100%;
	height: var(--header-height);
	background-color: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(8px);
	border-bottom: 1px solid var(--color-border);
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 1.5rem;
}
.header-back { font-size: 0.85rem; font-weight: 700; font-family:var(--font-eng); }
.header-logo { font-family: var(--font-eng); font-weight: 900; font-size: 1.2rem; }

/* ========================================
Layout & SEO Header
======================================== */
.main-container {
	padding-top: var(--header-height);
	max-width: 1100px;
	margin: 0 auto;
	padding-bottom: 8rem;
}

.page-seo-header {
	padding: 1.5rem 1.5rem 0;
}
.seo-h1 {
	font-size: 0.75rem;
	font-weight: 400;
	color: var(--color-text-sub);
	line-height: 1.6;
	margin: 0;
	font-family: var(--font-serif);
}

/* ========================================
Hero Section (SEO & Absolute Layout)
======================================== */
.cast-hero {
	position: relative;
	padding: 2rem 1.5rem 4rem;
	z-index: 1;
}

/* Float要素の高さを親に認識させるためのclearfix */
.cast-hero::after {
	content: "";
	display: block;
	clear: both;
}

/* 背景の透かし文字装飾 */
.cast-hero::before {
	content: attr(data-eng-name);
	position: absolute;
	top: 0;
	left: 1.5rem;
	font-family: var(--font-eng);
	font-size: clamp(4rem, 10vw, 8rem);
	font-weight: 900;
	color: var(--color-bg-sub);
	z-index: -1;
	line-height: 0.8;
	pointer-events: none;
	white-space: nowrap;
}

.cast-name {
	font-family: var(--font-serif);
	font-size: clamp(2.5rem, 6vw, 4rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--color-text-main);
}
.cast-age {
	font-family: var(--font-eng);
	font-size: 0.5em;
	color: var(--color-pink);
	vertical-align: super;
}

.hero-image-wrap {
	position: relative;
	aspect-ratio: 4/5;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 20px 40px rgba(0,0,0,0.08);
	margin-bottom: 2rem;
}
.hero-image-wrap img {
	width: 100%; height: 100%;
}

/*
.vertical-catch {
	position: absolute;
	top: 2rem;
	right: 1.5rem;
	writing-mode: vertical-rl;
	font-family: var(--font-serif);
	font-size: 1.2rem;
	letter-spacing: 0.3em;
	color: #ffffff;
	text-shadow: 0 2px 10px rgba(0,0,0,0.4);
	z-index: 2;
} */

.vertical-catch {
	position: absolute;
	top: 2rem;
	right: 1.5rem;
	writing-mode: vertical-rl;
	font-family: var(--font-serif);
	font-size: 1.2rem;
	letter-spacing: 0.3em;
	z-index: 2;

	/* PHPから渡された文字色 */
	color: var(--cast-color, #ffffff);

	/* * 濃いシャドウ（グロー効果）で擬似的な背景を作る
	 * 同じ色を広がり（ぼかし）を変えて何度も重ねることで、
	 * 文字の周囲がしっかり塗りつぶされて可読性が劇的に上がります。
	 */
	text-shadow:
		0 0 6px var(--outline-color, #000000),
		0 0 12px var(--outline-color, #000000),
		0 0 18px var(--outline-color, #000000),
		0 4px 15px rgba(0, 0, 0, 0.8); /* 最後に全体を少し落とす影 */
}


.shop-label {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-accent);
	letter-spacing: 0.1em;
	border-bottom: 1px solid var(--color-accent);
	padding-bottom: 0.3rem;
}

.intro-text {
	font-size: 0.95rem;
	color: var(--color-text-sub);
	line-height: 2;
	margin: 20px 0 2rem 0;
	font-family: var(--font-serif);
}

/* ★ スマホ閲覧時： Flexboxで見た目の順序を調整 */
@media (max-width: 899px) {
	.cast-hero {
		display: flex;
		flex-direction: column;
	}
	/* ソースコード上の順番を無視して、視覚的に美しい順序へ変更 */
	.hero-image-wrap { order: 1; }
	.shop-label { order: 2; margin-top: 1rem; margin-bottom: 1rem; }
	.cast-name { order: 3; margin-bottom: 2rem; }
	.intro-text { order: 4; }
	.action-btns { order: 5; }
}

/* ★ PC閲覧時： AbsoluteとFloatを駆使した回り込みレイアウト */
@media (min-width: 900px) {
	.cast-hero {
		padding: 3rem 1.5rem 5rem;
		/* h2とラベルを absoluteで配置するため、その分の高さを上部に確保 */
		padding-top: 9rem;
	}
	.hero-image-wrap {
		float: left;
		width: 42%;
		margin-right: 3.5rem;
		margin-bottom: 1.5rem;
	}

	/* 見出し(h2)をabsoluteで画像の右側上部に配置 */
	.cast-name {
		position: absolute;
		top: 4.5rem;
		left: calc(1.5rem + 42% + 3.5rem); /* 余白 + 画像幅 + マージン */
		margin: 0;
	}

	/* ラベルもabsoluteで配置 */
	.shop-label {
		position: absolute;
		top: 3rem;
		left: calc(1.5rem + 42% + 3.5rem);
		margin: 0;
	}
}

/* Action Buttons */
.action-btns {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
}
.btn-action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.8rem 1.5rem;
	border-radius: 50px;
	font-size: 0.85rem;
	font-weight: 700;
	cursor: pointer;
	transition: var(--transition);
}
.btn-review {
	background-color: var(--color-bg);
	color: var(--color-text-main);
	border: 1px solid var(--color-border);
}
.btn-review:hover {
	background-color: var(--color-text-main);
	color: #fff;
	border-color: var(--color-text-main);
	transform: translateY(-2px);
}
.btn-fav {
	background-color: transparent;
	color: var(--color-pink);
	border: 1px solid var(--color-pink);
	min-width: 180px;
}
.btn-fav:hover {
	background-color: rgba(192, 108, 132, 0.05); /* --color-pink の薄い色 */
	transform: translateY(-2px);
}
.btn-fav.is-active {
	background-color: var(--color-pink);
	color: #fff;
}
.btn-fav.is-active svg {
	fill: #fff;
}


/* ========================================
Section Common
======================================== */
.content-section {
	padding: 0 1.5rem;
	margin-bottom: 5rem;
}
.sec-title {
	margin-bottom: 1rem;
	position: relative;
	display: flex;
	flex-direction: column;
}
/* 英語を「見た目上」一番上(1)にする */
.sec-title .en {
	order: 1;
	font-family: var(--font-eng);
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
}
/* 日本語を「見た目上」真ん中(2)にする */
.sec-title .ja {
	order: 2;
	font-family: var(--font-sans);
	font-size: 0.75rem;
	color: var(--color-text-sub);
	margin-top: 0.5rem;
	letter-spacing: 0.05em;
}
/* 下線の装飾を「見た目上」一番下(3)にする（※これが重要です） */
.sec-title::after {
	content: '';
	display: block;
	width: 30px;
	height: 2px;
	background-color: var(--color-accent);
	margin-top: 12px;
	order: 3;
}

/* 各セクション見出し直下のPタグ（SEO用説明文） */
.sec-desc {
	font-size: 0.9rem;
	color: var(--color-text-sub);
	margin-bottom: 2rem;
	line-height: 1.6;
}

/* ========================================
Movie Section
======================================== */
.movie-wrapper {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	border-radius: 8px;
	overflow: hidden;
	background: #111;
	box-shadow: 0 15px 30px rgba(0,0,0,0.15);
}

.cast-movie {
	width: 100%;
	height: auto;
	max-height: 80vh;
	object-fit: contain;
	display: block;
	margin: 0 auto;
}

/* ========================================
Profile Section
======================================== */
.profile-box {
	background-color: var(--color-bg-sub);
	border-radius: 8px;
	padding: 2.5rem 2rem;
}
.spec-list {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem 3rem;
	margin-bottom: 2.5rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid var(--color-border);
}
.spec-item {
	display: flex;
	flex-direction: column;
}
.spec-item dt {
	font-family: var(--font-eng);
	font-size: 0.75rem;
	color: var(--color-text-sub);
	letter-spacing: 0.1em;
}
.spec-item dd {
	font-family: var(--font-serif);
	font-size: 1.5rem;
	font-weight: 700;
}
.spec-item dd span {
	font-family: var(--font-sans);
	font-size: 0.8rem;
	font-weight: normal;
	margin-left: 2px;
}

@media (max-width: 600px) {
	.spec-list {
		gap: 1.5rem 1.5rem;
	}
}


.qa-list {
	display: grid;
	gap: 1.5rem;
}
.qa-item dt {
	font-weight: 700;
	font-size: 0.95rem;
	color: var(--color-pink);
	margin-bottom: 0.5rem;
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
}
.qa-item dt::before {
	content: 'Q.';
	font-family: var(--font-eng);
	font-size: 1.2rem;
	line-height: 1;
}
.qa-item dd {
	font-size: 0.95rem;
	color: var(--color-text-main);
	padding-left: 1.8rem;
}

/* ========================================
User Reviews Section
======================================== */
.review_cont {
	background-color: var(--color-bg-sub);
	padding: 2.5rem 2rem;
	border-radius: 8px;
}
.review-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media(min-width: 768px){
	.review-grid { grid-template-columns: repeat(3, 1fr); }
}

.review-card {
	background: #fff;
	padding: 1.5rem;
	border-radius: 8px;
	border: 1px solid var(--color-border);
	position: relative;
	display: flex;
	flex-direction: column;
	height: 100%;
}
.review-card::before {
	content: '“';
	position: absolute;
	top: 10px; right: 20px;
	font-family: var(--font-serif);
	font-size: 4rem;
	color: #f0f0f0;
	line-height: 1;
	pointer-events: none;
}
.review-stars {
	color: #fbbf24;
	font-size: 1.2rem;
	margin-bottom: 0.5rem;
	letter-spacing: 2px;
}
.review-title {
	font-weight: 700;
	font-size: 1rem;
	margin-bottom: 0.5rem;
	color: var(--color-text-main);
}

		.review-text {
			font-size: 0.85rem;
			color: var(--color-text-sub);
			line-height: 1.6;
			margin-bottom: 1rem;

			max-height: 120px;
			overflow-y: auto;
			padding-right: 5px;
		}

		.review-text::-webkit-scrollbar {
			width: 4px; /* スクロールバーの幅を細くして野暮ったさを消す */
		}
		.review-text::-webkit-scrollbar-track {
			background: #f1f1f1;
			border-radius: 4px;
		}
		.review-text::-webkit-scrollbar-thumb {
			background: #ccc;
			border-radius: 4px;
		}
		.review-text::-webkit-scrollbar-thumb:hover {
			background: var(--accent-pink); /* ホバー時にサイトのアクセントカラーに光らせる */
		}


.review-target {
	display: flex;
	align-items: center;
	gap: 0.8rem;
	border-top: 1px dashed var(--color-border);
	padding-top: 1rem;
	margin-top: auto;
}
.review-target img {
	width: 40px; height: 40px;
	border-radius: 50%;
	object-fit: cover;
}
.review-target-info {
	display: flex; flex-direction: column;
}
.review-target-shop {
	font-size: 0.65rem; color: #888;
}
.review-target-cast {
	font-weight: 700; font-size: 0.9rem; color: var(--color-pink);
}

.rev_all_box {
	text-align: center;
	margin-top: 2rem;
}
.rev_all_a {
	font-weight: 700;
	color: var(--color-text-main);
	border-bottom: 2px solid var(--color-pink);
	padding-bottom: 2px;
	transition: var(--transition);
}
.rev_all_a:hover {
	opacity: 0.7;
}

/* ========================================
Gallery Section
======================================== */
.gallery-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
}
@media (min-width: 600px) {
	.gallery-grid { grid-template-columns: repeat(3, 1fr); gap: 15px; }
}
.gallery-item {
	position: relative;
	border-radius: 8px;
	overflow: hidden;
	background-color: var(--color-bg-sub);
	cursor: pointer;
}
.gallery-item:nth-child(1) {
	grid-column: span 2;
	grid-row: span 2;
	aspect-ratio: 4/5;
}
.gallery-item:not(:nth-child(1)) {
	aspect-ratio: 1/1;
}
.gallery-item img {
	width: 100%; height: 100%;
	transition: transform 0.5s;
}
.gallery-item:hover img {
	transform: scale(1.05);
}

/* ========================================
Schedule & Shop
======================================== */
.bottom-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 4rem;
}
@media (min-width: 900px) {
	.bottom-grid { grid-template-columns: 1fr 1fr; }
}

.schedule-table {
	width: 100%;
	border-collapse: collapse;
}
.schedule-table th, .schedule-table td {
	padding: 1.2rem 0;
	border-bottom: 1px solid var(--color-border);
	text-align: left;
	font-size: 0.95rem;
}
.schedule-table th {
	font-weight: 500;
	color: var(--color-text-sub);
	width: 45%;
}
.schedule-table td.active {
	color: var(--color-pink);
	font-weight: 700;
}

.shop-card {
	border: 1px solid var(--color-border);
	padding: 2.5rem 2rem;
	border-radius: 8px;
	text-align: center;
}
.shop-card-name {
	font-family: var(--font-serif);
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 1rem;
}
.shop-card-desc {
	font-size: 0.85rem;
	color: var(--color-text-sub);
	margin-bottom: 2rem;
}
.btn-shop {
	display: block;
	width: 100%;
	padding: 1rem;
	background-color: var(--color-text-main);
	color: #fff;
	font-weight: 700;
	border-radius: 50px;
	transition: background-color 0.3s;
}
.btn-shop:hover { background-color: var(--color-accent); }

/* ========================================
Footer
======================================== */
.site-footer {
	text-align: center;
	padding: 3rem 1.5rem;
	border-top: 1px solid var(--color-border);
	margin-top: 4rem;
	font-family: var(--font-eng);
	font-size: 0.8rem;
	color: var(--color-text-sub);
}

/* ========================================
Gallery Modal (Lightbox)
======================================== */
.gallery-modal {
	display: none;
	position: fixed;
	z-index: 9999;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.85);
	backdrop-filter: blur(5px);
	-webkit-backdrop-filter: blur(5px);
	opacity: 0;
	transition: opacity 0.3s ease;
}

.gallery-modal.show {
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 1;
}

.gallery-modal-content {
	max-width: 90%;
	max-height: 85vh;
	border-radius: 4px;
	box-shadow: 0 10px 30px rgba(0,0,0,0.5);
	transform: scale(0.95);
	transition: transform 0.3s ease, opacity 0.2s ease;
	object-fit: contain;
}

.gallery-modal.show .gallery-modal-content {
	transform: scale(1);
}

.gallery-modal-close {
	position: absolute;
	top: 20px;
	right: 30px;
	color: #fff;
	font-size: 40px;
	font-weight: 300;
	cursor: pointer;
	z-index: 10001;
	transition: color 0.2s;
	line-height: 1;
}

.gallery-modal-close:hover {
	color: var(--color-pink);
}

.gallery-modal-nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(255, 255, 255, 0.1);
	color: white;
	border: none;
	cursor: pointer;
	width: 50px;
	height: 50px;
	font-size: 20px;
	border-radius: 50%;
	transition: background 0.3s, transform 0.2s;
	z-index: 10001;
	display: flex;
	justify-content: center;
	align-items: center;
}

.gallery-modal-nav:hover {
	background: rgba(255, 255, 255, 0.3);
	transform: translateY(-50%) scale(1.1);
}

.gallery-modal-nav.prev { left: 20px; }
.gallery-modal-nav.next { right: 20px; }

@media (max-width: 768px) {
	.gallery-modal-nav { width: 40px; height: 40px; font-size: 16px; }
	.gallery-modal-nav.prev { left: 10px; }
	.gallery-modal-nav.next { right: 10px; }
	.gallery-modal-close { top: 15px; right: 20px; font-size: 35px; }
}

/* ========================================
Bottom Fixed Action Bar
======================================== */
.action-bar-1 {
	position: fixed;
	bottom: 0; left: 0; width: 100%;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(10px);
	padding: 12px 15px 20px;
	border-top: 1px solid var(--color-border);
	z-index: 100;
}

.balloon-1 {
	position: absolute;
	bottom: calc(100% + 15px);
	left: 50%;
	transform: translateX(-50%);
	background: var(--color-pink);
	color: #fff;
	padding: 6px 16px;
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 700;
	white-space: nowrap;
	box-shadow: 0 4px 10px rgba(192, 108, 132, 0.3);
	animation: float 2s ease-in-out infinite;
	pointer-events: none;
}

.balloon-1::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 6px solid transparent;
	border-top-color: var(--color-pink);
}

@keyframes float {
	0%, 100% { transform: translate(-50%, 0); }
	50% { transform: translate(-50%, -5px); }
}

.btn-tel-1 {
	display: flex;
	justify-content: center;
	align-items: center;
	background: var(--color-text-main);
	color: #fff;
	padding: 14px;
	border-radius: 8px;
	font-weight: 700;
	font-size: 1.2rem;
	text-decoration: none;
	letter-spacing: 0.05em;
	max-width: 600px;
	margin: 0 auto;
	box-shadow: 0 4px 10px rgba(0,0,0,0.1);
	transition: transform 0.2s, background 0.2s;
}

.btn-tel-1:hover {
	background: #333;
	transform: translateY(-2px);
}

.icon-tel {
	margin-right: 8px;
	font-size: 1.3rem;
	display: inline-block;
	transform: translateY(2px);
}




/* ========================================
Fixed Navigation (PC/スマホ共通・完全固定)
======================================== */

/* ★ 修正ポイント: リンクをクリックしてジャンプした際、タイトルがメニューの下に隠れないようにする設定 */
html {
	scroll-behavior: smooth;
	scroll-padding-top: calc(var(--header-height) + 55px + 20px);
}

.page-nav {
	position: fixed; /* ★ sticky から fixed へ変更 */
	top: var(--header-height); /* ヘッダーのすぐ下に固定 */
	left: 0;
	width: 100%;
	background-color: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(8px);
	border-bottom: 1px solid var(--color-border); /* ★ 変数名を既存のCSSに合わせた */
	z-index: 90; /* ★ 既存のヘッダーが100なので、それより下に潜り込ませる */
}

.page-nav-list {
	display: flex;
	max-width: 1000px;
	margin: 0 auto;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none; /* Firefox */
}

.page-nav-list::-webkit-scrollbar {
	display: none; /* Chrome/Safari */
}

.page-nav-item {
	scroll-snap-align: start;
	flex-shrink: 0;
}

.page-nav-link {
	display: block;
	padding: 1rem 1.5rem;
	font-family: var(--font-eng);
	font-size: 0.95rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	color: var(--text-sub); /* ★ 変数名を既存のCSSに合わせた */
	position: relative;
	white-space: nowrap;
}

.page-nav-link:hover {
	color: var(--text-main);
}

/* PC閲覧時はメニューを中央寄せにする */
@media (min-width: 900px) {
	.page-nav-list {
		justify-content: center;
	}
}