@charset "utf-8";

/* =============================================
   Park Tower Hall - WEBフォーム スタイル
   main.css の設計トークン準拠
   ============================================= */

:root {
	--color-primary: #0c7b49;
	--color-primary-hover: #369168;
	--color-primary-light: #d9ece4;
	--color-primary-pale: #f0f8f4;
	--color-bg-section: #f8f6ef; /* .l-block:nth-of-type(odd) と同値 */
	--color-white: #fff;
	--color-text: #2a2a2a;
	--color-text-sub: #666;
	--color-border: #e7e7e7;
	--color-footer-bg: #5e5e5e; /* .l-footer と同値 */
	/* fonts */
	--font-noto: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", 游ゴシック Medium, YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif;
	--font-dm: "DM Sans", sans-serif;
	--font-zen: "Zen Kaku Gothic New", sans-serif;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	font-size: 62.5%;
}

body {
	background-color: var(--color-white);
	color: var(--color-text);
	font-family: var(--font-noto);
	font-size: 1.6rem; /* main.css と同値 */
	line-height: 1.5; /* main.css と同値 */
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	margin: 0;
	padding: 0;
}

a {
	color: var(--color-text);
	text-decoration: none;
	display: block;
}
ul,
ol {
	list-style: none;
	margin: 0;
	padding: 0;
}
img {
	max-width: 100%;
	height: auto;
	display: block;
}

/* ===== Inner ===== */
.l-inner {
	max-width: 1472px;
	width: 100%;
	margin-inline: auto;
	padding-inline: 20px;
}
.l-inner--narrow {
	max-width: 1024px;
	margin: 0 auto;
}

@media only screen and (max-width: 768px) {
	.l-inner--narrow {
		width: 100%;
		padding-inline: 8.5333333333vw;
	}
}

/* main.css .l-under-inner と同値 */
.l-under-inner {
	max-width: 1024px;
	margin-inline: auto;
}
@media only screen and (max-width: 768px) {
	.l-under-inner {
		padding-inline: 8.5333333333vw;
	}
}

/* ===== HEADER ===== */
.l-header {
	background-color: var(--color-white);
	/* border-bottom: solid 1px var(--color-border); */
	position: sticky;
	top: 0;
	z-index: 9999;
}
.l-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-block: 16px;
	padding-inline: 40px;
	max-width: 1472px;
	margin-inline: auto;
}

/* ロゴ：main.css の .l-header+.p-logo-link と同等サイズ感 */
.p-logo-link {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	transition: 0.3s;
}
.p-logo-link:hover {
	opacity: 0.6;
}

.p-logo-svg,
.p-logo-white,
.p-logo-black {
	width: 77px; /* main.css .l-header+.p-logo-link width:77px */
	height: auto;
}

/* ヘッダー右側CVボタン群 */
.p-nav-btn-wrap {
	display: flex;
	flex-direction: row;
	gap: 8px;
	align-items: center;
}

/* main.css .p-btn__cv と同値 */
.p-btn__cv {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 8px;
	width: 184px;
	height: 48px;
	font-size: 1.3rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	white-space: nowrap;
	border-radius: calc(infinity * 1px); /* ピル型 */
	cursor: pointer;
	transition: background-color 0.3s;
}
/* main.css .p-btn__green */
.p-btn__green {
	background-color: var(--color-primary);
	border: solid 2px var(--color-primary);
	color: var(--color-white);
}
.p-btn__green:hover {
	background-color: var(--color-white);
	color: var(--color-primary);
}
/* main.css .p-btn__white */
.p-btn__white {
	background-color: var(--color-white);
	border: solid 2px var(--color-primary);
	color: var(--color-primary);
}
.p-btn__white:hover {
	background-color: var(--color-primary);
	color: var(--color-white);
}

/* ===== PAGE HEADING (c-under-heading 相当) ===== */
.l-under-top {
	/* background-color: var(--color-bg-section); */
	background-color: #fff;
	text-align: center;
	/* padding-block: 64px; */
}

.c-under-heading {
	padding-block: 0;
}

/* main.css .c-heading-6_dm と同値 */
.c-heading-6_dm {
	font-size: 6.4rem;
	line-height: 1.3;
	font-family: var(--font-dm);
	font-weight: 600;
	color: var(--color-primary);
	letter-spacing: 0.05em;
	margin: 0;
}

/* main.css .c-heading-5 と同値（CONTACTサブ見出し用） */
.c-heading-5 {
	font-size: 1.8rem;
	line-height: 1.6;
	font-family: var(--font-zen);
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--color-text);
	margin: 8px 0 0;
}

/* main.css .c-heading-4 と同値 */
.c-heading-4 {
	font-size: 2.8rem;
	line-height: 1.6;
	font-family: var(--font-zen);
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--color-text);
	margin: 0;
}

/* ===== BREADCRUMB ===== */
.c-bread {
	background-color: var(--color-white);
	/* border-bottom: solid 1px var(--color-border); */
	padding-block: 12px;
}
.c-bread ol {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	align-items: center;
	font-size: 1.2rem;
	color: var(--color-text-sub);
}
.c-bread li + li::before {
	content: "›";
	margin-right: 4px;
	color: #bbb;
}
.c-bread a {
	display: inline;
	color: var(--color-primary);
}
.c-bread a:hover {
	text-decoration: underline;
}

/* ===== MAIN ===== */
.l-main,
.l-block {
	background-color: var(--color-white);
	padding-block: 80px 120px;
}

/* リードテキスト */
.form_text {
	font-size: 1.6rem;
	line-height: 1.8;
	color: var(--color-text);
	white-space: pre-line;
	width: fit-content;
	margin-inline: auto;
	text-align: left;
}
.form_text:empty {
	display: none;
}
.p-form-lead {
	font-size: 1.6rem;
	line-height: 1.8;
	color: var(--color-text);
	margin-bottom: 40px;
}
.p-form-lead p + p {
	margin-top: 8px;
}

/* フォームコンテナ */
.p-form-box {
	background-color: var(--color-white);
}

/* セクション見出し（OUTLINE / CHARGE 相当） */
.p-form-section-heading {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-bottom: 32px;
	padding-bottom: 16px;
	border-bottom: solid 2px var(--color-primary); /* .u-border-bottom と同値 */
}
.p-form-section-heading .en {
	font-size: 2.4rem;
	font-family: var(--font-dm);
	font-weight: 600;
	color: var(--color-primary);
	letter-spacing: 0.05em;
	line-height: 1.3;
}
.p-form-section-heading .ja {
	font-size: 1.6rem;
	font-family: var(--font-zen);
	font-weight: 600;
	color: var(--color-text);
	letter-spacing: 0.02em;
}

/* ===== SAASKE FORM ===== */

/* 必須注記 */
#require {
	font-size: 1.3rem;
	color: var(--color-text-sub);
	margin-bottom: 24px;
}

article.resp {
	float: none;
	margin: 64px auto;
	position: relative;
}
article.resp > form {
	float: none;
	margin: 0 auto;
	overflow: hidden;
	width: 100%;
}
article.resp > form > ul.form_list {
	margin-bottom: 0;
}

/* ラベルセクション行 */
article.resp form li.label {
	background-color: var(--color-bg-section);
	border-left: 4px solid var(--color-primary);
	font-size: 2.4rem;
	font-weight: 700;
	font-family: var(--font-zen);
	overflow: hidden;
	padding: 10px 16px;
	position: relative;
	color: var(--color-text);
	margin-top: 0 !important;
	margin-bottom: 24px;
}
/* 最初の li.label 以外は上マージン */
article.resp form li.label + li.label,
article.resp form li.clr + li.label {
	margin-top: 32px !important;
}

/* フォーム各行 */
article.resp form li.clr {
	display: flex;
	align-items: flex-start;
	margin-top: 0 !important;
	padding-block: 20px;
	overflow: hidden;
	border-bottom: solid 1px var(--color-border);
}

/* フィールドラベル */
article.resp form li.clr label.col.span_3,
article.resp form li.clr p.col.span_3 {
	background: transparent;
	cursor: inherit;
	float: none;
	/* font-size: 1.4rem; */
	padding: 6px 0;
	width: 220px;
	min-width: 220px;
	flex-shrink: 0;
	font-weight: 600;
	font-family: var(--font-noto);
	color: var(--color-text);
	line-height: 1.6;
}

/* 必須バッジ */
article.resp form li.clr label.col.span_3.required::after,
article.resp form li.clr p.col.span_3.required::after {
	content: "必須";
	display: inline-block;
	background-color: var(--color-primary);
	color: var(--color-white);
	font-size: 1rem;
	font-weight: 700;
	padding: 1px 7px;
	margin-left: 8px;
	vertical-align: middle;
	line-height: 1.8;
	letter-spacing: 0.05em;
}

/* 入力エリア */
article.resp form li.clr div.col.span_9 {
	float: none;
	flex: 1;
	padding-left: 24px;
	/* font-size: 1.4rem; */
}

article.resp form li.clr div.col.span_9 em {
	color: #e33e41;
	font-style: normal;
}
article.resp form li.clr div.col.span_9 img {
	max-width: 100%;
	width: auto;
	display: inline-block;
}

/* テキスト入力 / Email / Tel */
article.resp input[type="text"],
article.resp input[type="email"],
article.resp input[type="tel"],
article.resp input[type="password"],
article.resp input[type="number"] {
	border: solid 1px var(--color-border);
	border-radius: 3px;
	font-size: 1.6rem;
	padding: 8px 12px;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	background-color: var(--color-white);
	color: var(--color-text);
	font-family: var(--font-noto);
	transition:
		border-color 0.2s,
		box-shadow 0.2s;
	-webkit-appearance: none;
	appearance: none;
}

article.resp input[type="number"] {
	width: auto;
	max-width: 8em;
}

/* 日時入力（jQuery UI datepicker が付与する .hasDatepicker）は auto 幅 */
article.resp input.hasDatepicker {
	width: auto;
	max-width: 8em;
}

/* 郵便番号などの短幅 input は auto 幅 */
article.resp input[type="text"][size="6"],
article.resp input[type="text"][size="7"],
article.resp input[type="text"][size="8"],
article.resp input[type="text"][size="10"],
article.resp input[type="text"][size="12"] {
	width: auto;
	max-width: none;
}

/* 直接並列 input（tel分割・郵便番号分割など） */
article.resp form li.clr div.col.span_9:has(> input[type="text"] ~ input[type="text"]) {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px 6px;
}
article.resp form li.clr div.col.span_9:has(> input[type="text"] ~ input[type="text"]) > p {
	flex: 0 0 100%; /* f_comt / f_comb は独立行に */
}
article.resp form li.clr div.col.span_9:has(> input[type="text"] ~ input[type="text"]) > input[type="text"]:not(.hasDatepicker) {
	flex: 1 1 0;
	width: auto;
	min-width: 0;
}

/* 分割郵便番号（size="6" + size="8"）は伸縮なし・auto幅 */
article.resp form li.clr div.col.span_9:has(> input[type="text"][size="6"]) > input[type="text"][size="6"],
article.resp form li.clr div.col.span_9:has(> input[type="text"][size="6"]) > input[type="text"][size="8"] {
	flex: 0 0 auto;
	width: auto;
	max-width: 12em;
}

/* 住所セット：〒input + 住所変換ボタンを含む <p> は横並び */
article.resp div.col.span_9 p:has(> input[type="button"]) {
	display: flex;
	align-items: center;
	flex-wrap: nowrap;
	gap: 8px;
}
/* 住所セット内の郵便番号 input はPC時 auto幅（ボタンと隣接） */
article.resp div.col.span_9 p:has(> input[type="button"]) > input[type="text"] {
	flex: 0 0 auto;
	width: auto;
}

/* 日時：datepicker input + select が同一 div.col.span_9 に並ぶ場合は横並び（折り返し許可） */
article.resp form li.clr div.col.span_9:has(> input.hasDatepicker):has(> select) {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
}
article.resp form li.clr div.col.span_9:has(> input.hasDatepicker):has(> select) > p:empty {
	display: none;
}
/* 日時：日付 input は見切れない幅を固定確保 */
article.resp form li.clr div.col.span_9:has(> input.hasDatepicker):has(> select) > input.hasDatepicker {
	flex: 0 0 auto;
	width: 8em;
	min-width: 8em;
	max-width: none;
}
/* 日時：時間 select は最低限の幅を確保 */
article.resp form li.clr div.col.span_9:has(> input.hasDatepicker):has(> select) > select {
	flex: 0 0 auto;
	min-width: 4.5em;
}
/* jQuery UI datepicker がステップ表示より前面に表示されるよう z-index を上書き */
.ui-datepicker {
	z-index: 9999 !important;
}

.ui-datepicker-title {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
}

.ui-datepicker-title select {
	font-size: 1.6rem !important;
	padding: 4px 2px !important;
	height: 36px !important;
	line-height: 1 !important;
	margin: 0 !important;
	box-sizing: border-box !important;
	vertical-align: middle;
}

/* テキストエリア */
article.resp textarea {
	border: solid 1px var(--color-border);
	border-radius: 3px;
	font-size: 1.4rem;
	padding: 8px 12px;
	width: 100%;
	background-color: var(--color-white);
	color: var(--color-text);
	font-family: var(--font-noto);
	transition:
		border-color 0.2s,
		box-shadow 0.2s;
	height: 130px;
	resize: vertical;
	box-sizing: border-box;
	max-width: 100%;
	display: block;
}

/* セレクト */
article.resp div.col.span_9 select {
	border: solid 1px var(--color-border);
	border-radius: 3px;
	font-size: 1.6rem;
	padding: 8px 36px 8px 12px;
	max-width: 340px;
	/* width: 100%; */
	background-color: var(--color-white);
	color: var(--color-text);
	font-family: var(--font-noto);
	transition:
		border-color 0.2s,
		box-shadow 0.2s;
	-webkit-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230C7B49' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
}

/* フォーカス */
article.resp input[type="text"]:focus,
article.resp input[type="email"]:focus,
article.resp input[type="tel"]:focus,
article.resp input[type="password"]:focus,
article.resp input[type="number"]:focus,
article.resp textarea:focus,
article.resp div.col.span_9 select:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px rgba(12, 123, 73, 0.12);
}

/* 姓名並列 */
.input-name-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 16px;
	align-items: center;
}
.input-name-wrap span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 1.4rem;
}

/* 姓・名 / セイ・メイ / せい・めい インライン span 構造 */
article.resp form li.clr div.col.span_9:has(> span) {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	gap: 8px;
}
article.resp form li.clr div.col.span_9 > span {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	flex: 1;
	min-width: 0;
	white-space: nowrap;
	font-size: 1.4rem;
}
article.resp form li.clr div.col.span_9 > span input[type="text"] {
	width: 100%;
	max-width: 100%;
	min-width: 0;
}

/* チェックボックス / ラジオラベル */
article.resp div.col.span_9 label {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	cursor: pointer;
	/* font-size: 1.4rem; */
	font-weight: 400;
	padding: 3px 0;
	line-height: 1.6;
}
/* article.resp div.col.span_9 label + br {
	display: none;
} */

.radio-group,
.checkbox-group {
	display: flex;
	flex-wrap: wrap;
	gap: 2px 0;
	flex-direction: column;
}
article.resp div.col.span_9 input[type="checkbox"],
article.resp div.col.span_9 input[type="radio"] {
	width: 16px;
	height: 16px;
	min-width: 16px;
	cursor: pointer;
	accent-color: var(--color-primary);
	margin: 0;
}

/* コメントテキスト */
article.resp .f_comt,
article.resp .f_comb {
	font-size: 1.2rem;
	margin: 0;
	color: var(--color-text-sub);
	line-height: 1.6;
}
article.resp .f_comt {
	margin-bottom: 6px;
}
article.resp .f_comb {
	margin-top: 6px;
}

/* ===== 送信ボタン（.c-btn__primary 準拠） ===== */
.row.submit_btn {
	text-align: center;
	margin-top: 48px;
}

/* ===== 確認画面：項目名と回答の整列 ===== */
article.resp form ul.check_page li.clr {
	display: flex;
	align-items: center;
}
article.resp form ul.check_page li.clr > label {
	flex: 0 0 25%;
	float: none;
}
article.resp form ul.check_page li.clr > div.input {
	flex: 1 1 0;
	float: none;
	min-width: 0;
}

/* ===== 確認画面：戻る・送信ボタンエリア ===== */
article.resp form > div.col.span_3.submit_btn,
article.resp form > div.col.span_9.submit_btn {
	float: left;
	margin-top: 48px;
	text-align: center;
	padding: 0;
}
article.resp form > div.col.span_3.submit_btn {
	width: 30%;
}
article.resp form > div.col.span_9.submit_btn {
	width: 70%;
}
/* 戻るボタン（セカンダリ） */
article.resp form > div.col.span_3.submit_btn input[type="button"] {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 180px;
	padding: 14px 32px;
	background-color: var(--color-white);
	color: var(--color-text-sub);
	border: solid 2px var(--color-border);
	border-radius: calc(infinity * 1px);
	font-size: 1.6rem;
	font-weight: 500;
	font-family: var(--font-noto);
	letter-spacing: 0.05em;
	cursor: pointer;
	transition: background-color 0.3s;
}
article.resp form > div.col.span_3.submit_btn input[type="button"]:hover {
	background-color: #f5f5f5;
}
/* 送信ボタン（プライマリ） */
article.resp form > div.col.span_9.submit_btn input[type="submit"] {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 400px;
	padding: 24px 64px;
	background-color: var(--color-primary);
	color: var(--color-white);
	border: none;
	border-radius: calc(infinity * 1px);
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	line-height: 1.5;
	font-family: var(--font-noto);
	cursor: pointer;
	transition: background-color 0.3s;
}
article.resp form > div.col.span_9.submit_btn input[type="submit"]:hover {
	background-color: var(--color-primary-hover);
}
article.resp form > div.col.span_9.submit_btn input[type="submit"]:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}
.row.submit_btn input[type="submit"] {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 400px;
	border-radius: calc(infinity * 1px); /* ピル型 .c-btn と同値 */
	padding: 24px 64px; /* .c-btn と同値 */
	background-color: var(--color-primary);
	color: var(--color-white);
	border: none;
	font-size: 1.8rem; /* .c-btn span と同値 */
	font-weight: 500; /* .c-btn span と同値 */
	letter-spacing: 0.1em; /* .c-btn span と同値 */
	line-height: 1.5;
	font-family: var(--font-noto);
	cursor: pointer;
	transition: background-color 0.3s;
	position: relative;
}
.row.submit_btn input[type="submit"]:hover {
	background-color: var(--color-primary-hover); /* #369168 */
}
.row.submit_btn input[type="submit"]:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* ===== type="button"（住所変換など補助ボタン） ===== */
article.resp input[type="button"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 16px;
	background-color: var(--color-white);
	color: var(--color-primary);
	border: solid 1.5px var(--color-primary);
	border-radius: 3px;
	font-size: 1.3rem;
	font-weight: 600;
	font-family: var(--font-noto);
	letter-spacing: 0.05em;
	cursor: pointer;
	transition:
		background-color 0.2s,
		color 0.2s;
	vertical-align: middle;
}
article.resp input[type="button"]:hover {
	background-color: var(--color-primary);
	color: var(--color-white);
}

/* ===== 個人情報 ===== */
.resp .policy {
	background: var(--color-white);
	box-sizing: border-box;
	border: solid 1px var(--color-border);
	border-radius: 3px;
	margin: 8px 0;
	padding: 0;
}
.resp .policy * {
	box-sizing: border-box;
}
.resp .policy #pri {
	border: none !important;
	margin: 0;
	overflow: initial;
	padding: 0;
}
article.resp .policy h2 {
	display: none;
	margin-top: 0;
}
article.resp .policy .policy_html {
	overflow-y: scroll;
	height: 150px;
	padding: 16px 20px;
	text-align: left;
	-webkit-overflow-scrolling: touch;
	font-size: 1.3rem;
	line-height: 1.8;
}
article.resp .policy .policy_check {
	background: var(--color-bg-section);
	/* font-size: 1.3rem; */
	padding: 12px 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	border-top: solid 1px var(--color-border);
	box-sizing: border-box;
}
article.resp .policy .policy_check label {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	/* font-size: 1.3rem; */
	font-weight: 500;
	line-height: 1.5;
	color: var(--color-text);
}

/* カスタムチェックボックス */
article.resp .policy .policy_check input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	width: 18px;
	height: 18px;
	min-width: 18px;
	border: 2px solid var(--color-border);
	border-radius: 3px;
	background-color: var(--color-white);
	cursor: pointer;
	position: relative;
	transition:
		background-color 0.2s,
		border-color 0.2s;
	margin: 0;
}
article.resp .policy .policy_check input[type="checkbox"]:checked {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
}
article.resp .policy .policy_check input[type="checkbox"]:checked::after {
	content: "";
	position: absolute;
	left: 4px;
	top: 1px;
	width: 6px;
	height: 10px;
	border: 2px solid var(--color-white);
	border-top: none;
	border-left: none;
	transform: rotate(45deg);
}
article.resp .policy .policy_check input[type="checkbox"]:focus-visible {
	outline: none;
	box-shadow: 0 0 0 3px rgba(12, 123, 73, 0.2);
}
.policy_msg {
	display: none;
}

/* 個人情報利用目的 */
.p-form-privacy {
	margin-top: 32px;
	font-size: 1.3rem;
	line-height: 1.9;
	color: var(--color-text-sub);
	padding: 20px 24px;
	background-color: var(--color-bg-section);
}
.p-form-privacy a {
	display: inline;
	color: var(--color-primary);
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* ===== サンクス画面 ===== */
article.resp:has(.msgbox) {
	margin-top: 0;
}
article.resp .msgbox {
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
	padding: 0 0 48px;
}
article.resp .msgbox h2 {
	font-size: 2.4rem;
	font-family: var(--font-zen);
	font-weight: 700;
	color: var(--color-primary);
	margin: 0 0 40px;
	line-height: 1.5;
	letter-spacing: 0.02em;
}
article.resp .msgbox .message {
	font-size: 1.5rem;
	line-height: 1.9;
	width: fit-content;
	margin-inline: auto;
	color: var(--color-text);
	text-align: left;
}
article.resp .msgbox .message a {
	display: inline;
	color: var(--color-primary);
	text-decoration: underline;
	text-underline-offset: 2px;
	word-break: break-all;
}
/* サンクス画面 お戻りボタン */
div.col.span_12.submit_btn {
	text-align: center;
	margin-top: 48px;
}
div.col.span_12.submit_btn input[type="submit"] {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 280px;
	padding: 18px 48px;
	background-color: var(--color-white);
	color: var(--color-primary);
	border: solid 2px var(--color-primary);
	border-radius: calc(infinity * 1px);
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	font-family: var(--font-noto);
	cursor: pointer;
	transition:
		background-color 0.3s,
		color 0.3s;
}
div.col.span_12.submit_btn input[type="submit"]:hover {
	background-color: var(--color-primary);
	color: var(--color-white);
}

/* ===== TEL ブロック ===== */
.c-tel-block {
	margin-top: 40px;
	padding: 24px 32px;
	background-color: var(--color-bg-section);
	display: flex;
	align-items: center;
	gap: 24px;
	flex-wrap: wrap;
}
.c-tel-block__label {
	font-size: 1.4rem;
	font-weight: 600;
	color: var(--color-text);
}
.c-tel-block__hours {
	font-size: 1.2rem;
	color: var(--color-text-sub);
	margin-top: 2px;
}
/* main.css .c-tel と同値（DM Sansで大きめの電話番号） */
.c-tel-block__tel {
	display: inline;
	font-family: var(--font-dm);
	font-size: 2.8rem;
	font-weight: 900;
	color: var(--color-primary);
	letter-spacing: 0.04em;
	line-height: 1.5;
}
.c-tel-block__tel:hover {
	opacity: 0.7;
}

/* ===== FOOTER（main.css .l-footer 準拠） ===== */
.l-footer {
	background: var(--color-footer-bg); /* #5e5e5e */
	position: relative;
	z-index: 10;
}
.l-footer * {
	color: var(--color-white);
} /* main.css .l-footer * と同値 */
.l-footer a {
	width: fit-content;
}

.l-footer-top {
	padding-block: 64px 80px;
}
.l-footer-inner {
	display: flex;
	justify-content: space-between;
	width: 100%;
	padding-inline: 40px;
}
.p-footer-info {
	flex-shrink: 0;
}

/* main.css .c-text-dm-28__150-bl 相当 */
.p-footer-logo {
	font-family: var(--font-dm);
	font-size: 2.4rem;
	font-weight: 900;
	letter-spacing: 0.06em;
	line-height: 1;
	margin-bottom: 24px;
}
.p-footer-logo small {
	display: block;
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: 0.15em;
	margin-top: 6px;
	opacity: 0.7;
}

/* main.css .c-text-noto-16__180-bo 相当 */
.p-footer-company {
	font-size: 1.6rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.8;
	margin-bottom: 2px;
}
/* main.css .c-text-noto-14__130-me 相当 */
.p-footer-dept {
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	line-height: 1.3;
	opacity: 0.7;
	margin-bottom: 16px;
}
/* main.css .c-text-noto-16__180-re 相当 */
.p-footer-address {
	font-size: 1.6rem;
	line-height: 1.8;
	letter-spacing: 0.04em;
	margin-bottom: 16px;
}
/* main.css .c-tel .c-text-dm-28__150-bl 相当 */
.p-footer-tel a {
	display: inline;
	font-family: var(--font-dm);
	font-size: 2.8rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	line-height: 1.5;
}
.p-footer-hours {
	font-size: 1.4rem;
	line-height: 1.8;
	letter-spacing: 0.04em;
	opacity: 0.6;
	margin-top: 4px;
}

/* サイトマップ */
.p-sitemap {
	display: flex;
	gap: 48px;
}
.p-sitemap-col {
	display: flex;
	flex-direction: column;
	gap: 24px;
}
.p-sitemap-col > div {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
/* main.css .c-text-noto-16__180-bo 相当 */
.p-sitemap a.parent {
	font-size: 1.6rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.8;
}
/* main.css .c-text-noto-16__130-re 相当 */
.p-sitemap a {
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.3;
	transition: opacity 0.2s;
}
.p-sitemap a:hover {
	opacity: 0.6;
}

/* フッター下部 */
.l-footer-bottom {
	border-top: solid 1px #e7e7e7;
	padding-block: 32px; /* main.css .l-footer-bottom と同値 */
}
.l-footer-bottom-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
	padding-inline: 40px;
}
.p-link {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
}
/* main.css .c-text-noto-14__130-me 相当 */
.p-link a {
	display: inline;
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	line-height: 1.3;
	transition: opacity 0.2s;
}
.p-link a:hover {
	opacity: 0.6;
}

/* main.css .p-copy .c-text-dm-12__150-re 相当 */
.p-copy {
	font-family: var(--font-dm);
	font-size: 1.2rem;
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.5;
	opacity: 0.6;
}

/* .c-center-txt（main.css と同値） */
.c-center-txt {
	text-align: center;
}

/* u-pc-element：SP 非表示（main.css と同値） */
@media only screen and (max-width: 768px) {
	.u-pc-element {
		display: none !important;
	}
}

/* アトリウムオプション無効スタイル */
label.atrium-option-disabled {
	opacity: 0.4;
	color: #999;
	cursor: not-allowed;
	pointer-events: none;
}

/* ===== RESPONSIVE ===== */
@media only screen and (max-width: 768px) {
	html {
		font-size: 55%;
	}
	body {
		font-size: 4.2666666667vw;
	} /* main.css と同値 */

	.l-header-inner {
		padding-inline: 5.3333333333vw;
	}
	.p-nav-btn-wrap {
		display: none;
	}

	/* .l-under-top {
		padding-block: 10.6666666667vw 8vw;
	} */
	.c-heading-6_dm {
		font-size: 10.6666666667vw;
		margin: 0;
	}
	.c-heading-4 {
		font-size: 5.8666666667vw;
		margin: 0;
	}

	.l-main,
	.l-block {
		padding-block: 17.0666666667vw;
	}

	/* サンクス画面 SP */
	article.resp .msgbox {
		padding: 32px 0;
	}
	article.resp .msgbox h2 {
		font-size: 2rem;
		margin-bottom: 24px;
	}
	div.col.span_12.submit_btn input[type="submit"] {
		width: 100%;
	}

	article.resp form li.clr {
		flex-direction: column;
		padding-block: 16px;
	}

	article.resp form li.label {
		font-size: 5.3333333333vw;
	}

	article.resp form li.clr label.col.span_3,
	article.resp form li.clr p.col.span_3 {
		width: 100%;
		min-width: 100%;
		padding-bottom: 6px;
	}
	article.resp form li.clr div.col.span_9 {
		padding-left: 0;
		width: 100%;
	}
	.input-name-wrap {
		flex-direction: column;
		gap: 6px;
	}
	.input-name-wrap span {
		width: 100%;
	}
	.input-name-wrap input {
		width: 100% !important;
		max-width: 100% !important;
	}

	/* 日時：SP では date input + カレンダーアイコンで1行を埋め、時間 select を次行へ確実に送る */
	article.resp form li.clr div.col.span_9:has(> input.hasDatepicker):has(> select) > input.hasDatepicker {
		flex: 1 0 calc(100% - 70px); /* 70px = img幅(最大64px) + gap(6px) のバッファ */
		width: auto;
		min-width: 0;
		max-width: none;
	}
	article.resp form li.clr div.col.span_9:has(> input.hasDatepicker):has(> select) > img {
		flex: 0 0 auto;
		max-width: none; /* グローバルの max-width: 100% による拡大を防ぐ */
	}

	/* 住所セット：SP時は郵便番号 input を縮小可能にしてボタンを押し出さない */
	article.resp div.col.span_9 p:has(> input[type="button"]) > input[type="text"] {
		flex: 1 1 0;
		min-width: 0;
	}

	/* 姓・名 / セイ・メイ / せい・めい SP */
	article.resp form li.clr div.col.span_9:has(> span) {
		flex-wrap: nowrap; /* 横並びを維持 */
		gap: 6px;
	}
	article.resp form li.clr div.col.span_9 > span {
		flex: 1;
		min-width: 0;
	}
	article.resp form li.clr div.col.span_9 > span input[type="text"] {
		width: 100%;
		max-width: 100%;
	}

	.row.submit_btn input[type="submit"] {
		width: 100%;
		padding: 18px 24px;
		font-size: 1.6rem;
		border-radius: calc(infinity * 1px);
	}

	/* 確認画面：戻る・送信ボタン SP */
	article.resp form > div.col.span_3.submit_btn,
	article.resp form > div.col.span_9.submit_btn {
		float: none;
		width: 100%;
		margin-top: 16px;
	}
	article.resp form > div.col.span_3.submit_btn {
		order: 2;
		margin-top: 8px;
	}
	article.resp form > div.col.span_3.submit_btn input[type="button"] {
		width: 100%;
	}
	article.resp form > div.col.span_9.submit_btn input[type="submit"] {
		width: 100%;
		padding: 18px 24px;
		font-size: 1.6rem;
	}

	.c-tel-block {
		flex-direction: column;
		gap: 8px;
		padding: 20px;
	}

	.l-footer-inner {
		flex-direction: column;
		padding-inline: 8.5333333333vw;
		gap: 32px;
	}
	.l-footer-bottom-inner {
		flex-direction: column;
		align-items: flex-start;
		padding-inline: 8.5333333333vw;
	}
	.p-sitemap {
		gap: 24px;
	}
}

/* ===== Form Step Indicator ===== */
#js-form-steps {
	padding-top: 32px;
	margin-bottom: 40px;
}

.p-form-step-list {
	--step-arrow: 18px;
	--step-h: 48px;
	display: flex;
	width: 100%;
}

.p-form-step-item {
	flex: 1;
	height: var(--step-h);
	display: flex;
	align-items: center;
	justify-content: center;
	background: #efefef;
	color: #aaa;
	font-family: var(--font-noto);
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	white-space: nowrap;
	position: relative;
	margin-right: calc(-1 * var(--step-arrow));
	padding: 0 calc(var(--step-arrow) + 16px);
}

.p-form-step-item:last-child {
	margin-right: 0;
}

/* 1番目：左フラット・右矢印 */
.p-form-step-item:nth-child(1) {
	z-index: 4;
	clip-path: polygon(
		0 0,
		calc(100% - var(--step-arrow)) 0,
		100% 50%,
		calc(100% - var(--step-arrow)) 100%,
		0 100%
	);
}

/* 2番目：左インデント・右矢印 */
.p-form-step-item:nth-child(2) {
	z-index: 3;
	clip-path: polygon(
		0 0,
		calc(100% - var(--step-arrow)) 0,
		100% 50%,
		calc(100% - var(--step-arrow)) 100%,
		0 100%,
		var(--step-arrow) 50%
	);
}

/* 3番目：左インデント・右フラット */
.p-form-step-item:nth-child(3) {
	z-index: 2;
	clip-path: polygon(
		0 0,
		100% 0,
		100% 100%,
		0 100%,
		var(--step-arrow) 50%
	);
}

/* アクティブのみグリーン */
.p-form-step-item.is-active {
	background: var(--color-primary);
	color: var(--color-white);
	font-weight: 700;
}

.p-form-step-label {
	position: relative;
	z-index: 1;
}

@media only screen and (max-width: 768px) {
	.p-form-step-list {
		--step-arrow: 12px;
		--step-h: 40px;
	}

	#js-form-steps {
		padding-top: 24px;
		margin-bottom: 28px;
	}

	.p-form-step-item {
		font-size: 1.2rem;
		padding: 0 calc(var(--step-arrow) + 8px);
	}
}

/* ===== Input auto-width with inline prefix/suffix ===== */
.input.has-inline-text {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px;
}

.input.has-inline-text p.f_comt,
.input.has-inline-text p.f_comb {
	width: 100%;
	flex-shrink: 0;
}

.input.has-inline-text input[type="text"],
.input.has-inline-text input[type="email"],
.input.has-inline-text input[type="number"],
.input.has-inline-text input[type="password"],
.input.has-inline-text input[type="tel"],
.input.has-inline-text select,
.input.has-inline-text textarea {
	flex: 1;
	min-width: 80px;
}

/* ===== SP: ヒーローイメージ背景が途切れる問題の修正 ===== */
@media only screen and (max-width: 768px) {
	.l-under-top {
		background-size: cover !important;
	}
	.l-under-top::before,
	.l-under-top::after {
		height: 100% !important;
		min-height: 100% !important;
		background-size: cover !important;
	}
	.c-under-heading {
		background-size: cover !important;
		height: auto !important;
		min-height: auto !important;
	}
	.c-under-heading::before,
	.c-under-heading::after {
		height: 100% !important;
		min-height: 100% !important;
		background-size: cover !important;
	}
}
