/*
 * Clarke & Wright Contact Form
 * Designed to inherit Divi theme styling — no hard-coded colours.
 * Uses Divi's CSS custom properties where available; falls back to sensible defaults.
 */

.cwcf-wrap {
	--cwcf-radius: 6px;
	--cwcf-gap: 18px;
	--cwcf-input-pad-y: 14px;
	--cwcf-input-pad-x: 16px;
	--cwcf-error: #c0392b;
	--cwcf-muted: #6b7280;
	--cwcf-border: rgba(0, 0, 0, 0.15);
	--cwcf-border-focus: var(--et_pb_accent_color, #2c466a);
	--cwcf-bg-error: rgba(192, 57, 43, 0.06);
	--cwcf-bg-success: rgba(46, 125, 50, 0.08);
	--cwcf-success-text: #2e7d32;

	max-width: 760px;
	margin: 0 auto;
	font-family: inherit;
	color: inherit;
}

.cwcf-title {
	margin: 0 0 12px 0;
}
.cwcf-intro {
	margin: 0 0 24px 0;
	color: var(--cwcf-muted);
}

/* ---------- success / error banners ---------- */

.cwcf-success {
	background: var(--cwcf-bg-success);
	border-left: 4px solid var(--cwcf-success-text);
	padding: 18px 20px;
	border-radius: var(--cwcf-radius);
	margin-bottom: 24px;
}
.cwcf-success p {
	margin: 0;
	color: var(--cwcf-success-text);
	font-weight: 600;
}

.cwcf-general-error {
	background: var(--cwcf-bg-error);
	border-left: 4px solid var(--cwcf-error);
	padding: 14px 18px;
	border-radius: var(--cwcf-radius);
	margin-bottom: 24px;
}
.cwcf-general-error p {
	margin: 0;
	color: var(--cwcf-error);
}

/* ---------- grid + rows ---------- */

.cwcf-grid {
	display: flex;
	flex-direction: column;
	gap: var(--cwcf-gap);
}

.cwcf-row {
	display: grid;
	gap: var(--cwcf-gap);
}
.cwcf-row--full { grid-template-columns: 1fr; }
.cwcf-row--two  { grid-template-columns: repeat(2, 1fr); }

@media (max-width: 600px) {
	.cwcf-row--two { grid-template-columns: 1fr; }
}

/* ---------- field wrappers ---------- */

.cwcf-field {
	display: flex;
	flex-direction: column;
}
.cwcf-label {
	display: block;
	margin-bottom: 6px;
	font-weight: 600;
	font-size: 0.95em;
	line-height: 1.4;
}
.cwcf-req {
	color: var(--cwcf-error);
	margin-left: 2px;
}
.cwcf-help {
	margin: 6px 0 0 0;
	color: var(--cwcf-muted);
	font-size: 0.85em;
	line-height: 1.4;
}
.cwcf-error {
	margin: 6px 0 0 0;
	color: var(--cwcf-error);
	font-size: 0.85em;
	font-weight: 600;
}

/* ---------- inputs ---------- */

.cwcf-input,
.cwcf-textarea,
.cwcf-select {
	display: block;
	width: 100%;
	padding: var(--cwcf-input-pad-y) var(--cwcf-input-pad-x);
	font-family: inherit;
	font-size: 1em;
	line-height: 1.4;
	color: inherit;
	background: #ffffff;
	border: 1px solid var(--cwcf-border);
	border-radius: var(--cwcf-radius);
	box-sizing: border-box;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.cwcf-textarea {
	resize: vertical;
	min-height: 140px;
}
.cwcf-select {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23555' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	padding-right: 40px;
}
.cwcf-input:focus,
.cwcf-textarea:focus,
.cwcf-select:focus {
	outline: 0;
	border-color: var(--cwcf-border-focus);
	box-shadow: 0 0 0 3px rgba(44, 70, 106, 0.15);
}

.cwcf-field--error .cwcf-input,
.cwcf-field--error .cwcf-textarea,
.cwcf-field--error .cwcf-select {
	border-color: var(--cwcf-error);
	box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.12);
}

/* ---------- radio + checkbox ---------- */

.cwcf-radio-group {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	padding-top: 4px;
}
.cwcf-radio,
.cwcf-checkbox {
	display: inline-flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
	padding: 10px 14px;
	border: 1px solid var(--cwcf-border);
	border-radius: var(--cwcf-radius);
	background: #ffffff;
	transition: border-color 0.15s ease, background 0.15s ease;
	line-height: 1.4;
}
.cwcf-radio:hover,
.cwcf-checkbox:hover {
	border-color: var(--cwcf-border-focus);
}
.cwcf-radio input,
.cwcf-checkbox input {
	margin: 4px 0 0 0;
	flex-shrink: 0;
}
.cwcf-radio:has(input:checked),
.cwcf-checkbox:has(input:checked) {
	border-color: var(--cwcf-border-focus);
	background: rgba(44, 70, 106, 0.04);
}

.cwcf-checkbox {
	width: 100%;
	margin-bottom: 8px;
}
.cwcf-checkbox a {
	text-decoration: underline;
}

/* Multi-select checkbox group ("What can we help with?") */
.cwcf-checkboxes {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	padding-top: 4px;
}
.cwcf-checkboxes .cwcf-checkbox {
	width: auto;
	margin: 0;
}
@media (max-width: 600px) {
	.cwcf-checkboxes { grid-template-columns: 1fr; }
}

/* ---------- conditional fields ---------- */

.cwcf-field--conditional {
	display: none;
}
.cwcf-field--conditional.is-visible {
	display: flex;
	animation: cwcf-fadein 0.2s ease;
}
@keyframes cwcf-fadein {
	from { opacity: 0; transform: translateY(-2px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ---------- honeypot (visually hidden) ---------- */

.cwcf-hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* ---------- actions / submit ---------- */

.cwcf-actions {
	margin-top: 28px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	align-items: flex-start;
}
.cwcf-actions__note {
	margin: 0;
	color: var(--cwcf-muted);
	font-size: 0.85em;
	line-height: 1.4;
}

.cwcf-submit {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 32px;
	font-family: inherit;
	font-size: 1em;
	font-weight: 600;
	color: #ffffff;
	background: var(--et_pb_button_color, var(--et_pb_accent_color, #2c466a));
	border: 0;
	border-radius: var(--cwcf-radius);
	cursor: pointer;
	transition: opacity 0.15s ease, transform 0.05s ease;
}
.cwcf-submit:hover { opacity: 0.92; }
.cwcf-submit:active { transform: translateY(1px); }
.cwcf-submit:disabled { opacity: 0.6; cursor: progress; }

.cwc