/*
 * contact.css — Contact ページ（.contact-hero FV + .contact-form-section ラボ見学フォーム）
 *
 * 【ブレークポイント方針】
 *   モバイルファースト。主に min-width で段階的に拡張。
 *   1440 / 1200 / 1024 / 768 / 480 付近を意識（clamp・%・vw・rem 中心、px は最小限）
 *
 * ---------------------------------------------------------------------------
 * 【どの class を触ると何が変わるか】
 *   .contact-hero              … セクション全体（背景・上下パディングの基調）
 *   .contact-hero__inner       … 横の最大幅・左右余白（中央寄せのラッパ）
 *   .contact-hero__header      … 見出しブロックの下マージン
 *   .contact-hero__title-en    … 英字 CONTACT（色・字間・サイズ）
 *   .contact-hero__title-ja    … 日本語見出し（サイズ・上余白）
 *   .contact-hero__cards       … カードのグリッド（列数・ギャップ）
 *   .contact-hero__card        … 各カード（背景・角丸・影・高さ・hover）
 *   .contact-hero__card-label  … カード文言
 *   .contact-hero__card-icon   … 緑丸のサイズ・色（アイコン枠）
 *   .contact-hero__card-icon-glyph … Material Icons 用（Studio 踏襲のタイポ・レンダリング）
 *   .contact-hero__notes       … 補足ブロックの上余白・最大幅
 *   .contact-hero__note        … 各段落（行間・段落間）
 *   .contact-hero__email       … メール表記の強調（必要なら色・太字）
 *
 *   .contact-form-section      … ラボ見学フォームのセクション枠
 *   .contact-form-section__inner / __title / __about-* / __body
 *   .contact-lab-tour         … CF7 出力のスタイルをスコープ（.wpcf7 配下 + contact-form__*）
 *   .contact-form__field / __label / __required / __help / __input / __textarea
 *   .contact-form__datetime / __datetime-row / __datetime-unit / __datetime-separator
 *   .contact-form__agree / __submit
 *
 * 【文言・リンクの差し替え場所】
 *   page-contact.php 内の該当テキストノードおよび href="#..." を編集。
 *   見出し（日本語）は固定ページのタイトル（WP 管理画面）がそのまま出力されます。
 *
 * 【緑丸アイコンの実装】
 *   HTML: .contact-hero__card-icon 内に <i class="material-icons contact-hero__card-icon-glyph">。
 *   CSS : 円は .contact-hero__card-icon。グリフは .contact-hero__card-icon-glyph（Material Icons 踏襲）。
 * ---------------------------------------------------------------------------
 */

/* -------------------------------------------------------------------------
   デザイントークン（FV 範囲）
   ------------------------------------------------------------------------- */
.contact-hero {
	--contact-hero-bg: #fcefdf;
	--contact-hero-title-en: #544631;
	--contact-hero-title-ja: #544631;
	--contact-hero-card-bg: #ffffff;
	--contact-hero-card-text: #333333;
	/* Studio 踏襲: 0 0 10px rgba(0,0,0,0.2) */
	--contact-hero-card-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
	--contact-hero-card-shadow-hover: 0 4px 14px rgba(0, 0, 0, 0.24);
	--contact-hero-card-radius: 8px;
	--contact-hero-card-fixed-w: 278px;
	--contact-hero-card-fixed-h: 90px;
	--contact-hero-card-gap: 16px;
	/* Studio 踏襲: #05aa7d */
	--contact-hero-icon-bg: #05aa7d;
	--contact-hero-icon-fg: #ffffff;
	--contact-hero-note: #333333;
	--contact-hero-inner-max: 72rem;
	--contact-hero-font: "Zen Maru Gothic", "Hiragino Sans", "Hiragino Kaku Gothic ProN", sans-serif;
}

/* -------------------------------------------------------------------------
   セクション全体
   ------------------------------------------------------------------------- */
.contact-hero {
	position: relative;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	margin: 0;
	padding: 200px 0px 100px 0px;
	background-color: var(--contact-hero-bg);
	font-family: var(--contact-hero-font);
	overflow-x: clip;
}

.contact-hero__inner {
	width: 100%;
	max-width: min(var(--contact-hero-inner-max), 100%);
	margin-inline: auto;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	align-items: center;
}

/* -------------------------------------------------------------------------
   見出し
   ------------------------------------------------------------------------- */
.contact-hero__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	margin: 0;
	padding: 0;
	margin-bottom: clamp(2rem, 5vw, 3.75rem);
	width: 100%;
	max-width: 100%;
}

.contact-hero__title-en {
	margin: 0;
	padding: 0;
	font-size: clamp(2.25rem, 6.5vw, 4rem);
	font-weight: 600;
	letter-spacing: 0.08em;
	line-height: 1.15;
	color: var(--contact-hero-title-en);
	text-transform: uppercase;
}

.contact-hero__title-ja {
	margin: clamp(0.5rem, 1.5vw, 0.85rem) 0 0;
	padding: 0;
	font-size: clamp(1.125rem, 2.8vw, 1.5rem);
	font-weight: 600;
	letter-spacing: 0.06em;
	line-height: 1.5;
	color: var(--contact-hero-title-ja);
}

/* -------------------------------------------------------------------------
   導線カード（SP: 1 列 → 768px 以上: 2 列）
   ------------------------------------------------------------------------- */
.contact-hero__cards {
	display: grid;
	grid-template-columns: 1fr;
	justify-items: center;
	gap: var(--contact-hero-card-gap);
	width: 100%;
	max-width: min(52rem, 100%);
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	list-style: none;
}

.contact-hero__card {
	display: flex;
	flex: none;
	flex-direction: row;
	flex-wrap: nowrap;
	align-content: center;
	align-items: center;
	justify-content: center;
	gap: var(--contact-hero-card-gap);
	box-sizing: border-box;
	width: min(var(--contact-hero-card-fixed-w), 100%);
	max-width: 100%;
	height: var(--contact-hero-card-fixed-h);
	padding: 10px 20px;
	background: var(--contact-hero-card-bg);
	color: var(--contact-hero-card-text);
	border-radius: var(--contact-hero-card-radius);
	box-shadow: var(--contact-hero-card-shadow);
	text-decoration: none;
	transition:
		transform 0.22s ease,
		box-shadow 0.22s ease;
}

.contact-hero__card:hover {
	transform: translateY(-0.125rem);
	box-shadow: var(--contact-hero-card-shadow-hover);
}

.contact-hero__card:focus-visible {
	outline: 2px solid var(--contact-hero-icon-bg);
	outline-offset: 3px;
}

.contact-hero__card-label {
	flex: 0 1 auto;
	min-width: 0;
	width: auto;
	max-width: 100%;
	height: auto;
	color: var(--contact-hero-card-text);
	font-family: var(--contact-hero-font);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.4;
	text-align: left;
}

/* 緑丸＋矢印（SVG は currentColor で白を継承） */
.contact-hero__card-icon {
	flex: 0 0 auto;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-content: center;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	padding: 0;
	border-radius: 48px;
	background: var(--contact-hero-icon-bg);
	color: var(--contact-hero-icon-fg);
}

/*
 * Material Icons（Studio / 既存 FAQ ブロックと同系の指定）
 * グリフ名は page-contact.php の <i> 内テキストで変更（例: expand_more）
 */
.contact-hero__card-icon-glyph {
	align-items: center;
	display: inline-flex;
	font-family: "Material Icons";
	font-size: 24px;
	font-style: normal;
	font-weight: 400;
	justify-content: center;
	letter-spacing: normal;
	line-height: 1;
	text-transform: none;
	white-space: nowrap;
	word-wrap: normal;
	direction: ltr;
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
	color: inherit;
}

/* -------------------------------------------------------------------------
   補足文
   ------------------------------------------------------------------------- */
.contact-hero__notes {
	width: 80%;
	max-width: min(40rem, 100%);
	margin-block: clamp(2.25rem, 5.5vw, 3.5rem) 0;
	margin-inline: auto;
	padding: 0;
	box-sizing: border-box;
	text-align: left;
}

.contact-hero__note {
	margin: 0;
	padding: 0;
	font-size: clamp(0.8125rem, 1.85vw, 0.9375rem);
	font-weight: 400;
	line-height: 1.85;
	letter-spacing: 0.02em;
	color: var(--contact-hero-note);
}

.contact-hero__note + .contact-hero__note {
	margin-top: clamp(0.85rem, 2vw, 1.15rem);
}

.contact-hero__email {
	font-weight: 600;
	word-break: break-all;
}

/* =============================================================================
   ラボ見学申し込みフォーム（Fluent Forms + テーマラッパ）
   スコープ: .contact-lab-tour（.frm-fluent-form 内の要素）
   Fluent の class 差異に備え、独自 class（form-datetime-*）を主に日時レイアウトに使用
   ============================================================================= */

.contact-lab-tour {
	--contact-form-bg: #fff7e5ff;
	--contact-form-text: #333333;
	--contact-form-title: #544631;
	--contact-form-accent-line: #fad74a;
	--contact-form-link: #1565c0;
	--contact-form-input-bg: #ffffff;
	--contact-form-input-border: rgba(0, 0, 0, 0.12);
	--contact-form-placeholder: #9e9e9e;
	--contact-form-help: #888888;
	--contact-form-required: #c62828;
	--contact-form-focus: #05aa7d;
	--contact-form-submit-bg: #3a3a3a;
	--contact-form-submit-text: #ffffff;
	--contact-form-submit-hover: #2c2c2c;
	--contact-form-inner-max: 44rem;
	--contact-form-input-min-h: clamp(2.65rem, 5.5vw, 2.95rem);
	--contact-form-radius: clamp(0.35rem, 0.9vw, 0.45rem);
	--contact-form-radius-btn: clamp(0.25rem, 0.6vw, 0.35rem);
	font-family: var(--contact-hero-font);
	color: var(--contact-form-text);
	background-color: var(--contact-form-bg);
}

.contact-form-section__inner {
	width: 100%;
	max-width: min(var(--contact-form-inner-max), 100%);
	margin-inline: auto;
	padding-inline: clamp(1.15rem, 3.8vw, 2.25rem);
	padding-block: clamp(2.35rem, 5.5vw, 4.25rem);
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	align-items: stretch;
}

/* FORM HEADER — 左に黄色ライン（Studio：細め・上品） */
.contact-form-section__title {
	position: relative;
	margin: 0;
	padding: 0;
	padding-left: clamp(0.7rem, 1.8vw, 0.95rem);
	margin-inline: auto;
	display: inline-block;
	width: fit-content;
	max-width: 100%;
	box-sizing: border-box;
	border-left: clamp(0.34rem, 0.65vw, 1.1rem) solid var(--contact-form-accent-line);
	font-size: clamp(2.05rem, 3.35vw, 2.35rem);
	font-weight: 600;
	line-height: 1.4;
	letter-spacing: 0.05em;
	color: #333333;
	text-align: left;
}

/* FORM BUTTON — ピル型・黄枠・白背景 */
.contact-form-section__about-wrap {
	display: flex;
	justify-content: center;
	width: 100%;
	margin-top: clamp(1rem, 2.6vw, 1.35rem);
	margin-bottom: clamp(1.5rem, 3.8vw, 2.1rem);
}

.contact-form-section__about-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: clamp(2.45rem, 5.5vw, 2.65rem);
	padding: 0.48em clamp(1.6rem, 4vw, 2.1rem);
	border-radius: 999px;
	background-color: #ffffff;
	color: var(--contact-form-title);
	font-family: inherit;
	font-size: clamp(0.86rem, 1.95vw, 0.95rem);
	font-weight: 500;
	line-height: 1.4;
	text-decoration: none;
	box-sizing: border-box;
	transition:
		background-color 0.2s ease,
		color 0.2s ease,
		border-color 0.2s ease,
		box-shadow 0.2s ease;
	    align-content: center;
    border-bottom: 2px solid #fad74a;
    border-left: 2px solid #fad74a;
    border-radius: 32px;
    border-right: 2px solid #fad74a;
    border-top: 2px solid #fad74a;
    flex-direction: column;
    flex-wrap: nowrap;
    height: 63px;
    justify-content: center;
    width: 200px;
    max-width: 100%;
}

.contact-form-section__about-btn:hover {
	background-color: rgba(255, 196, 51, 0.08);
	box-shadow: 0 0.12rem 0.55rem rgba(84, 70, 49, 0.07);
}

.contact-form-section__about-btn:focus-visible {
	outline: 2px solid var(--contact-form-focus);
	outline-offset: 3px;
}

/* FORM BODY */
.contact-form-section__body {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.contact-form-section__fallback {
	margin: 0;
	padding: 1rem;
	border-radius: var(--contact-form-radius);
	background: rgba(255, 255, 255, 0.65);
	color: var(--contact-form-title);
	font-size: 0.95rem;
	line-height: 1.6;
}

/* --- Fluent：基本はプラグイン既定のテーブルレイアウトを維持 ---
   ※ 前回の全体 block 化で希望日時が縦崩れしたため、ここでは触りすぎない
*/
.contact-lab-tour .frm-fluent-form table.ff-t-container,
.contact-lab-tour .frm-fluent-form .ff-t-container {
	width: 100%;
	border: 0;
}

/* --- Fluent Forms 共通 --- */
.contact-lab-tour .frm-fluent-form {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.contact-lab-tour .frm-fluent-form .ff-el-group {
	margin-bottom: clamp(0.95rem, 2.4vw, 1.35rem);
	box-sizing: border-box;
}

.contact-lab-tour .frm-fluent-form .ff-el-group:last-child {
	margin-bottom: 0;
}

.contact-lab-tour .frm-fluent-form .ff-el-input--content {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.contact-lab-tour .frm-fluent-form .ff-el-input--label {
	display: block;
	margin-bottom: clamp(0.28rem, 1vw, 0.4rem);
	font-size: clamp(0.8rem, 1.75vw, 0.88rem);
	font-weight: 500;
	line-height: 1.45;
	color: var(--contact-form-text);
}

.contact-lab-tour .frm-fluent-form .ff-el-input--label label {
	font-weight: inherit;
	color: inherit;
}

/* 必須表示（目標: 小さな赤い「※必須」） */
.contact-lab-tour .frm-fluent-form .ff-el-input--label .text-danger,
.contact-lab-tour .frm-fluent-form .ff-el-input--label .ff-el-required {
	display: inline;
	margin-left: 0.22em;
	color: var(--contact-form-required) !important;
	font-size: 0;
	line-height: 1;
}

.contact-lab-tour .frm-fluent-form .ff-el-input--label .text-danger::before,
.contact-lab-tour .frm-fluent-form .ff-el-input--label .ff-el-required::before {
	content: "※必須";
	font-size: 0.74rem;
	font-weight: 600;
	letter-spacing: 0.01em;
}

/* text-danger が出ないテーマ/バージョン向けの保険 */
.contact-lab-tour .frm-fluent-form .ff-el-group.ff-el-is-required:not(:has(input[type="checkbox"])):not(:has(input[type="radio"])) .ff-el-input--label label:not(:has(+ .text-danger))::after {
	content: " ※必須";
	font-size: 0.74rem;
	font-weight: 600;
	color: var(--contact-form-required);
	white-space: nowrap;
}

.contact-lab-tour .frm-fluent-form .ff-el-group.required:not(:has(input[type="checkbox"])):not(:has(input[type="radio"])) .ff-el-input--label label::after {
	content: " ※必須";
	font-size: 0.74rem;
	font-weight: 600;
	color: var(--contact-form-required);
	white-space: nowrap;
}

/* ヘルプ / 説明文（Fluent の Description・Help text） */
.contact-lab-tour .frm-fluent-form .ff-el-input--label .ff-help-block,
.contact-lab-tour .frm-fluent-form .ff-el-input--label .ff-help-inline {
	display: block;
}

.contact-lab-tour .frm-fluent-form .ff-el-help-message,
.contact-lab-tour .frm-fluent-form .ff-el-form-help,
.contact-lab-tour .frm-fluent-form .ff-el-input--content > .text-muted,
.contact-lab-tour .frm-fluent-form .ff-el-input--content .description,
.contact-lab-tour .frm-fluent-form span.ff-el-help-text {
	display: block;
	margin-top: 0;
	margin-bottom: clamp(0.34rem, 1vw, 0.5rem);
	font-size: clamp(0.76rem, 1.65vw, 0.84rem);
	line-height: 1.5;
	color: var(--contact-form-help);
	font-weight: 400;
}

/* Fluent の tooltip/info アイコン表示は使わない（Studio は常時テキスト表示） */
.contact-lab-tour .frm-fluent-form .ff-el-input--label .ff-help-icon,
.contact-lab-tour .frm-fluent-form .ff-el-input--label .ff-help-icon-wrap,
.contact-lab-tour .frm-fluent-form .ff-el-input--label .ff-icon,
.contact-lab-tour .frm-fluent-form .ff-el-input--label .ff-tooltip,
.contact-lab-tour .frm-fluent-form .ff-el-input--label .ff_tooltip,
.contact-lab-tour .frm-fluent-form .ff-el-input--label [data-toggle="tooltip"],
.contact-lab-tour .frm-fluent-form .ff-el-input--label [data-bs-toggle="tooltip"],
.contact-lab-tour .frm-fluent-form .ff-el-input--label [data-original-title],
.contact-lab-tour .frm-fluent-form .ff-el-input--label [aria-label*="help" i],
.contact-lab-tour .frm-fluent-form .ff-el-input--label [aria-label*="ヘルプ"],
.contact-lab-tour .frm-fluent-form .ff-el-input--label .dashicons-info,
.contact-lab-tour .frm-fluent-form .ff-el-input--label .fa-info-circle,
.contact-lab-tour .frm-fluent-form .ff-el-input--label .fa-circle-info {
	display: none !important;
}

/* tooltip 方式で absolute/fade されるケースを常時表示に矯正 */
.contact-lab-tour .frm-fluent-form .ff-el-help-message,
.contact-lab-tour .frm-fluent-form .ff-el-form-help {
	position: static !important;
	opacity: 1 !important;
	visibility: visible !important;
	transform: none !important;
	pointer-events: auto !important;
	max-width: 100%;
}

/* Studio 見た目: ラベル直下の補助文を明示 */
.contact-lab-tour .frm-fluent-form .contact-form-section__field-example {
	margin-top: -0.08rem;
	margin-bottom: clamp(0.34rem, 1vw, 0.5rem);
	font-size: clamp(0.74rem, 1.6vw, 0.82rem);
	line-height: 1.45;
	letter-spacing: 0;
	color: #8d8d8d;
}

.contact-lab-tour .frm-fluent-form .ff-el-help-message:empty,
.contact-lab-tour .frm-fluent-form .ff-el-form-help:empty,
.contact-lab-tour .frm-fluent-form .ff-el-input--content > .text-muted:empty,
.contact-lab-tour .frm-fluent-form .ff-el-input--content .description:empty,
.contact-lab-tour .frm-fluent-form span.ff-el-help-text:empty {
	display: none;
}

.contact-lab-tour .frm-fluent-form input.ff-el-form-control:not([type="checkbox"]):not([type="radio"]),
.contact-lab-tour .frm-fluent-form select.ff-el-form-control,
.contact-lab-tour .frm-fluent-form textarea.ff-el-form-control {
	width: 100%;
	max-width: 100%;
	min-height: var(--contact-form-input-min-h);
	padding: 0.5em clamp(0.7rem, 1.8vw, 0.95rem);
	box-sizing: border-box;
	border: 1px solid var(--contact-form-input-border);
	border-radius: var(--contact-form-radius);
	background-color: var(--contact-form-input-bg);
	font-family: inherit;
	font-size: clamp(0.88rem, 1.9vw, 0.98rem);
	line-height: 1.4;
	color: var(--contact-form-text);
	transition:
		border-color 0.18s ease,
		box-shadow 0.18s ease;
}

.contact-lab-tour .frm-fluent-form textarea.ff-el-form-control {
	min-height: clamp(6.5rem, 18vw, 8.5rem);
	resize: vertical;
}

.contact-lab-tour .frm-fluent-form select.ff-el-form-control {
	cursor: pointer;
	appearance: auto;
}

.contact-lab-tour .frm-fluent-form input.ff-el-form-control::placeholder,
.contact-lab-tour .frm-fluent-form textarea.ff-el-form-control::placeholder {
	/* 補助文はラベル下で見せるため、placeholder は目立たせない */
	color: var(--contact-form-placeholder);
	opacity: 0.18;
	font-size: 0.96em;
}

.contact-lab-tour .frm-fluent-form input.ff-el-form-control:focus,
.contact-lab-tour .frm-fluent-form select.ff-el-form-control:focus,
.contact-lab-tour .frm-fluent-form textarea.ff-el-form-control:focus {
	outline: none;
	border-color: var(--contact-form-focus);
	box-shadow: 0 0 0 0.12rem rgba(5, 170, 125, 0.18);
}

/* 同意チェック — 小さめ・方針リンクは青系 */
.contact-lab-tour .frm-fluent-form .ff-el-form-check,
.contact-lab-tour .frm-fluent-form .ff-el-input--content .form-check,
.contact-lab-tour .frm-fluent-form .ff-el-tc {
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	gap: clamp(0.45rem, 1.2vw, 0.6rem);
}

.contact-lab-tour .frm-fluent-form .ff-el-form-check input[type="checkbox"],
.contact-lab-tour .frm-fluent-form .form-check-input,
.contact-lab-tour .frm-fluent-form .ff-el-tc input[type="checkbox"] {
	flex: 0 0 auto;
	width: 0.95rem;
	height: 0.95rem;
	min-width: 0.95rem;
	margin-top: 0.22em;
	accent-color: var(--contact-form-focus);
	cursor: pointer;
}

.contact-lab-tour .frm-fluent-form .ff-el-form-check label,
.contact-lab-tour .frm-fluent-form .form-check-label,
.contact-lab-tour .frm-fluent-form .ff-el-tc label {
	flex: 1 1 auto;
	min-width: 0;
	font-size: clamp(0.8rem, 1.75vw, 0.88rem);
	line-height: 1.6;
	font-weight: 400;
	color: var(--contact-form-text);
	cursor: pointer;
}

.contact-lab-tour .frm-fluent-form .ff-el-form-check a,
.contact-lab-tour .frm-fluent-form .form-check-label a,
.contact-lab-tour .frm-fluent-form .ff-el-tc a {
	color: var(--contact-form-link);
	text-decoration: underline;
	text-underline-offset: 0.18em;
}

.contact-lab-tour .frm-fluent-form .ff-el-form-check a:hover,
.contact-lab-tour .frm-fluent-form .form-check-label a:hover,
.contact-lab-tour .frm-fluent-form .ff-el-tc a:hover {
	text-decoration-thickness: 0.1em;
}

/* 送信 — 横幅いっぱい寄り・控えめ角丸・矢印強調 */
.contact-lab-tour .frm-fluent-form .ff-el-group:has(button.ff-btn-submit),
.contact-lab-tour .frm-fluent-form .ff_submit_btn_wrapper,
.contact-lab-tour .frm-fluent-form .ff-el-submit {
	display: flex;
	justify-content: center;
	width: 100%;
	margin-top: clamp(1.25rem, 3.2vw, 1.85rem);
	padding-top: clamp(0.35rem, 1vw, 0.5rem);
}

.contact-lab-tour .frm-fluent-form button.ff-btn.ff-btn-submit,
.contact-lab-tour .frm-fluent-form button[type="submit"].ff-btn-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5em;
	width: 100%;
	max-width: 100%;
	min-height: clamp(2.85rem, 6.5vw, 3.15rem);
	padding: 0.62em clamp(1.25rem, 3.5vw, 2rem);
	box-sizing: border-box;
	border: none;
	border-radius: var(--contact-form-radius-btn);
	background-color: var(--contact-form-submit-bg);
	color: var(--contact-form-submit-text);
	font-family: inherit;
	font-size: clamp(0.92rem, 2vw, 1.02rem);
	font-weight: 600;
	line-height: 1.25;
	letter-spacing: 0.05em;
	cursor: pointer;
	transition:
		background-color 0.2s ease,
		transform 0.2s ease,
		box-shadow 0.2s ease;
}

.contact-lab-tour .frm-fluent-form button.ff-btn.ff-btn-submit::after,
.contact-lab-tour .frm-fluent-form button[type="submit"].ff-btn-submit::after {
	content: ">";
	margin-left: 0.15em;
	font-size: 1.05em;
	line-height: 1;
	font-weight: 700;
	transform: scaleX(0.85);
}

.contact-lab-tour .frm-fluent-form button.ff-btn.ff-btn-submit:hover,
.contact-lab-tour .frm-fluent-form button[type="submit"].ff-btn-submit:hover {
	background-color: var(--contact-form-submit-hover);
	box-shadow: 0 0.3rem 0.85rem rgba(0, 0, 0, 0.16);
	transform: translateY(-0.05rem);
}

.contact-lab-tour .frm-fluent-form button.ff-btn.ff-btn-submit:focus-visible,
.contact-lab-tour .frm-fluent-form button[type="submit"].ff-btn-submit:focus-visible {
	outline: 2px solid var(--contact-form-focus);
	outline-offset: 3px;
}

/* =============================================================================
   希望日時（functions.php 挿入 + 行レイアウト）
   ============================================================================= */

.contact-form-section__required-mark {
	font-size: 0.82em;
	font-weight: 600;
	color: var(--contact-form-required);
	white-space: nowrap;
}

.contact-form-section__datetime {
	width: 100%;
	max-width: 100%;
	margin-top: clamp(0.35rem, 1vw, 0.5rem);
	margin-bottom: clamp(1rem, 2.5vw, 1.35rem);
	box-sizing: border-box;
}

.contact-form-section__datetime-heading {
	margin: 0 0 clamp(0.35rem, 1vw, 0.5rem);
	padding: 0;
	font-size: clamp(0.82rem, 1.8vw, 0.9rem);
	font-weight: 600;
	line-height: 1.45;
	color: var(--contact-form-text);
}

.contact-form-section__datetime-note-wrap {
	margin: 0 0 clamp(0.75rem, 2vw, 1rem);
	padding: 0;
}

.contact-form-section__datetime-note {
	font-size: clamp(0.78rem, 1.7vw, 0.86rem);
	font-weight: 500;
	color: var(--contact-form-link);
	text-decoration: underline;
	text-underline-offset: 0.18em;
}

.contact-form-section__datetime-note:hover {
	text-decoration-thickness: 0.1em;
}

.contact-form-section__datetime-block {
	margin-bottom: clamp(0.85rem, 2.2vw, 1.15rem);
}

.contact-form-section__datetime-label {
	margin: 0 0 clamp(0.45rem, 1.2vw, 0.6rem);
	padding: 0;
	font-size: clamp(0.8rem, 1.75vw, 0.88rem);
	font-weight: 600;
	line-height: 1.4;
	color: var(--contact-form-text);
}

/* 日時行：select を横並び、SP は折り返し */
.contact-lab-tour .contact-form-section__datetime-row.form-datetime-row,
.contact-lab-tour .form-datetime-row.contact-form-section__datetime-row {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: clamp(0.35rem, 1.4vw, 0.55rem) clamp(0.25rem, 1vw, 0.45rem);
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.contact-lab-tour .contact-form-section__datetime-row .ff-t-container {
	display: flex !important;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: clamp(0.35rem, 1.4vw, 0.55rem) clamp(0.25rem, 1vw, 0.45rem);
	width: 100% !important;
}

.contact-lab-tour .contact-form-section__datetime-row .ff-t-cell {
	display: flex !important;
	width: auto !important;
	padding: 0 !important;
	border: 0 !important;
	flex: 1 1 5.25rem;
	min-width: min(100%, 4.75rem);
	max-width: 100%;
}

.contact-lab-tour .contact-form-section__datetime-row > .ff-el-group,
.contact-lab-tour .contact-form-section__datetime-row .ff-t-cell > .ff-el-group {
	flex: 1 1 5.25rem;
	min-width: min(100%, 4.75rem);
	max-width: 100%;
	margin-bottom: 0 !important;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	gap: 0.25rem;
	box-sizing: border-box;
}

.contact-lab-tour .contact-form-section__datetime-row .ff-el-input--label {
	display: none !important;
}

.contact-lab-tour .contact-form-section__datetime-row .ff-el-input--content {
	flex: 1 1 auto;
	min-width: 0;
	width: auto;
	margin: 0;
}

.contact-lab-tour .contact-form-section__datetime-row select.ff-el-form-control {
	min-height: clamp(2.45rem, 5.2vw, 2.75rem);
	font-size: clamp(0.82rem, 1.8vw, 0.92rem);
	padding-left: 0.45rem;
	padding-right: 1.75rem;
}

/* 月・日 接尾辞（name に first_month 等を含む select を想定） */
.contact-lab-tour .contact-form-section__datetime-row .ff-el-group:has(select[name*="first_month"])::after,
.contact-lab-tour .contact-form-section__datetime-row .ff-el-group:has(select[name*="second_month"])::after {
	content: "月";
	flex: 0 0 auto;
	font-size: clamp(0.8rem, 1.7vw, 0.88rem);
	font-weight: 500;
	color: var(--contact-form-text);
	line-height: 1;
	padding-bottom: 0.08em;
}

.contact-lab-tour .contact-form-section__datetime-row .ff-el-group:has(select[name*="first_day"])::after,
.contact-lab-tour .contact-form-section__datetime-row .ff-el-group:has(select[name*="second_day"])::after {
	content: "日";
	flex: 0 0 auto;
	font-size: clamp(0.8rem, 1.7vw, 0.88rem);
	font-weight: 500;
	color: var(--contact-form-text);
	line-height: 1;
	padding-bottom: 0.08em;
}

/* 終了時刻の直前に 「〜」 */
.contact-lab-tour .contact-form-section__datetime-row .ff-el-group:has(select[name*="first_time_end"])::before,
.contact-lab-tour .contact-form-section__datetime-row .ff-el-group:has(select[name*="second_time_end"])::before {
	content: "〜";
	flex: 0 0 auto;
	font-size: clamp(0.95rem, 2.2vw, 1.05rem);
	font-weight: 600;
	color: var(--contact-form-title);
	line-height: 1;
	padding-inline: clamp(0.05rem, 0.6vw, 0.25rem);
	margin-bottom: 0.1em;
	white-space: nowrap;
}

/* カスタム HTML の区切り（Fluent 側で挿入した場合） */
.contact-lab-tour .form-datetime-separator {
	flex: 0 0 auto;
	align-self: center;
	font-size: clamp(0.95rem, 2.2vw, 1.05rem);
	font-weight: 600;
	color: var(--contact-form-title);
	white-space: nowrap;
	line-height: 1;
	padding-inline: 0.15rem;
}

/* 従来の .form-datetime-group ラッパ（併用時） */
.contact-lab-tour .form-datetime-group {
	width: 100%;
	max-width: 100%;
	margin-bottom: clamp(1rem, 2.5vw, 1.35rem);
	box-sizing: border-box;
}

.contact-lab-tour .form-datetime-group > label:first-of-type,
.contact-lab-tour .form-datetime-group .form-datetime-group-label {
	display: block;
	margin-bottom: clamp(0.4rem, 1.2vw, 0.55rem);
	font-size: clamp(0.8rem, 1.75vw, 0.88rem);
	font-weight: 600;
	line-height: 1.4;
	color: var(--contact-form-text);
}

.contact-lab-tour .form-datetime-row:not(.contact-form-section__datetime-row) {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: clamp(0.4rem, 1.6vw, 0.65rem);
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.contact-lab-tour .form-datetime-row > .ff-el-group,
.contact-lab-tour .form-datetime-row .ff-el-group {
	margin-bottom: 0 !important;
}

.contact-lab-tour .form-datetime-select {
	flex: 1 1 6rem;
	min-width: min(100%, 5.5rem);
	max-width: 100%;
	box-sizing: border-box;
}

.contact-lab-tour .form-datetime-select .ff-el-input--label {
	margin-bottom: 0.2rem;
	font-size: clamp(0.72rem, 1.5vw, 0.8rem);
	font-weight: 500;
	color: rgba(51, 51, 51, 0.85);
}

.contact-lab-tour .contact-form__field label {
	color: #333;
    font-feature-settings: 'palt' 1;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    height: auto;
    letter-spacing: 0.05em;
    line-height: 1.5;
    text-align: left;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}

@media (min-width: 48rem) {
	.contact-lab-tour .contact-form-section__datetime-row .ff-t-container {
		flex-wrap: nowrap;
	}

	.contact-lab-tour .contact-form-section__datetime-row .ff-t-cell {
		flex: 1 1 0;
		min-width: 0;
	}

	.contact-lab-tour .contact-form-section__datetime-row > .ff-el-group {
		flex: 1 1 0;
		min-width: 0;
	}

	.contact-lab-tour .contact-form-section__datetime-row {
		flex-wrap: nowrap;
	}

	.contact-lab-tour .form-datetime-row:not(.contact-form-section__datetime-row) {
		flex-wrap: nowrap;
	}

	.contact-lab-tour .form-datetime-select {
		flex: 1 1 0;
		min-width: 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	.contact-form-section__about-btn,
	.contact-lab-tour .frm-fluent-form button.ff-btn.ff-btn-submit,
	.contact-lab-tour .frm-fluent-form button[type="submit"].ff-btn-submit {
		transition: none;
	}

	.contact-lab-tour .frm-fluent-form button.ff-btn.ff-btn-submit:hover,
	.contact-lab-tour .frm-fluent-form button[type="submit"].ff-btn-submit:hover {
		transform: none;
	}
}

/* =============================================================================
   Contact Form 7 — ラボ見学フォーム（Studio 寄せ）
   ============================================================================= */
.contact-lab-tour .wpcf7 {
	width: 100%;
	max-width: 100%;
}

.contact-lab-tour .wpcf7-form {
	width: 100%;
	max-width: 100%;
	margin: 0;
}

/* field / label / help */
.contact-lab-tour .contact-form__field {
	margin-bottom: clamp(1.05rem, 2.3vw, 1.6rem);
	width: 100%;
	box-sizing: border-box;
}

.contact-lab-tour .contact-form__label {
	display: flex;
	align-items: baseline;
	gap: 0.4em;
	font-weight: 600;
	font-size: clamp(0.86rem, 1.9vw, 0.97rem);
	line-height: 1.4;
	color: var(--contact-form-text);
	margin: 0 0 0.45rem 0;
}

.contact-lab-tour .contact-form__required {
	color: var(--contact-form-required);
	font-weight: 700;
	font-size: 0.82em;
	letter-spacing: 0.02em;
	white-space: nowrap;
}

.contact-lab-tour .contact-form__help {
	margin: 0 0 0.55rem 0;
	font-size: 0.76rem;
	line-height: 1.4;
	color: var(--contact-form-help);
}

/* inputs */
.contact-lab-tour input.contact-form__input,
.contact-lab-tour select.contact-form__input,
.contact-lab-tour textarea.contact-form__textarea {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	border: 1px solid var(--contact-form-input-border);
	background-color: var(--contact-form-input-bg);
	color: var(--contact-form-text);
	padding: 0.62em 0.95em;
	font-family: inherit;
	font-size: clamp(0.9rem, 2vw, 1.02rem);
	line-height: 1.4;
	min-height: var(--contact-form-input-min-h);
}

.contact-lab-tour textarea.contact-form__textarea {
	min-height: clamp(7.5rem, 20vw, 9.5rem);
	resize: vertical;
}

.contact-lab-tour input.contact-form__input::placeholder,
.contact-lab-tour textarea.contact-form__textarea::placeholder {
	opacity: 0;
}

.contact-lab-tour select.contact-form__input {
	cursor: pointer;
	appearance: auto;
	padding-right: 2.2em;
}

/* textarea focus / input focus */
.contact-lab-tour input.contact-form__input:focus,
.contact-lab-tour select.contact-form__input:focus,
.contact-lab-tour textarea.contact-form__textarea:focus {
	outline: none;
	box-shadow: 0 0 0 0.12rem rgba(5, 170, 125, 0.18);
	border-color: rgba(5, 170, 125, 0.55);
}

/* datetime */
.contact-lab-tour .contact-form__datetime {
	margin-top: 0.15rem;
	margin-bottom: clamp(1.05rem, 2.3vw, 1.6rem);
}

.contact-lab-tour .contact-form__datetime-heading {
	margin: 0 0 0.35rem 0;
	font-weight: 700;
	color: var(--contact-form-text);
	font-size: 0.98rem;
}

.contact-lab-tour .contact-form__datetime-note {
	margin: 0 0 0.65rem 0;
	font-size: 0.82rem;
	font-weight: 500;
	color: var(--contact-form-link);
	text-decoration: underline;
	text-underline-offset: 0.18em;
}

.contact-lab-tour .contact-form__datetime-row {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: clamp(0.35rem, 1.2vw, 0.55rem) clamp(0.25rem, 1vw, 0.45rem);
}

.contact-lab-tour .contact-form__datetime-unit {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	flex: 1 1 auto;
	min-width: 4.6rem;
}

.contact-lab-tour .contact-form__datetime-select {
	width: auto;
	min-width: 5.25rem;
}

.contact-lab-tour .contact-form__datetime-separator {
	flex: 0 0 auto;
	color: var(--contact-form-title);
	font-weight: 800;
	line-height: 1;
	white-space: nowrap;
	margin-bottom: 0.05rem;
}

@media (min-width: 768px) {
	.contact-lab-tour .contact-form__datetime-row > p {
		flex-wrap: nowrap;
	}
	.contact-lab-tour .contact-form__datetime-row:not(:has(> p)) {
		flex-wrap: nowrap;
	}
	.contact-lab-tour .contact-form__datetime-unit {
		flex: 1 1 0;
		min-width: 0;
	}
}

/* agree（CF7: .contact-form__agree > p > .wpcf7-form-control-wrap） */
.contact-lab-tour .contact-form__agree {
	width: 100%;
	text-align: left;
	margin-bottom: clamp(1rem, 3vw, 1.5rem);
	font-size: 0.86rem;
	line-height: 1.6;
	color: var(--contact-form-text);
}

.contact-lab-tour .contact-form__agree > p {
	margin: 0;
	display: flex;
	justify-content: flex-start;
	width: 100%;
}

.contact-lab-tour .contact-form__agree .wpcf7-form-control-wrap {
	flex: 0 1 auto;
	max-width: 100%;
}

.contact-lab-tour .contact-form__agree .wpcf7-list-item {
	margin: 0;
}

.contact-lab-tour .contact-form__agree .wpcf7-list-item label {
	display: flex;
	align-items: flex-start;
	gap: clamp(0.45rem, 1.2vw, 0.65rem);
	margin: 0;
	cursor: pointer;
	color: var(--contact-form-text);
	text-decoration: none;
	font-weight: 400;
}

.contact-lab-tour .contact-form__agree input[type="checkbox"] {
	flex: 0 0 auto;
	width: 0.95rem;
	height: 0.95rem;
	min-width: 0.95rem;
	margin: 0.2em 0 0;
	accent-color: var(--contact-form-focus);
}

.contact-lab-tour .contact-form__agree .wpcf7-list-item-label {
	color: var(--contact-form-text);
	text-decoration: none;
	line-height: 1.6;
}

.contact-lab-tour .contact-form__agree a {
	color: var(--contact-form-link);
	text-decoration: underline;
	text-underline-offset: 0.18em;
}

.contact-lab-tour .contact-form__agree a:hover {
	opacity: 0.88;
}

/* submit（CF7 は div 内の input.wpcf7-submit が実体） */
.contact-lab-tour .contact-form__submit {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.contact-lab-tour .contact-form__submit > p {
	margin: 0;
	position: relative;
}

.contact-lab-tour .contact-form__submit input.wpcf7-submit {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	min-height: clamp(3rem, 7vw, 3.5rem);
	padding: 0 1rem;
	border: none;
	border-radius: var(--contact-form-radius);
	background-color: var(--contact-form-submit-bg);
	color: var(--contact-form-submit-text);
	font-family: inherit;
	font-weight: 700;
	letter-spacing: 0.04em;
	font-size: clamp(0.95rem, 2.2vw, 1.05rem);
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.contact-lab-tour .contact-form__submit input.wpcf7-submit:hover:not(:disabled) {
	background-color: var(--contact-form-submit-hover);
	transform: translateY(-0.05rem);
	box-shadow: 0 0.35rem 1rem rgba(0, 0, 0, 0.16);
}

.contact-lab-tour .contact-form__submit input.wpcf7-submit:disabled {
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

.contact-lab-tour .contact-form__submit .wpcf7-spinner {
	margin: 0.5rem auto 0;
	display: block;
}


/* -------------------------------------------------------------------------
   本文エリア（FV 外・ブロックエディタ）
   ------------------------------------------------------------------------- */
.page-contact__content {
	width: 100%;
	max-width: min(var(--contact-hero-inner-max), 100%);
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 4vw, 2.5rem);
	padding-bottom: clamp(2rem, 5vw, 4rem);
	box-sizing: border-box;
	font-family: var(--contact-hero-font);
}

/* -------------------------------------------------------------------------
   ブレークポイント：768px 以上 — カード 2 列
   ------------------------------------------------------------------------- */
@media (min-width: 768px) {
	.contact-hero__cards {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		justify-items: center;
		gap: var(--contact-hero-card-gap);
		max-width: min(
			calc(2 * var(--contact-hero-card-fixed-w) + var(--contact-hero-card-gap)),
			100%
		);
	}
}

/* -------------------------------------------------------------------------
   1200px 前後 — 見出しとカードの間をゆったり
   ------------------------------------------------------------------------- */
@media (min-width: 1200px) {
	.contact-hero__header {
		margin-bottom: clamp(2.75rem, 4vw, 4rem);
	}

	.contact-hero__title-en {
		font-size: clamp(3.25rem, 3.6vw, 4rem);
	}
}

/* -------------------------------------------------------------------------
   1440px 以上 — 大画面で内側の上限を固定しつつ余白だけ vw で調整
   ------------------------------------------------------------------------- */
@media (min-width: 1440px) {
	.contact-hero__inner {
		max-width: min(76rem, 92vw);
	}
}

/* -------------------------------------------------------------------------
   480px 以下 — タップ領域・折り返し
   ------------------------------------------------------------------------- */
@media (max-width: 480px) {
	/* 1 行に収まらない端末では高さだけ自動（Studio 90px は min-height で維持） */
	.contact-hero__card {
		height: auto;
		min-height: var(--contact-hero-card-fixed-h);
	}

}

@media (prefers-reduced-motion: reduce) {
	.contact-hero__card {
		transition: none;
	}

	.contact-hero__card:hover {
		transform: none;
	}
}

/* ==========================================================================
   Contact Form 7 FINAL OVERRIDE
   デザイン最終合わせ用（指定値ベース）
   ========================================================================== */

/* 1) フォーム全体余白 */
.contact-lab-tour .contact-form-section__body {
	max-width: 640px;
	margin: 0 auto;
}

.contact-lab-tour .wpcf7-form p {
	margin: 0;
}

.contact-lab-tour .wpcf7-form br {
	display: none;
}

.contact-lab-tour .contact-form__field {
	margin-bottom: 28px;
}

.contact-lab-tour .contact-form__field label,
.contact-lab-tour .contact-form__label {
	display: block;
}

.contact-lab-tour .contact-form__required {
	color: #d00;
	font-size: 12px;
	margin-left: 4px;
}

.contact-lab-tour .contact-form__help {
	font-size: 12px;
	color: #999;
	margin: 3px 0px 0px 0px!important;
}

.contact-form__datetime-group {
	padding-left: 16px;
	padding-bottom: 12px;
	padding-top: 7px;
}
/* 2) input / textarea / select 統一 */
.contact-lab-tour .contact-form__input,
.contact-lab-tour .contact-form__textarea,
.contact-lab-tour .contact-form__select {
	width: 100%;
	height: 48px;
	border: 1px solid #ddd;
	padding: 0 12px;
	background: #fff;
	font-size: 14px;
	box-sizing: border-box;
}

.contact-lab-tour .contact-form__textarea {
	height: 160px;
	padding: 12px;
}

/* 3) 希望日時 横並び（CF7 は行内に <p> を出すため flex は p に寄せる） */
.contact-lab-tour .contact-form__datetime-row {
	margin-inline: clamp(0px, 3.5vw, 1.125rem);
	box-sizing: border-box;
	display: block;
}

.contact-lab-tour .contact-form__datetime-row > p {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.5rem;
	margin: 0;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

/* 「月」「日」などをセレクト行の下側（エリア下端）に揃える */
.contact-lab-tour .contact-form__datetime-row .contact-form__datetime-right {
	align-self: flex-end;
	margin-right: 12px;
	line-height: 1;
}

.contact-lab-tour .contact-form__datetime-row:not(:has(> p)) {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.5rem;
}

.contact-lab-tour .contact-form__datetime-row select,
.contact-lab-tour .contact-form__datetime-row .contact-form__select {
	width: auto;
	min-width: 80px;
	max-width: 100%;
	padding: 12px;
}

.contact-form__datetime-row .bold {
	color: #333333;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.4;
    max-width: calc(100% - 8px);
}

.contact-form__datetime-title {
	color: #333333;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.4;
    max-width: calc(100% - 8px);
	padding-bottom: 8px;
}

.contact-lab-tour .contact-form__datetime-unit {
	font-size: 14px;
}

.contact-lab-tour .contact-form__datetime-sep,
.contact-lab-tour .contact-form__datetime-separator {
	margin: 0 4px;
}

/* 4) 第1希望・第2希望余白 */
.contact-lab-tour .contact-form__datetime-block {
	margin-bottom: 20px;
}

.contact-lab-tour .contact-form__datetime-label {
	font-size: 14px;
	margin-bottom: 8px;
}

/* 5) ボタン（実体は input.wpcf7-submit） */
.contact-lab-tour .contact-form__submit input.wpcf7-submit {
	height: 56px;
	background: #333;
	color: #fff;
	border-radius: 6px;
	font-size: 16px;
	border: 0;
}

.contact-lab-tour .contact-form__submit input.wpcf7-submit:hover:not(:disabled) {
	background: #2c2c2c;
}

/* スマホ最適化（崩れ防止） */
@media (max-width: 480px) {
	.contact-lab-tour .contact-form-section__body {
		max-width: 100%;
	}

	.contact-lab-tour .contact-form__datetime-row {
		margin-inline: clamp(0px, 2.5vw, 0.75rem);
	}

	.contact-lab-tour .contact-form__datetime-row select,
	.contact-lab-tour .contact-form__datetime-row .contact-form__select {
		min-width: 72px;
		flex: 1 1 auto;
	}
}

/* ==========================================================================
   希望日時ヘルプ — 中央モーダル（contact.js が .contact-form__help に紐づけ）
   ========================================================================== */

body.contact-help-modal-open {
	overflow: hidden;
}

.contact-lab-tour .contact-form__help.contact-form__help--modal-trigger {
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 0.18em;
	background: transparent;
    color: #0099ffff;
    flex: none;
    font-family: var(--s-font-a79198f2);
    font-feature-settings: 'palt' 1;
    font-size: 15px;
    font-style: normal;
    font-weight: 500;
    height: auto;
    letter-spacing: 0.05em;
    line-height: 1;
    padding: 0px 0px 0px;
    text-align: left;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}

.contact-lab-tour .contact-form__help.contact-form__help--modal-trigger:hover {
	opacity: 0.9;
}

.contact-help-modal[hidden] {
	display: none !important;
}

.contact-help-modal {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(1rem, 4vw, 2rem);
	box-sizing: border-box;
	font-family: "Zen Maru Gothic", "Hiragino Sans", "Hiragino Kaku Gothic ProN", sans-serif;
}

.contact-help-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.16);
	opacity: 0;
	transition: opacity 0.28s ease;
}

.contact-help-modal.is-open .contact-help-modal__backdrop {
	opacity: 1;
}

.contact-help-modal__panel {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: min(36rem, 100%);
	max-height: min(90vh, 100%);
	overflow: auto;
	margin: auto;
	padding: clamp(1.75rem, 5vw, 3.75rem);
	padding-top: clamp(2.5rem, 6vw, 3.25rem);
	box-sizing: border-box;
	background: #fdf9f3ff;
	border-radius: clamp(12px, 2.5vw, 18px);
	box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.22);
	color: #333;
	font-size: clamp(0.9rem, 2.2vw, 1rem);
	line-height: 1.75;
	outline: none;
	transform: scale(0.94) translateY(0.5rem);
	opacity: 0;
	transition:
		opacity 0.32s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}

.contact-help-modal.is-open .contact-help-modal__panel {
	opacity: 1;
	transform: scale(1) translateY(0);
}

.contact-help-modal__body p {
	margin: 0 0 1em;
	text-align: left;
}

.contact-help-modal__body p:last-child {
	margin-bottom: 0;
}

.contact-help-modal__dismiss {
	position: absolute;
	top: clamp(0.5rem, 1.5vw, 0.85rem);
	right: clamp(0.5rem, 1.5vw, 0.85rem);
	width: 2.25rem;
	height: 2.25rem;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: transparent;
	color: #666;
	font-size: 1.65rem;
	line-height: 1;
	cursor: pointer;
	transition: color 0.15s ease, background-color 0.15s ease;
	display: none;
}

.contact-help-modal__dismiss:hover {
	color: #111;
	background: rgba(0, 0, 0, 0.06);
}

.contact-help-modal__close {
	display: block;
	margin: clamp(1.25rem, 3vw, 1.75rem) auto 0;
	padding: 0.5em 1.75em;
	border: 1px solid #ccc;
	border-radius: 6px;
	background: #fff;
	color: #333;
	font-family: inherit;
	font-size: 0.9rem;
	cursor: pointer;
	transition: background-color 0.15s ease, border-color 0.15s ease;
}

.contact-help-modal__close:hover {
	background: #f5f5f5;
	border-color: #bbb;
}

@media (prefers-reduced-motion: reduce) {
	.contact-help-modal__backdrop,
	.contact-help-modal__panel {
		transition-duration: 0.01ms !important;
	}
}

/* ==========================================================================
   その他お問い合わせ（Contact Form 7）
   ラボ見学申し込みと同じデザイン言語で、必要項目のみを共通化
   ========================================================================== */

.contact-general-contact {
	--contact-form-bg: #fff7e5ff;
	--contact-form-text: #333333;
	--contact-form-title: #544631;
	--contact-form-accent-line: #fad74a;
	--contact-form-link: #1565c0;
	--contact-form-input-bg: #ffffff;
	--contact-form-input-border: rgba(0, 0, 0, 0.12);
	--contact-form-help: #888888;
	--contact-form-required: #c62828;
	--contact-form-focus: #05aa7d;
	--contact-form-submit-bg: #3a3a3a;
	--contact-form-submit-hover: #2c2c2c;
	--contact-form-submit-text: #ffffff;
	--contact-form-inner-max: 44rem;
	--contact-form-radius: clamp(0.35rem, 0.9vw, 0.45rem);
	color: var(--contact-form-text);
	background: var(--contact-form-bg);
	font-family: var(--contact-hero-font);
}

/* page-contact.php の各フォーム section に明示適用 */
.contact-font-scope,
.contact-font-scope * {
	font-family: "Zen Maru Gothic", "Hiragino Sans", "Hiragino Kaku Gothic ProN", sans-serif;
}

.contact-general-contact .contact-form-section__inner {
	padding-top: clamp(2rem, 5vw, 3rem);
}

.contact-general-contact .contact-form-section__body {
	max-width: 640px;
	margin: 0 auto;
}

.contact-general-contact .wpcf7-form p {
	margin: 0;
}

.contact-general-contact .wpcf7-form br {
	display: none;
}

.contact-general-contact .contact-form__field {
	margin-bottom: 28px;
}

#general-contact-form .contact-form-section__title {
	margin-bottom: 24px;
}

.contact-general-contact .contact-form__field label,
.contact-general-contact .contact-form__label {
	display: block;
	margin: 0 0 6px 0;
	color: var(--contact-form-text);
	font-size: 18px;
	line-height: 1.4;
	font-weight: 700;
}

.contact-general-contact .contact-form__required {
	color: var(--contact-form-required);
	font-size: 12px;
	margin-left: 4px;
	font-weight: 700;
}

.contact-general-contact .contact-form__help {
	font-size: 12px;
	color: var(--contact-form-help);
	margin: 3px 0 10px !important;
	line-height: 1.5;
}

.contact-general-contact .contact-form__input,
.contact-general-contact .contact-form__textarea {
	width: 100%;
	border: 1px solid var(--contact-form-input-border);
	background: var(--contact-form-input-bg);
	color: var(--contact-form-text);
	font-size: 14px;
	box-sizing: border-box;
	border-radius: 6px;
}

.contact-general-contact .contact-form__input {
	height: 48px;
	padding: 0 12px;
}

.contact-general-contact .contact-form__textarea {
	min-height: clamp(180px, 30vw, 240px);
	padding: 12px;
	resize: vertical;
}

.contact-general-contact .contact-form__input:focus,
.contact-general-contact .contact-form__textarea:focus {
	outline: none;
	border-color: var(--contact-form-focus);
	box-shadow: 0 0 0 0.12rem rgba(5, 170, 125, 0.18);
}

.contact-general-contact .contact-form__agree {
	width: 100%;
	margin: 0 0 clamp(1rem, 3vw, 1.5rem);
}

.contact-general-contact .contact-form__agree > p {
	display: flex;
	justify-content: flex-start;
	margin: 0;
}

.contact-general-contact .contact-form__agree .wpcf7-list-item {
	margin: 0;
}

.contact-general-contact .contact-form__agree label {
	display: flex;
	align-items: flex-start;
	gap: clamp(0.45rem, 1.2vw, 0.65rem);
	color: var(--contact-form-text);
	font-size: 0.92rem;
	line-height: 1.6;
}

.contact-general-contact .contact-form__agree input[type="checkbox"] {
	flex: 0 0 auto;
	width: 0.95rem;
	height: 0.95rem;
	min-width: 0.95rem;
	margin: 0.2em 0 0;
	accent-color: var(--contact-form-focus);
}

.contact-general-contact .contact-form__agree .wpcf7-list-item-label {
	color: var(--contact-form-text);
}

.contact-general-contact .contact-form__agree a {
	color: var(--contact-form-link);
	text-decoration: underline;
	text-underline-offset: 0.18em;
}

.contact-general-contact .contact-form__submit {
	width: 100%;
}

.contact-general-contact .contact-form__submit > p {
	margin: 0;
}

.contact-general-contact .contact-form__submit input.wpcf7-submit {
	width: 100%;
	height: 56px;
	border: 0;
	border-radius: 6px;
	background: var(--contact-form-submit-bg);
	color: var(--contact-form-submit-text);
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.04em;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.contact-general-contact .contact-form__submit input.wpcf7-submit:hover:not(:disabled) {
	background: var(--contact-form-submit-hover);
	transform: translateY(-0.05rem);
	box-shadow: 0 0.35rem 1rem rgba(0, 0, 0, 0.16);
}

.contact-general-contact .contact-form__submit input.wpcf7-submit:disabled {
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

.contact-general-contact .contact-form__submit .wpcf7-spinner {
	display: block;
	margin: 0.5rem auto 0;
}

@media (max-width: 480px) {
	.contact-general-contact .contact-form-section__body {
		max-width: 100%;
	}
	.contact-general-contact .contact-form__field {
		margin-bottom: 24px;
	}
}

#lab-tour-form {
	scroll-margin-top: 50px;
}

#general-contact-form {
	scroll-margin-top: 70px;
}
