/*
 * Engawa Contact — ect-contact.css v1.2.0
 */

/* ---------------------------------------------------------------
   ラッパー
--------------------------------------------------------------- */
.ect-wrap {
	max-width: 680px;
	margin: 0 auto;
}

.ect-title {
	margin-bottom: 1.5rem;
}

/* ---------------------------------------------------------------
   フィールド
--------------------------------------------------------------- */
.ect-field {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	margin-bottom: 1.25rem;
}

.ect-label {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--ew-text, #3a3530);
}

/* ---------------------------------------------------------------
   必須・任意バッジ
--------------------------------------------------------------- */
.ect-badge {
	display: inline-block;
	font-size: 0.6875rem;
	font-weight: 700;
	padding: 0.1em 0.5em;
	border-radius: 3px;
	letter-spacing: 0.03em;
	line-height: 1.6;
}

.ect-badge--required {
	background: var(--ew-error, #b0454a);
	color: #fff;
}

.ect-badge--optional {
	background: var(--ew-sand, #d0ccc8);
	color: var(--ew-text-sub, #7a7268);
}

/* ---------------------------------------------------------------
   テキスト・メール・電話・日付入力
--------------------------------------------------------------- */
.ect-input {
	width: 100%;
	padding: 0.625rem 0.875rem;
	border: 1px solid var(--ew-sand, #d0ccc8);
	border-radius: 6px;
	font-size: 1rem;
	font-family: var(--ew-font-sans, sans-serif);
	color: var(--ew-text, #3a3530);
	background: #fff;
	transition: border-color 0.2s, box-shadow 0.2s;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
}

.ect-input:focus {
	outline: none;
	border-color: var(--ew-accent, #8a7a6a);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--ew-accent, #8a7a6a) 15%, transparent);
}

.ect-input.ect-has-error {
	border-color: var(--ew-error, #b0454a);
}

.ect-textarea {
	resize: vertical;
	min-height: 140px;
	line-height: 1.6;
}

.ect-input--file {
	padding: 0.5rem 0.75rem;
	cursor: pointer;
}

/* ---------------------------------------------------------------
   セレクト
--------------------------------------------------------------- */
.ect-select-wrap {
	position: relative;
}

.ect-select-wrap::after {
	content: '';
	position: absolute;
	right: 0.875rem;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
	height: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 6px solid var(--ew-taupe, #9a9088);
	pointer-events: none;
}

.ect-select {
	width: 100%;
	padding: 0.625rem 2.5rem 0.625rem 0.875rem;
	border: 1px solid var(--ew-sand, #d0ccc8);
	border-radius: 6px;
	font-size: 1rem;
	font-family: var(--ew-font-sans, sans-serif);
	color: var(--ew-text, #3a3530);
	background: #fff;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
	cursor: pointer;
	transition: border-color 0.2s;
}

.ect-select:focus {
	outline: none;
	border-color: var(--ew-accent, #8a7a6a);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--ew-accent, #8a7a6a) 15%, transparent);
}

/* ---------------------------------------------------------------
   チェックボックス
--------------------------------------------------------------- */
.ect-checkboxes {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.ect-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	cursor: pointer;
	font-size: 0.9375rem;
	color: var(--ew-text, #3a3530);
	line-height: 1.5;
}

.ect-checkbox-label--inline {
	display: inline-flex;
	margin-right: 1rem;
}

.ect-checkbox {
	width: 1.125rem;
	height: 1.125rem;
	min-width: 1.125rem;
	margin-top: 0.1em;
	accent-color: var(--ew-accent, #8a7a6a);
	cursor: pointer;
}

.ect-checkbox-text a {
	color: var(--ew-accent, #8a7a6a);
	text-decoration: underline;
}

/* ---------------------------------------------------------------
   プライバシーポリシー
--------------------------------------------------------------- */
.ect-field--privacy {
	padding: 1rem;
	background: var(--ew-cream, #faf7f2);
	border: 1px solid var(--ew-sand, #d0ccc8);
	border-radius: 6px;
}

/* ---------------------------------------------------------------
   補足テキスト
--------------------------------------------------------------- */
.ect-field-note {
	font-size: 0.8125rem;
	color: var(--ew-text-sub, #7a7268);
	margin: 0;
}

/* ---------------------------------------------------------------
   エラーメッセージ
--------------------------------------------------------------- */
.ect-error {
	font-size: 0.8125rem;
	color: var(--ew-error, #b0454a);
	min-height: 1.2em;
}

/* ---------------------------------------------------------------
   送信ボタン
--------------------------------------------------------------- */
.ect-submit-wrap {
	margin-top: 0.5rem;
}

.ect-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 2.5rem;
	background: var(--ew-accent, #8a7a6a);
	color: #fff;
	border: none;
	border-radius: 6px;
	font-size: 1rem;
	font-family: var(--ew-font-sans, sans-serif);
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s, opacity 0.2s;
	letter-spacing: 0.05em;
}

.ect-submit:hover {
	background: var(--ew-accent-dark, #7a6a5a);
}

.ect-submit:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

/* ---------------------------------------------------------------
   確認画面
--------------------------------------------------------------- */
.ect-confirm {
	padding: 1.5rem;
	background: var(--ew-cream, #faf7f2);
	border: 1px solid var(--ew-sand, #d0ccc8);
	border-radius: 8px;
}

.ect-confirm-lead {
	margin: 0 0 1.25rem;
	font-weight: 600;
	color: var(--ew-text, #3a3530);
}

.ect-confirm-table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 1.5rem;
	font-size: 0.9375rem;
}

.ect-confirm-table th,
.ect-confirm-table td {
	padding: 0.625rem 0.75rem;
	border-bottom: 1px solid var(--ew-sand, #d0ccc8);
	text-align: left;
	vertical-align: top;
	line-height: 1.6;
}

.ect-confirm-table th {
	width: 8em;
	font-weight: 600;
	color: var(--ew-text-sub, #7a7268);
	white-space: nowrap;
}

.ect-confirm-table td {
	color: var(--ew-text, #3a3530);
	word-break: break-word;
}

.ect-confirm-actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.ect-btn-back {
	padding: 0.625rem 1.5rem;
	background: #fff;
	color: var(--ew-text, #3a3530);
	border: 1px solid var(--ew-sand, #d0ccc8);
	border-radius: 6px;
	font-size: 0.9375rem;
	font-family: var(--ew-font-sans, sans-serif);
	cursor: pointer;
	transition: background 0.2s;
}

.ect-btn-back:hover {
	background: var(--ew-cream, #faf7f2);
}

.ect-btn-send {
	padding: 0.625rem 2rem;
	background: var(--ew-accent, #8a7a6a);
	color: #fff;
	border: none;
	border-radius: 6px;
	font-size: 0.9375rem;
	font-family: var(--ew-font-sans, sans-serif);
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s, opacity 0.2s;
}

.ect-btn-send:hover {
	background: var(--ew-accent-dark, #7a6a5a);
}

.ect-btn-send:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

/* ---------------------------------------------------------------
   送信完了メッセージ
--------------------------------------------------------------- */
.ect-success {
	padding: 2rem 1.5rem;
	background: color-mix(in srgb, var(--ew-accent, #8a7a6a) 8%, #fff);
	border: 1px solid var(--ew-sand, #d0ccc8);
	border-left: 4px solid var(--ew-accent, #8a7a6a);
	border-radius: 6px;
	color: var(--ew-text, #3a3530);
	text-align: center;
}

.ect-success__icon {
	font-size: 2rem;
	color: var(--ew-accent, #8a7a6a);
	margin-bottom: 0.75rem;
}

.ect-success p {
	margin: 0;
	line-height: 1.6;
}

/* ---------------------------------------------------------------
   エラーバナー
--------------------------------------------------------------- */
.ect-form-error {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	padding: 0.875rem 1.25rem;
	background: var(--ew-error-bg, #fdf0f0);
	border: 1px solid var(--ew-error-border, #e8a0a0);
	border-radius: 6px;
	color: var(--ew-error-text, #8b2020);
	font-size: 0.9375rem;
	margin-bottom: 1.25rem;
}

.ect-form-error__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.25rem;
	height: 1.25rem;
	min-width: 1.25rem;
	background: var(--ew-error, #b0454a);
	color: #fff;
	border-radius: 50%;
	font-size: 0.75rem;
	font-weight: 700;
	margin-top: 0.1em;
}

/* ---------------------------------------------------------------
   レスポンシブ
--------------------------------------------------------------- */
@media (max-width: 600px) {
	.ect-submit,
	.ect-btn-send,
	.ect-btn-back {
		width: 100%;
	}

	.ect-confirm-table th {
		width: 6em;
	}

	.ect-confirm-table th,
	.ect-confirm-table td {
		display: block;
		width: 100%;
	}

	.ect-confirm-table th {
		padding-bottom: 0.25rem;
		border-bottom: none;
	}

	.ect-confirm-table td {
		padding-top: 0;
	}
}
