/*
 * CONTACT PAGE
 * Theme-agnostic contact form styles.
 * Uses --wp--preset--color--* from theme.json as the only external dependency.
 */

/* ================================================================
   Reset — fieldset / legend
   ================================================================ */
.contact-form fieldset,
.confirm-group {
	border: 0;
	margin: 0;
	padding: 0;
	min-inline-size: 0;
}
.contact-form legend {
	padding: 0;
	float: left;       /* prevent legend line-break in some browsers */
	width: 100%;
}

/* ================================================================
   Phone CTA section
   ================================================================ */
.contact-top {
	margin-top: 60px;
}
.contact-top .contact-top-box {
	display: flex;
	align-items: center;
	flex-direction: column;
	justify-content: center;
	gap: 6px;
	max-width: 640px;
	margin: 0 auto;
	padding: 40px 24px;
	border: 1px solid #e4e2e0;
	border-radius: 8px;
	background-color: #fafaf9;
}
.contact-top .contact-top-box .top-line {
	color: var(--wp--preset--color--text, #333);
	font-size: 15px;
	font-weight: 500;
	text-align: center;
	margin: 0;
}
.contact-top .contact-top-box .phone-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 44px;
	font-weight: 700;
	text-align: center;
	line-height: 1.2;
	letter-spacing: 0.02em;
}
.contact-top .contact-top-box .phone-number a {
	color: var(--wp--preset--color--text, #333);
	text-decoration: none;
}
.contact-top .contact-top-box .phone-number .icon {
	width: 0.75em;
	height: 0.75em;
	margin-right: 0.25em;
	line-height: 1;
	color: var(--wp--preset--color--primary, #33ADC7);
	transform: translateY(0.1em);
}
.contact-top .contact-top-box .phone-number .icon svg {
	display: block;
	width: 100%;
	height: 100%;
	fill: currentColor;
}
.contact-top .contact-top-box .btm-line {
	color: var(--wp--preset--color--text-muted, #707070);
	font-size: 13px;
	font-weight: 500;
	text-align: center;
	margin: 0;
}

/* ================================================================
   Form container
   ================================================================ */
.contact-form-container {
	padding: 48px 20px 80px;
}
.contact-form-container .container {
	max-width: 780px;
	margin: 0 auto;
}

/* ── Feedback (success / error) ── */
.contact-form-container .contact-result {
	text-align: center;
	padding: 1.25em 1.5em;
	margin-bottom: 36px;
	border-radius: 6px;
	border: 1px solid transparent;
}
.contact-form-container .contact-result p {
	font-size: 16px;
	line-height: 1.6;
	margin: 0;
}
.contact-form-container .contact-result.success {
	color: var(--wp--preset--color--success, #0b8e0b);
	background-color: #f0faf0;
	border-color: #c6e6c6;
}
.contact-form-container .contact-result.failed {
	color: var(--wp--preset--color--warning, #c53030);
	background-color: #fef2f2;
	border-color: #f5c6c6;
}

/* ================================================================
   Field group (label + input grid)
   ================================================================ */
.contact-form .field-group {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: 16px;
	margin-bottom: 24px;
	align-items: start;
}

/* ── Label area ── */
.contact-form .label-wrap {
	display: flex;
	align-items: baseline;
	gap: 0.5em;
	white-space: nowrap;
	justify-content: space-between;
	padding-top: 10px;
}
.contact-form .label-txt {
	color: var(--wp--preset--color--text, #333);
	font-size: 15px;
	font-weight: 600;
}
.contact-form .label-required,
.contact-form .label-success,
.contact-form .label-optional {
	flex-shrink: 0;
	color: #fff;
	font-size: 11px;
	font-weight: 600;
	line-height: 1;
	padding: 4px 8px;
	border-radius: 3px;
}
.contact-form .label-required {
	background-color: var(--wp--preset--color--warning, #e8460b);
}
.contact-form .label-success {
	background-color: var(--wp--preset--color--success, #0b8e0b);
}
.contact-form .label-optional {
	background-color: var(--wp--preset--color--text-muted, #999);
}

/* ── Input area ── */
.contact-form .input-wrap {
	width: 100%;
}

/* ── Focus / invalid rings ── */
.contact-form .input-wrap input:not([type="radio"]):focus,
.contact-form .input-wrap textarea:focus,
.contact-form .input-wrap:focus-within .select-group {
	border-color: var(--wp--preset--color--accent, #0a4b8b);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--wp--preset--color--accent, #0a4b8b) 25%, transparent);
	outline: none;
}
.contact-form .input-wrap input:user-invalid,
.contact-form .input-wrap textarea:user-invalid {
	border-color: var(--wp--preset--color--warning, #e8460b);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--wp--preset--color--warning, #e8460b) 20%, transparent);
}

/* ── Text input / textarea base ── */
.contact-form .form-input-text {
	display: block;
	width: 100%;
	font-size: 16px;
	line-height: 1.5;
	padding: 10px 12px;
	color: var(--wp--preset--color--text, #333);
	background-color: #fff;
	border: 1px solid #d0ceca;
	border-radius: 6px;
	outline: none;
	transition: border-color 0.2s, box-shadow 0.2s;
	box-sizing: border-box;
}
.contact-form textarea.form-input-text {
	min-height: 10em;
	resize: vertical;
}
.contact-form .form-input-text::placeholder {
	color: var(--wp--preset--color--text-muted, #999);
}

/* ── Radio buttons ── */
.contact-form .radio-group {
	display: flex;
	flex-direction: row;
	margin: 0;
	padding: 0;
	border: 1px solid #d0ceca;
	border-radius: 6px;
	list-style-type: none;
	overflow: hidden;
}
.contact-form .form-input-radio {
	flex: 1 1 auto;
	padding: 10px 12px;
	font-size: 15px;
	text-align: center;
	transition: background-color 0.15s;
}
.contact-form .form-input-radio:not(:first-of-type) {
	border-left: 1px solid #d0ceca;
}
.contact-form .form-input-radio input[type="radio"] {
	margin-right: 0.35em;
	accent-color: var(--wp--preset--color--accent, #0a4b8b);
}
.contact-form .form-input-radio:has(input:checked) {
	background-color: color-mix(in srgb, var(--wp--preset--color--accent, #0a4b8b) 8%, #fff);
}
.contact-form .radio-label {
	width: 100%;
	cursor: pointer;
}

/* ── Select ── */
.contact-form .select-group {
	position: relative;
	display: inline-block;
	padding: 10px calc(12px + 16px + 8px) 10px 12px;
	color: var(--wp--preset--color--text, #333);
	background-color: #fff;
	border: 1px solid #d0ceca;
	border-radius: 6px;
	outline: none;
	transition: border-color 0.2s, box-shadow 0.2s;
}
.contact-form .select-group::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 12px;
	margin-top: -5px;
	width: 8px;
	height: 8px;
	border-right: 2px solid var(--wp--preset--color--text-muted, #999);
	border-bottom: 2px solid var(--wp--preset--color--text-muted, #999);
	transform: rotate(45deg);
	pointer-events: none;
}
.contact-form .form-input-select {
	-webkit-appearance: none;
	appearance: none;
	color: var(--wp--preset--color--text, #333);
	font-size: 16px;
	outline: none;
	border: 0;
	background-color: transparent;
}

/* ── Sub-labels (address, fullname_with_kana) ── */
.contact-form .sub-label {
	display: block;
	font-size: 13px;
	font-weight: 500;
	color: var(--wp--preset--color--text-muted, #707070);
	margin-bottom: 4px;
}

/* ── Composite field wrappers ── */
.contact-form .input-address-wrap,
.contact-form .input-fullname-wrap,
.contact-form .input-name-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
.contact-form .input-address-zipcode,
.contact-form .input-fullname {
	flex: 1;
}
.contact-form .input-address-pref {
	flex: 2;
}
.contact-form .input-address-city {
	flex: 2;
}
.contact-form .input-address-option {
	flex: 100%;
}
.contact-form .input-name-fullname,
.contact-form .input-name-kana {
	flex: 1;
}

/* ── Notes below inputs ── */
.contact-form .input-notes {
	display: block;
	line-height: 1.5;
	margin-top: 6px;
	color: var(--wp--preset--color--text-muted, #999);
	font-size: 13px;
}

/* ================================================================
   Agreement + Submit
   ================================================================ */
.confirm-group {
	text-align: center;
	margin: 8px 0 32px;
	padding-top: 24px;
	border-top: 1px solid #e8e6e4;
}
.confirm-group .agree-text {
	color: var(--wp--preset--color--text-muted, #707070);
	font-size: 14px;
	font-weight: 400;
	margin-bottom: 12px;
}
.confirm-group .agree-text a {
	color: var(--wp--preset--color--accent, #0a4b8b);
	text-decoration: underline;
	text-underline-offset: 2px;
}
.confirm-group .agree-btn {
	display: inline-block;
}
.confirm-group .agree-label {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5em;
	font-size: 15px;
	cursor: pointer;
}
.confirm-group .agree-chk {
	appearance: none;
	-webkit-appearance: none;
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	border: 2px solid #bbb;
	border-radius: 4px;
	position: relative;
	display: inline-block;
	background: #fff;
	cursor: pointer;
	transition: background-color 0.15s, border-color 0.15s;
}
.confirm-group .agree-chk:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent, #0a4b8b);
	outline-offset: 2px;
}
.confirm-group .agree-chk::after {
	content: "";
	position: absolute;
	top: 2px;
	left: 6px;
	width: 6px;
	height: 11px;
	border-right: 2.5px solid #fff;
	border-bottom: 2.5px solid #fff;
	transform: rotate(45deg) scale(0);
	transform-origin: center;
	transition: transform 0.15s ease-out;
}
.confirm-group .agree-chk:checked {
	background-color: var(--wp--preset--color--accent, #0a4b8b);
	border-color: var(--wp--preset--color--accent, #0a4b8b);
}
.confirm-group .agree-chk:checked::after {
	transform: rotate(45deg) scale(1);
}

/* ── reCAPTCHA ── */
.contact-form .g-recaptcha {
	display: flex;
	justify-content: center;
	margin-bottom: 24px;
}

/* ── Submit button ── */
.contact-form .submit-group {
	display: flex;
	justify-content: center;
}
.contact-form .submit-btn {
	appearance: none;
	-webkit-appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 280px;
	height: 56px;
	padding: 0 32px;
	border: 2px solid var(--wp--preset--color--text, #333);
	border-radius: 6px;
	background-color: var(--wp--preset--color--text, #333);
	color: #fff;
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0.04em;
	cursor: pointer;
	transition: background-color 0.2s, color 0.2s;
}
.contact-form .submit-btn:hover:not(:disabled) {
	background-color: #fff;
	color: var(--wp--preset--color--text, #333);
}
.contact-form .submit-btn:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent, #0a4b8b);
	outline-offset: 2px;
}
.contact-form .submit-btn:disabled {
	background-color: #d4d4d4;
	color: #888;
	border-color: #d4d4d4;
	cursor: not-allowed;
	opacity: 0.7;
}
.contact-form .submit-btn:disabled:hover {
	background-color: #d4d4d4;
	color: #888;
}

/* ================================================================
   Responsive — Tablet (< 992px)
   ================================================================ */
@media (max-width: 991.98px) {
	.contact-top {
		margin-top: 40px;
	}
	.contact-top .contact-top-box {
		padding: 32px 20px;
	}
	.contact-top .contact-top-box .phone-number {
		font-size: 38px;
	}
	.contact-top .contact-top-box .phone-number .icon {
		font-size: 24px;
	}
	.contact-form-container {
		padding: 32px 16px 60px;
	}
	.contact-form .field-group {
		grid-template-columns: 1fr;
		gap: 4px;
		margin-bottom: 20px;
	}
	.contact-form .label-wrap {
		justify-content: flex-start;
		align-items: center;
		padding-top: 0;
	}
	.contact-form .field-group .radio-group {
		flex-direction: column;
	}
	.contact-form .form-input-radio {
		text-align: left;
	}
	.contact-form .form-input-radio:not(:first-of-type) {
		border-left: 0;
		border-top: 1px solid #d0ceca;
	}
	.contact-form .input-address-pref {
		flex: 1;
	}
	.contact-form .input-address-city {
		flex: 100%;
	}
	.contact-form .submit-btn {
		width: 100%;
		min-width: 0;
	}
}

/* ================================================================
   Responsive — SP (< 768px)
   ================================================================ */
@media (max-width: 767.98px) {
	.contact-top .contact-top-box .phone-number {
		font-size: 8vw;
	}
	.contact-top .contact-top-box .phone-number .icon {
		font-size: 5.5vw;
	}
	.contact-form .input-name-fullname,
	.contact-form .input-name-kana {
		flex: 100%;
	}
}
