/* =============================================================================
   Component: Title Hero — 全ページ共通のページタイトルヒーロー
   ========================================================================== */

.tt-title-hero {
	position: relative;
	background: #EEEEEE;
	/* padding-top はフローティングヘッダー (brand top:12, height:48 → bottom y=60) を
	   完全に下回るために最低 80px 確保。デスクトップは余裕で広くとる */
	padding: clamp(80px, 10vw, 120px) 0 clamp(32px, 5vw, 56px);
	/* drip overflowぶん + 余裕。shape-drip --md (clamp(60px,10vw,160px)) と
	   合わせる: 滴の最大160px + 視覚的余白〜48px */
	margin-bottom: clamp(96px, 14vw, 208px);
}

.tt-title-hero__h1 {
	margin: 0;
	font-size: 0; /* 視覚的には画像が見出し。テキスト span は sr-only */
	line-height: 0;
}

.tt-title-hero__image {
	display: block;
	width: 100%;
	max-width: 1140px;
	height: auto;
	margin-inline: auto;
}

/* --- テキストモード (タイトル画像が無いページ用) ----------------
   Terms/Privacy/FAQ で使ってる SVG タイトル画像 (アウトライン文字) と
   見た目を揃えるため、Anton (display) + 黒線アウトラインで模す。 */

.tt-title-hero__text {
	display: block;
	text-align: center;
	font-size: initial; /* h1 の font-size: 0 をリセット */
	line-height: 1;
}

.tt-title-hero__text-en {
	display: block;
	font-family: "Anton", "Montserrat", "Noto Sans JP", sans-serif;
	font-size: clamp(56px, 12vw, 160px);
	font-weight: 400;
	line-height: 0.95;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: transparent;
	-webkit-text-stroke: 1.5px #000000;
}

.tt-title-hero__text-jp {
	display: block;
	margin-top: clamp(12px, 1.5vw, 20px);
	font-family: "Noto Sans JP", sans-serif;
	font-size: clamp(14px, 1.6vw, 18px);
	font-weight: 600;
	letter-spacing: 0.1em;
	color: #000000;
	line-height: 1.4;
}
