/**
 * Open Campus Reservation Page Styles
 * Figma: PC 1497-11281 / TB 1573-34420 / SP 1573-34396
 *
 * @package Senmon_School
 */

/* ベース */
.senmon-school-reservation {
	background-color: var(--senmon-color-white);
	color: var(--senmon-color-gray-90);
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 14px;
	line-height: 2;
	letter-spacing: 0.05em;
}

.senmon-school-reservation__outer {
	padding: 120px 0;
	box-sizing: border-box;
}

.senmon-school-reservation__inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--senmon-page-gutter-x);
	box-sizing: border-box;
}

/* PC: メイン + その他の連絡方法（横並び） */
.senmon-school-reservation__layout {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: 40px;
}

.senmon-school-reservation__main {
	flex: 0 1 720px;
	display: flex;
	flex-direction: column;
	gap: 48px;
	min-width: 0;
}

.senmon-school-reservation__sidebar {
	flex: 0 0 200px;
	margin-top: -24px;
}

/* SP: 下部固定バー分の余白（Figma 90px） */
@media (max-width: 600px) {
	.senmon-school-reservation__outer {
		padding: 40px 0 130px;
	}
}

/* セクションヘッダー（Figma: dot + JA + EN + lead） */
.senmon-school-reservation__header {
	display: flex;
	flex-direction: column;
}

.senmon-school-reservation__section-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.senmon-school-reservation__section-dot {
	width: 6px;
	height: 6px;
	border-radius: 100px;
	background-color: var(--senmon-color-primary);
}

@media (max-width: 600px) {
	.senmon-school-reservation__section-dot {
		width: 4px;
		height: 4px;
	}
}

.senmon-school-reservation__section-label-ja {
	font-family: var(--senmon-font-ja, 'Zen Maru Gothic', system-ui, sans-serif);
	font-weight: 700;
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: var(--senmon-color-primary);
}

.senmon-school-reservation__section-title {
	margin: 0;
	font-family: var(--senmon-font-nav);
	font-weight: 700;
	line-height: 1.5;
	color: var(--senmon-color-primary);
	font-size: 40px;
	letter-spacing: 2px;
}

.senmon-school-reservation__section-lead {
	margin: 0;
	padding-top: 16px;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 18px;
	line-height: 1.5;
	letter-spacing: 0.05em;
}

@media (max-width: 959px) {
	.senmon-school-reservation__outer {
		padding: 40px 0;
	}
	.senmon-school-reservation__section-title {
		font-size: 32px;
		letter-spacing: 0.04em;
	}
}

@media (max-width: 600px) {
	.senmon-school-reservation__section-title {
		font-size: 26px;
		letter-spacing: 0.1em;
	}
}

/* Event box */
.senmon-school-reservation__event-box {
	background: linear-gradient(180deg, rgba(245, 251, 90, 0.1) 0%, rgba(7, 189, 123, 0.1) 100%);
	padding: 24px;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.senmon-school-reservation__event-title {
	margin: 0;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 24px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: var(--senmon-color-primary);
}

.senmon-school-reservation__event-details {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.senmon-school-reservation__event-name {
	margin: 0;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: 0.05em;
}

.senmon-school-reservation__event-time {
	margin: 0;
	display: inline-flex;
	gap: 16px;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: 0.05em;
}

/* フォーム */
.senmon-school-reservation__form {
	display: flex;
	flex-direction: column;
	gap: 48px;
}

.senmon-school-form-group {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.senmon-school-form-group__label {
	margin: 0;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 18px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: var(--senmon-color-gray-90);
}

.senmon-school-form-group__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 72px;
	padding: 2px 8px;
	border-radius: 100px;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 12px;
	line-height: 1.5;
	letter-spacing: 0.05em;
}

.senmon-school-form-group__badge--required {
	background-color: var(--senmon-color-secondary-70);
	color: var(--senmon-color-white);
}

.senmon-school-form-group__badge--optional {
	background-color: var(--senmon-color-gray-10);
	color: var(--senmon-color-gray-70);
}

.senmon-school-form-group__note {
	margin: 0;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: var(--senmon-color-gray-90);
}

.senmon-school-form-group__input,
.senmon-school-form-group__textarea,
.senmon-school-form-group__select {
	width: 100%;
	box-sizing: border-box;
	padding: 16px;
	border-radius: 8px;
	border: 1px solid transparent;
	background-color: var(--senmon-color-gray-10);
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: var(--senmon-color-gray-90);
}

.senmon-school-form-group__textarea {
	min-height: 320px;
	resize: vertical;
}

.senmon-school-form-group__select {
	background-color: var(--senmon-color-white);
	border-color: var(--senmon-color-gray-90);
	padding-right: 48px;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='10' viewBox='0 0 16 10'%3E%3Cpath d='M1 1l7 7 7-7' fill='none' stroke='%231B1B1B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	background-size: 16px 10px;
}

.senmon-school-form-group__input:focus,
.senmon-school-form-group__textarea:focus,
.senmon-school-form-group__select:focus {
	outline: none;
	border-color: var(--senmon-color-primary);
}

.senmon-school-form-group__input::placeholder,
.senmon-school-form-group__textarea::placeholder {
	color: var(--senmon-color-gray-70);
	opacity: 1;
}

.senmon-school-form-group__help {
	display: none;
	margin: 0;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: var(--senmon-color-caution-red-100);
	/* margin-top: −16px; */
}

.senmon-school-form-group__checkbox-other-input {
	width: 100%;
}

.senmon-school-form-group__input--other {
	display: block;
}

/* TB */
@media (max-width: 959px) {
	.senmon-school-reservation__form {
		gap: 24px;
	}
}

/* チェックボックス */
.senmon-school-form-group__checkbox-group {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.senmon-school-form-group__checkbox-item {
	display: flex;
	align-items: center;
	gap: 16px;
}

.senmon-school-form-group__checkbox-item input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 20px;
	height: 20px;
	border-radius: 2px;
	border: 2px solid var(--senmon-color-gray-90);
	background-color: var(--senmon-color-white);
	cursor: pointer;
	position: relative;
	flex: 0 0 auto;
}

.senmon-school-form-group__checkbox-item input[type="checkbox"]:checked {
	background-color: var(--senmon-color-gray-90);
	border-color: var(--senmon-color-gray-90);
}

.senmon-school-form-group__checkbox-item input[type="checkbox"]:checked::after {
	content: '✓';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: var(--senmon-color-white);
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
}

.senmon-school-form-group__checkbox-item label {
	margin: 0;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	cursor: pointer;
}

/* ラジオボタン（Sessions などの単一選択。選択箇所は円形） */
.senmon-school-form-group__radio-group {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.senmon-school-form-group__radio-item {
	display: flex;
	align-items: center;
	gap: 16px;
}

.senmon-school-form-group__radio-item input[type="radio"] {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	border: 2px solid var(--senmon-color-gray-90);
	background-color: var(--senmon-color-white);
	cursor: pointer;
	position: relative;
	flex: 0 0 auto;
}

.senmon-school-form-group__radio-item input[type="radio"]:checked::after {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	background-color: var(--senmon-color-gray-90);
	border-radius: 50%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.senmon-school-form-group__radio-item label {
	margin: 0;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	cursor: pointer;
}

@media (max-width: 959px) {
	.senmon-school-form-group__checkbox-item {
		gap: 8px;
	}
	
	.senmon-school-form-group__checkbox-item input[type="checkbox"] {
		width: 16px;
		height: 16px;
	}

	.senmon-school-form-group__checkbox-item input[type="checkbox"]:checked::after {
		font-size: 12px;
	}

	.senmon-school-form-group__checkbox-item label {
		font-size: 14px;
	}

	.senmon-school-form-group__radio-item {
		gap: 8px;
	}

	.senmon-school-form-group__radio-item input[type="radio"] {
		width: 16px;
		height: 16px;
	}

	.senmon-school-form-group__radio-item input[type="radio"]:checked::after {
		width: 8px;
		height: 8px;
	}

	.senmon-school-form-group__radio-item label {
		font-size: 14px;
	}
}

/* プライバシー */
.senmon-school-reservation__privacy {
	margin-top: 8px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.senmon-school-reservation__privacy-text {
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 14px;
	line-height: 2;
	letter-spacing: 0.05em;
}

.senmon-school-reservation__privacy-link {
	color: #1e90ff;
	text-decoration: underline;
	text-decoration-skip-ink: none;
}

.senmon-school-reservation__privacy-checkbox {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.senmon-school-reservation__privacy-checkbox input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 18px;
	height: 18px;
	border-radius: 2px;
	border: 2px solid var(--senmon-color-gray-90);
	background-color: var(--senmon-color-white);
	cursor: pointer;
	position: relative;
	flex: 0 0 auto;
}

.senmon-school-reservation__privacy-checkbox input[type="checkbox"]:checked {
	background-color: var(--senmon-color-gray-90);
	border-color: var(--senmon-color-gray-90);
}

.senmon-school-reservation__privacy-checkbox input[type="checkbox"]:checked::after {
	content: '✓';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: var(--senmon-color-white);
	font-size: 16px;
	font-weight: 700;
	line-height: 1;
}

.senmon-school-reservation__privacy-checkbox label {
	margin: 0;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	cursor: pointer;
}

.senmon-school-reservation__notice {
	margin-top: 8px;
}

.senmon-school-reservation__notice-list {
	margin: 0;
	padding-left: 1.25em;
	list-style: disc;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 14px;
	line-height: 2;
	letter-spacing: 0.05em;
}

.senmon-school-reservation__notice-list li + li {
	margin-top: 8px;
}

/* reCAPTCHA（エラーメッセージはウィジェット直上） */
.senmon-school-reservation__recaptcha {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}

.senmon-school-reservation__recaptcha .senmon-school-form-group__error {
	align-self: stretch;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

/* 送信ボタン（見た目は contact.css の .senmon-school-contact__submit-button に統一） */
.senmon-school-reservation__submit.senmon-school-contact__field--submit {
	margin-top: 8px;
}

/* その他の連絡方法（Contact と同じコンポーネントを予約ページ内で使用） */
.senmon-school-reservation .senmon-school-other-ways {
	margin-top: 24px;
}

/* Reservation ページでは contact.css が読み込まれないため、必要最小限だけ再定義 */
.senmon-school-reservation .senmon-school-contact__sidebar {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.senmon-school-reservation .senmon-school-contact__sidebar-header {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.senmon-school-reservation .senmon-school-contact__sidebar-badge-row {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.senmon-school-reservation .senmon-school-contact__sidebar-dot {
	width: 6px;
	height: 6px;
	border-radius: 100px;
	background-color: var(--senmon-color-primary);
}

.senmon-school-reservation .senmon-school-contact__sidebar-label-ja {
	font-family: var(--senmon-font-ja, 'Zen Maru Gothic', system-ui, sans-serif);
	font-weight: 700;
	font-size: 14px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: var(--senmon-color-primary);
}

.senmon-school-reservation .senmon-school-contact__sidebar-title-en {
	margin: 0;
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 24px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: var(--senmon-color-primary);
}

.senmon-school-reservation .senmon-school-contact__actions {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.senmon-school-reservation .senmon-school-contact__action {
	margin: 0;
}

.senmon-school-reservation .senmon-school-contact__action-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	width: 100%;
	min-height: 50px;
	padding: 8px 16px;
	border-radius: 100px;
	background-color: var(--senmon-color-primary);
	color: var(--senmon-color-white);
	text-decoration: none;
	box-sizing: border-box;
	position: relative;
}

.senmon-school-contact__action-pill::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(180deg, #F5FB5A 0%, #07BD7B 100%);
    opacity: 0;
    transition: opacity var(--senmon-transition);
    pointer-events: none;
    z-index: 0;
}

.senmon-school-contact__action-pill:hover::before,
.senmon-school-contact__action-pill:focus::before {
	opacity: 1;
}

.senmon-school-reservation .senmon-school-contact__pill-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	color: var(--senmon-color-white);
	z-index: 1;
}

.senmon-school-reservation .senmon-school-contact__pill-icon-inner {
	width: 18px;
	height: 18px;
	display: block;
	background-color: var(--senmon-color-white);
	-webkit-mask-image: url("../../images/common/mail.svg");
	mask-image: url("../../images/common/mail.svg");
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-position: center;
	-webkit-mask-size: contain;
	mask-size: contain;
}

.senmon-school-reservation .senmon-school-contact__pill-icon--phone .senmon-school-contact__pill-icon-inner {
	-webkit-mask-image: url("../../images/common/phone.svg");
	mask-image: url("../../images/common/phone.svg");
}

.senmon-school-reservation .senmon-school-contact__pill-icon--whatsapp .senmon-school-contact__pill-icon-inner {
	-webkit-mask-image: url("../../images/common/WhatsApp.svg");
	mask-image: url("../../images/common/WhatsApp.svg");
	-webkit-mask-position: 50% 12%;
	mask-position: 50% 0%;
	-webkit-mask-size: 280% auto;
	mask-size: 280% auto;
}

.senmon-school-reservation .senmon-school-contact__pill-text {
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 14px;
	line-height: 2;
	letter-spacing: 0.05em;
	z-index: 1;
}

/* Figma (1543:10781) に合わせる: ボタン高さ 50px / icon 18px */
.senmon-school-reservation .senmon-school-contact__pill-icon {
	width: 18px;
	height: 18px;
}

.senmon-school-reservation .senmon-school-contact__pill-icon-inner {
	width: 18px;
	height: 18px;
}

/* hover は Contact と同様、色変化なし（必要なら後で追加） */
.senmon-school-reservation .senmon-school-contact__action-pill:hover,
.senmon-school-reservation .senmon-school-contact__action-pill:focus {
	color: var(--senmon-color-white);
}

/* TB/SP: サイドバーを下に回す */
@media (max-width: 959px) {
	.senmon-school-reservation__layout {
		flex-direction: column;
		align-items: stretch;
		gap: 24px;
	}

	.senmon-school-reservation__main {
		gap: 24px;
	}

	.senmon-school-reservation__sidebar {
		flex: 1;
		width: 100%;
		margin-top: 0;
	}
}

@media (max-width: 959px) {
	.senmon-school-reservation .senmon-school-contact__actions {
		flex-direction: row;
		gap: 8px;
		justify-content: center;
	}
	.senmon-school-reservation .senmon-school-contact__action {
		flex: 1 1 0;
	}
}

@media (max-width: 600px) {
	.senmon-school-reservation .senmon-school-contact__actions {
		flex-direction: column;
		gap: 8px;
	}
	.senmon-school-reservation .senmon-school-contact__sidebar-dot {
		width: 4px;
		height: 4px;
	}
}

/* SP: Send は有効時のみ緑塗り（contact と同じ。フォームは .senmon-school-contact__form ではないため別セレクタ） */
@media (max-width: 600px) {
	.senmon-school-reservation__sidebar {
		margin-bottom: 0;
	}

	.senmon-school-reservation__form .senmon-school-contact__submit-button--ready:not(:disabled):hover,
    .senmon-school-reservation__form .senmon-school-contact__submit-button--ready:not(:disabled):focus {
        background-color: var(--senmon-color-white);
        border-color: var(--senmon-color-primary);
        color: var(--senmon-color-primary);
    }

	.senmon-school-reservation__form .senmon-school-contact__submit-button--ready:not(:disabled) {
		background-color: var(--senmon-color-primary);
		color: var(--senmon-color-white);
	}
}

/* エラー表示（JS が .senmon-school-form-group--error を付与） */
.senmon-school-form-group--error .senmon-school-form-group__input,
.senmon-school-form-group--error .senmon-school-form-group__textarea,
.senmon-school-form-group--error .senmon-school-form-group__select {
	border-color: var(--senmon-color-caution-red-100);
	background-color: var(--senmon-color-caution-red-10);
}

/* 複数チェック＋Other 欄のみのブロック: エラーでも入力の赤枠・赤背景は付けない（文言・help のみ） */
.senmon-school-form-group--checkbox-error-no-field.senmon-school-form-group--error .senmon-school-form-group__input,
.senmon-school-form-group--checkbox-error-no-field.senmon-school-form-group--error .senmon-school-form-group__textarea,
.senmon-school-form-group--checkbox-error-no-field.senmon-school-form-group--error .senmon-school-form-group__select {
	border-color: transparent;
	background-color: var(--senmon-color-gray-10);
}

.senmon-school-form-group--checkbox-error-no-field.senmon-school-form-group--error .senmon-school-form-group__select {
	background-color: var(--senmon-color-white);
	border-color: var(--senmon-color-gray-90);
}

.senmon-school-form-group--checkbox-error-no-field.senmon-school-form-group--error .senmon-school-form-group__input:focus,
.senmon-school-form-group--checkbox-error-no-field.senmon-school-form-group--error .senmon-school-form-group__textarea:focus,
.senmon-school-form-group--checkbox-error-no-field.senmon-school-form-group--error .senmon-school-form-group__select:focus {
	border-color: var(--senmon-color-primary);
}

.senmon-school-form-group--error .senmon-school-form-group__help {
	display: block;
}

.senmon-school-form-group__error {
	display: block;
	color: var(--senmon-color-caution-red-100);
	font-family: var(--senmon-font-hero);
	font-weight: 500;
	font-size: 12px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	margin: 0;
}

/* ラベル直下のエラー文言は間隔を少し詰める */
.senmon-school-form-group__label + .senmon-school-form-group__error {
	margin-top: -12px;
}

