@charset "UTF-8";

/* =========================================================
form reset
========================================================= */
fieldset {
	border: none;
	margin-inline: 0;
}
/* =========================================================
o-form / フォームコンポーネント
========================================================= */

/* フォームボックス */
.o-formBox {
	margin-bottom: var(--gap04);
}

.o-formBox:last-child {
	margin-bottom: 0;
}

/* フォームタイトル */
.o-formTitle {
	display: flex;
	align-items: center;
	gap: var(--gap01);
	margin-bottom: var(--gap02);
	font-size: var(--fs-mid);
	font-weight: 700;
	color: var(--text-color01);
}

.o-formTitle__badge {
	display: inline-block;
	padding: 0.2rem 0.6rem;
	border-radius: var(--radius01);
	font-size: var(--fs-tiny);
	font-weight: 500;
	white-space: nowrap;
}

.o-formTitle__badge.__required {
	background-color: var(--accent-color03);
	color: var(--text-color04);
}

.o-formTitle__badge.__optional {
	background-color: var(--base-color01);
	color: var(--text-color04);
}

/* フォームラベル */
.o-formLabel {
	display: block;
}

/* 入力フィールド */
.o-formInput,
.p-consulForm__input,
.p-consulForm__select,
.p-consulForm__textarea {
	width: 100%;
	padding: var(--gap04) var(--gap04);
	border: none;
	border-bottom: 1px solid var(--border-color01);
	border-radius: var(--radius01);
	background-color: var(--base-color02);
	font-size: var(--fs-p);
	font-family: var(--font-family01);
	color: var(--text-color01);
	transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.o-formInput,
.p-consulForm__input:focus,
.p-consulForm__select:focus,
.p-consulForm__textarea:focus {
	outline: none;
	border-color: var(--accent-color02);
	box-shadow: 0 0 0 2px rgba(var(--accent-color01-rgb), 0.1);
}
.o-formInput::placeholder,
.p-consulForm__input::placeholder,
.p-consulForm__textarea::placeholder {
	color: var(--text-color02);
	opacity: 0.6;
}

/* Select要素のスタイリング */
.p-consulForm__select {
	position: relative;
	padding-right: 3rem;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	cursor: pointer;
}

/* selectのカスタムアイコン（Material Symbols） */
.o-formSelect {
	position: relative;
	padding: 0;
}

.o-formSelect::after {
	content: "expand_more";
	font-family: 'Material Symbols Outlined';
	font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
	position: absolute;
	right: var(--gap03);
	top: 50%;
	transform: translateY(-50%);
	font-size: 20px;
	color: var(--text-color01);
	pointer-events: none;
}

.o-formSelect:focus-within::after {
	color: var(--accent-color01);
}

.p-consulForm__select:hover {
	border-color: var(--accent-color01);
}

/* Radioボタングループ */
.o-formRadioGroup {
	display: flex;
	flex-direction: column;
	gap: 1px;
	padding: var(--gap02);
	background-color: var(--base-color02);
}

/* Radioボタンのスタイリング */
.o-formRadio {
	position: relative;
	display: flex;
	align-items: center;
	padding: var(--gap04);
	cursor: pointer;
	user-select: none;
	background-color: var(--base-color03);
	transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.o-formRadio.__justtext {
	padding: 0;
}

.o-formRadio.__justtext:hover {
	box-shadow: none;
}

.o-formRadio__input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.o-formRadio__label {
	position: relative;
	padding-left: 2.5rem;
	font-size: var(--fs-p);
	color: var(--text-color01);
	cursor: pointer;
	transition: color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.o-formRadio__label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border: 2px solid var(--base-color01); /* 通常時 枠: base-color02 */
    border-radius: 4px;
    background-color: transparent;
    transition: all 0.2s ease;
}

.o-formRadio__label::after {
    content: "check"; /* Material Symbols check */
    font-family: 'Material Symbols Outlined';
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: var(--base-color01); /* 通常時 アイコン: base-color02 */
    pointer-events: none;
    transition: color 0.2s ease;
}

/* ホバー時: inputにフォーカスするようなシャドウ、枠とアイコンをaccent-color02に */
.o-formRadio:hover {
	z-index: 1;
    box-shadow: 0 0 0 3px rgba(var(--accent-color02-rgb), 0.12);
}
.o-formRadio:hover .o-formRadio__label::before {
    border-color: var(--accent-color02);
}
.o-formRadio:hover .o-formRadio__label::after {
    color: var(--accent-color02);
}

/* 選択時: 枠は透明、背景accent-color02、アイコン白、文字色も白 */.o-formRadio__input:checked + .o-formRadio__label {
    color: var(--accent-color02);
}
.o-formRadio__input:checked + .o-formRadio__label {
    color: var(--accent-color02);
}
.o-formRadio__input:checked + .o-formRadio__label::before {
    border-color: transparent;
    background-color: var(--accent-color02);
    box-shadow: none;
}
.o-formRadio__input:checked + .o-formRadio__label::after {
    color: var(--text-color04);
}

/* フォーカス時のシャドウ（アクセシビリティ） */
.o-formRadio__input:focus + .o-formRadio__label::before {
    box-shadow: 0 0 0 3px rgba(var(--accent-color02-rgb), 0.2);
}

/* Textarea */
.p-consulForm__textarea {
	min-height: 120px;
	resize: vertical;
	font-family: var(--font-family01);
	line-height: 1.6;
}

/* Submitボタン */
.p-consulForm__submit {
	width: 100%;
	padding: var(--gap05) var(--gap05);
	background: var(--gradient-button01);
	color: var(--text-color04);
	border: none;
	border-radius: var(--radius01);
	font-size: var(--fs-p);
	font-weight: 600;
	font-family: var(--font-family01);
	cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.p-consulForm__submit:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow02);
	background: var(--gradient-button01);
}

.p-consulForm__submit:active {
	transform: translateY(0);
}

.p-consulForm__submit:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(var(--accent-color01-rgb), 0.3);
}

/* プライバシーポリシーテキスト */
.p-consulForm__privacy {
	margin-top: var(--gap03);
	font-size: var(--fs-min);
	color: var(--text-color02);
	line-height: 1.6;
	text-align: center;
}

@media (max-width: 480px) {
	.p-consulForm__privacy {
		font-size: 10px;
	}
}

.p-consulForm__privacyLink {
	color: var(--link-color01);
	text-decoration: underline;
	text-underline-offset: 2px;
	transition: opacity 0.3s ease;
}

.p-consulForm__privacyLink:hover {
	opacity: 0.7;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
	.o-formRadioGroup {
		gap: var(--gap01);
	}

}
