/**
 * Contact Form 7 — form UI (contact page).
 * Scoped under .c-contact-form-shell
 */

.c-contact-form-shell {
	--cf7-error: #c5534a;
	--cf7-error-bg: #fef5f3;
	--cf7-error-border: rgba(197, 83, 74, 0.45);
	--cf7-focus-ring: rgba(240, 138, 107, 0.28);
}

.c-contact-form-shell .wpcf7 {
	margin: 0;
}

.c-contact-form-shell .wpcf7 form {
	margin: 0;
}

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

/* ----- Field layout ----- */

.c-cf7-form .c-cf7-field {
	margin: 0 0 1.35rem;
}

.c-cf7-form .c-cf7-field:last-of-type {
	margin-bottom: 0;
}

.c-cf7-field__head {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}

.c-cf7-field__label {
	font-size: 0.9375rem;
	font-weight: 500;
	color: #303030;
}

.c-cf7-field__hint {
	margin: 0.5rem 0 0;
	font-size: 0.8125rem;
	line-height: 1.65;
	color: var(--color-text-muted);
}

.c-cf7-field__hint a {
	color: var(--color-primary-dark);
	font-weight: 600;
}

.c-cf7-badge {
	display: inline-block;
	padding: 0 0.5rem;
	border-radius: var(--radius-xs);
	font-size: 0.8125rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0;
	white-space: nowrap;
}

.c-cf7-badge--required {
	padding: 0 0.5rem;
	border-radius: var(--radius-xs);
	background-color: #ff9845;
	color: var(--color-white);
}

.c-cf7-badge--optional {
	background-color: #d7ccc4;
	color: var(--color-white);
}

/* ----- Inputs ----- */

.c-contact-form-shell .wpcf7-form-control-wrap {
	display: block;
	margin: 0;
}

.c-contact-form-shell .wpcf7-text,
.c-contact-form-shell .wpcf7-email,
.c-contact-form-shell .wpcf7-tel,
.c-contact-form-shell .wpcf7-textarea,
.c-contact-form-shell .wpcf7-file,
.c-contact-form-shell .c-cf7-control,
.c-contact-form-shell input.c-cf7-control,
.c-contact-form-shell textarea.c-cf7-control {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	margin: 0;
}

.c-contact-form-shell .wpcf7-text,
.c-contact-form-shell .wpcf7-email,
.c-contact-form-shell .wpcf7-tel,
.c-contact-form-shell .wpcf7-textarea,
.c-contact-form-shell .c-cf7-control,
.c-contact-form-shell input.c-cf7-control:not([type="file"]):not([type="checkbox"]):not([type="submit"]),
.c-contact-form-shell textarea.c-cf7-control {
	min-height: 3.25rem;
	padding: 1rem 1.5rem;
	border: 1px solid #e0e0e0;
	border-radius: var(--radius-xs);
	background-color: var(--color-white);
	font-size: 1rem;
	line-height: 1.45;
	color: var(--color-ink);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	-webkit-appearance: none;
	appearance: none;
}

.c-contact-form-shell .wpcf7-textarea,
.c-contact-form-shell textarea.c-cf7-control {
	min-height: 9rem;
	padding-top: 0.85rem;
	resize: vertical;
}

.c-contact-form-shell .wpcf7-text:focus,
.c-contact-form-shell .wpcf7-email:focus,
.c-contact-form-shell .wpcf7-tel:focus,
.c-contact-form-shell .wpcf7-textarea:focus,
.c-contact-form-shell .c-cf7-control:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px var(--cf7-focus-ring);
}

.c-contact-form-shell .wpcf7-not-valid,
.c-contact-form-shell input.wpcf7-not-valid,
.c-contact-form-shell textarea.wpcf7-not-valid {
	border-color: var(--cf7-error-border);
	background-color: var(--cf7-error-bg);
}

/* File upload */

.c-contact-form-shell .c-cf7-field--file .wpcf7-form-control-wrap {
	padding: 0.85rem 0.9rem;
	border: 1px dashed var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-bg-soft);
}

.c-contact-form-shell input.c-cf7-file,
.c-contact-form-shell input[type="file"].wpcf7-file,
.c-contact-form-shell input[type="file"].c-cf7-file {
	min-height: auto;
	padding: 0;
	border: none;
	background: transparent;
	font-size: 0.875rem;
	box-shadow: none;
}

.c-contact-form-shell input.c-cf7-file:focus,
.c-contact-form-shell input[type="file"].wpcf7-file:focus {
	box-shadow: none;
}

/* Acceptance */

.c-cf7-field--acceptance .c-cf7-field__head {
	margin-bottom: 0.35rem;
}

.c-cf7-field--acceptance .wpcf7-list-item,
.c-cf7-field--acceptance .wpcf7-checkbox {
	margin: 0;
}

.c-cf7-field--acceptance .wpcf7-list-item label,
.c-cf7-field--acceptance .wpcf7-checkbox label {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	margin: 0;
	padding: 0.85rem 0.9rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-white);
	font-size: 0.9375rem;
	font-weight: 500;
	line-height: 1.55;
	color: var(--color-ink);
	cursor: pointer;
}

.c-cf7-field--acceptance input[type="checkbox"],
.c-cf7-field--acceptance .wpcf7-acceptance input[type="checkbox"],
.c-cf7-field--acceptance .wpcf7-checkbox input[type="checkbox"] {
	flex-shrink: 0;
	width: 1.25rem;
	height: 1.25rem;
	margin-top: 0.15rem;
	accent-color: var(--color-primary);
}

.c-cf7-field--acceptance .wpcf7-not-valid + .wpcf7-list-item label,
.c-cf7-field--acceptance .wpcf7-form-control-wrap .wpcf7-not-valid ~ label {
	border-color: var(--cf7-error-border);
}

/* Validation tips */

.c-contact-form-shell .wpcf7-not-valid-tip {
	display: block;
	margin-top: 0.4rem;
	font-size: 0.8125rem;
	font-weight: 600;
	line-height: 1.45;
	color: var(--cf7-error);
}

/* Response banner */

.c-contact-form-shell .wpcf7-response-output {
	margin: 1.25rem 0 0;
	padding: 0.85rem 1rem;
	border-radius: var(--radius-md);
	font-size: 0.875rem;
	line-height: 1.55;
	border-width: 1px;
}

.c-contact-form-shell .wpcf7 form.invalid .wpcf7-response-output {
	border-color: var(--cf7-error-border);
	background: var(--cf7-error-bg);
	color: var(--cf7-error);
}

.c-contact-form-shell .wpcf7 form.sent .wpcf7-response-output {
	border-color: rgba(143, 185, 139, 0.55);
	background: rgba(143, 185, 139, 0.12);
	color: var(--color-ink);
}

.c-contact-form-shell .wpcf7 form.failed .wpcf7-response-output,
.c-contact-form-shell .wpcf7 form.aborted .wpcf7-response-output {
	border-color: var(--cf7-error-border);
	background: var(--cf7-error-bg);
	color: var(--cf7-error);
}

/* Submit — match .c-btn-primary */

.c-contact-form-shell .wpcf7-submit-wrap,
.c-cf7-form > .wpcf7-submit,
.c-cf7-form > input.wpcf7-submit {
	margin-top: 1.5rem;
}

.c-contact-form-shell .wpcf7-submit,
.c-contact-form-shell input.wpcf7-submit,
.c-contact-form-shell input.c-cf7-submit {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 3.25rem;
	margin: 0;
	padding: 0.85rem 1.5rem;
	border: 2px solid var(--color-primary);
	border-radius: var(--radius-pill);
	background-color: var(--color-primary);
	color: var(--color-white) !important;
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 800;
	line-height: 1.35;
	letter-spacing: 0.02em;
	cursor: pointer;
	box-shadow: var(--shadow-soft);
	transition: background-color 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
	-webkit-appearance: none;
	appearance: none;
}

.c-contact-form-shell .wpcf7-submit:hover,
.c-contact-form-shell input.wpcf7-submit:hover,
.c-contact-form-shell input.c-cf7-submit:hover {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: var(--color-white) !important;
}

.c-contact-form-shell .wpcf7-submit:focus-visible,
.c-contact-form-shell input.wpcf7-submit:focus-visible {
	outline: none;
	box-shadow: 0 0 0 3px var(--cf7-focus-ring);
}

.c-contact-form-shell .wpcf7-submit:active,
.c-contact-form-shell input.wpcf7-submit:active {
	transform: translateY(1px);
}

.c-contact-form-shell .wpcf7-spinner {
	display: inline-block;
	margin: 0.75rem auto 0;
	vertical-align: middle;
}

/* Screen reader / hidden */

.c-contact-form-shell .wpcf7 .screen-reader-response {
	position: absolute;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	border: 0;
}

@media (min-width: 768px) {
	.c-contact-form-shell .wpcf7-submit,
	.c-contact-form-shell input.wpcf7-submit,
	.c-contact-form-shell input.c-cf7-submit {
		width: 100%;
		min-width: 0;
	}
}

/* Figma contact-sp / pc（.p-page--contact のみ） */

.p-page--contact .c-cf7-form .c-cf7-field {
	margin-bottom: 1.5rem;
}

.p-page--contact .c-cf7-field__head {
	margin-bottom: 0.25rem;
}

.p-page--contact .c-cf7-field--file {
	margin-bottom: 1.5rem;
}

.p-page--contact .c-cf7-field--file .c-cf7-field__head {
	margin-bottom: 0.35rem;
}

.p-page--contact .c-cf7-field__hint {
	font-size: 0.625rem;
	line-height: 1.6;
	color: var(--color-ink);
}

.p-page--contact .c-cf7-field--acceptance .wpcf7-list-item label,
.p-page--contact .c-cf7-field--acceptance .wpcf7-checkbox label {
	padding: 0;
	border: none;
	background: transparent;
	font-size: 0.8125rem;
	font-weight: 400;
	line-height: 1.8;
	color: var(--color-ink);
}

.p-page--contact .c-cf7-field--acceptance input[type="checkbox"] {
	width: 1.3125rem;
	height: 1.3125rem;
	margin-top: 0.2rem;
	border: 1px solid #777;
	border-radius: 5px;
}

.p-page--contact .c-contact-form-shell .wpcf7-submit,
.p-page--contact .c-contact-form-shell input.wpcf7-submit,
.p-page--contact .c-contact-form-shell input.c-cf7-submit {
	border-radius: 6px;
	border-color: var(--color-primary);
	background-color: var(--color-primary);
	font-size: 0.9375rem;
	font-weight: 700;
	line-height: 1.8;
}

.p-page--contact .c-contact-form-shell .wpcf7-submit-wrap,
.p-page--contact .c-cf7-form > .wpcf7-submit,
.p-page--contact .c-cf7-form > input.wpcf7-submit {
	margin-top: 0;
}
