/* ==========================================================================
   SaMa Obrt — Contact Form 7 Styles
   ========================================================================== */

/* --- Form layout --- */
.wpcf7-form {
	display: grid;
	gap: 1.25rem;
}

/* Two-column row for name fields */
.wpcf7-form .cf7-row-2col {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.25rem;
}

@media (max-width: 480px) {
	.wpcf7-form .cf7-row-2col {
		grid-template-columns: 1fr;
	}
}

/* --- Labels --- */
.wpcf7-form label {
	display: block;
	font-family: var(--wp--preset--font-family--nunito);
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--wp--preset--color--foreground);
	margin-bottom: 0.4rem;
}

/* --- Inputs and textarea --- */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form input[type="number"],
.wpcf7-form textarea,
.wpcf7-form select {
	width: 100%;
	padding: 0.7rem 1rem;
	border: 1px solid #E5E7EB;
	border-radius: 6px;
	font-family: var(--wp--preset--font-family--nunito);
	font-size: 0.95rem;
	color: var(--wp--preset--color--foreground);
	background-color: #fff;
	box-sizing: border-box;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	outline: none;
}

.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form input[type="url"]:focus,
.wpcf7-form input[type="number"]:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px rgba(43, 96, 148, 0.12);
}

.wpcf7-form textarea {
	resize: vertical;
	min-height: 130px;
}

/* CF7 wraps inputs in spans — make them block-level */
.wpcf7-form .wpcf7-form-control-wrap {
	display: block;
}

/* Remove default CF7 paragraph margin so our grid gap controls spacing */
.wpcf7-form > p {
	margin: 0;
}

/* --- Submit button --- */
.wpcf7-form input[type="submit"],
.wpcf7-form .wpcf7-submit {
	background-color: var(--wp--preset--color--primary);
	color: #fff;
	border: none;
	padding: 0.85rem 2rem;
	border-radius: 6px;
	font-family: var(--wp--preset--font-family--nunito);
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.1s ease;
	display: inline-block;
}

.wpcf7-form input[type="submit"]:hover,
.wpcf7-form .wpcf7-submit:hover {
	background-color: var(--wp--preset--color--accent);
}

.wpcf7-form input[type="submit"]:active,
.wpcf7-form .wpcf7-submit:active {
	transform: translateY(1px);
}

/* --- Validation errors --- */
.wpcf7-form .wpcf7-not-valid {
	border-color: #e53e3e !important;
	box-shadow: 0 0 0 3px rgba(229, 62, 62, 0.12) !important;
}

.wpcf7-form .wpcf7-not-valid-tip {
	display: block;
	margin-top: 0.3rem;
	font-size: 0.8rem;
	color: #e53e3e;
	font-family: var(--wp--preset--font-family--nunito);
}

/* --- Response output (success / error message) --- */
.wpcf7-response-output {
	margin: 0.5rem 0 0;
	padding: 0.75rem 1rem;
	border-radius: 6px;
	font-family: var(--wp--preset--font-family--nunito);
	font-size: 0.9rem;
	border: none !important;
}

.wpcf7-form.sent .wpcf7-response-output {
	background-color: rgba(61, 155, 140, 0.12);
	color: var(--wp--preset--color--accent);
	border-left: 3px solid var(--wp--preset--color--accent) !important;
}

.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.aborted .wpcf7-response-output,
.wpcf7-form.spam .wpcf7-response-output {
	background-color: rgba(229, 62, 62, 0.08);
	color: #e53e3e;
	border-left: 3px solid #e53e3e !important;
}

.wpcf7-form.invalid .wpcf7-response-output {
	background-color: rgba(232, 147, 90, 0.12);
	color: var(--wp--preset--color--secondary);
	border-left: 3px solid var(--wp--preset--color--secondary) !important;
}

/* --- Spinner --- */
.wpcf7 .ajax-loader {
	display: inline-block;
	margin-left: 0.75rem;
	vertical-align: middle;
}
