/* =============================================================================
 - GW Sandbox Form
 - Styles #grve-sandbox-form to match Figma spec.
============================================================================= */
#grve-sandbox-form {
	--gwsand-border-c: #dbdbdb;
	--gwsand-placeholder-c: #9e9e9e;
	--gwsand-captcha-bg: #e2e6ee;
	--gwsand-text-c: #000000;
	--gwsand-radius: 4px;
	--gwsand-field-py: 12px;
	--gwsand-field-px: 24px;
	--gwsand-font-size: 18px;
	--gwsand-line-height: 1.6;
	--gwsand-gap: 8px;

	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: var(--gwsand-gap);
	width: 100%;
	max-width: 440px;
	margin-left: auto;
	margin-right: auto;
}

#grve-sandbox-form .grve-sandbox-field {
	margin: 0;
	width: 100%;
}

/* Inputs & select — shared base */
#grve-sandbox-form input[type="email"],
#grve-sandbox-form input[type="text"],
#grve-sandbox-form input[type="number"],
#grve-sandbox-form select {
	display: block;
	width: 100%;
	box-sizing: border-box;
	padding: var(--gwsand-field-py) var(--gwsand-field-px);
	background-color: #ffffff;
	border: 1px solid var(--gwsand-border-c);
	border-radius: var(--gwsand-radius);
	font-size: var(--gwsand-font-size);
	line-height: var(--gwsand-line-height);
	color: var(--gwsand-text-c);
	box-shadow: none;
	outline: none;
	transition: border-color .2s ease;
}

#grve-sandbox-form input::placeholder {
	color: var(--gwsand-placeholder-c);
	opacity: 1;
}

#grve-sandbox-form input:focus,
#grve-sandbox-form select:focus {
	border-color: var(--gwsand-text-c);
}

/* Native select chevron */
#grve-sandbox-form select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path d='M5.5 7.5l4.5 5 4.5-5' fill='none' stroke='%239e9e9e' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");
	background-repeat: no-repeat;
	background-position: right 16px center;
	background-size: 16px 16px;
	padding-right: 44px;
}

/* Captcha row (math question + answer field) — targets the wrapper that CWSA
   typically renders around the captcha. Falls back gracefully if not present. */
#grve-sandbox-form .cwsa-captcha,
#grve-sandbox-form .grve-sandbox-captcha {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	gap: 10px;
	width: 100%;
}

#grve-sandbox-form .cwsa-captcha .cwsa-captcha-question,
#grve-sandbox-form .grve-sandbox-captcha-question {
	display: inline-flex;
	align-items: center;
	padding: var(--gwsand-field-py) var(--gwsand-field-px);
	background-color: var(--gwsand-captcha-bg);
	border: 1px solid var(--gwsand-border-c);
	border-radius: var(--gwsand-radius);
	font-size: var(--gwsand-font-size);
	line-height: var(--gwsand-line-height);
	color: var(--gwsand-text-c);
	white-space: nowrap;
	flex-shrink: 0;
}

#grve-sandbox-form .cwsa-captcha input,
#grve-sandbox-form .grve-sandbox-captcha input {
	flex: 1 1 auto;
	min-width: 0;
}

/* Submit button */
#grve-sandbox-form button[type="submit"],
#grve-sandbox-form .wp-block-button__link,
#grve-sandbox-form .wp-element-button {
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: center;
	padding: var(--gwsand-field-py) var(--gwsand-field-px);
	background-color: var(--gwsand-text-c);
	color: #ffffff;
	border: 1px solid var(--gwsand-text-c);
	border-radius: var(--gwsand-radius);
	font-size: var(--gwsand-font-size);
	line-height: var(--gwsand-line-height);
	font-weight: 400;
	text-align: center;
	text-decoration: none;
	cursor: pointer;
	box-shadow: none;
	transition: opacity .2s ease, background-color .2s ease;
}

#grve-sandbox-form button[type="submit"]:hover,
#grve-sandbox-form .wp-block-button__link:hover,
#grve-sandbox-form .wp-element-button:hover {
	opacity: 0.85;
	color: #ffffff;
}

/* Reset the wrapper around the submit button so it doesn't add extra centering
   that conflicts with the full-width button. */
#grve-sandbox-form .grve-sandbox-field:has(button[type="submit"]) {
	text-align: left;
}

/* Messages (if any) */
#grve-sandbox-form .cwsa-messages,
#grve-sandbox-form .grve-sandbox-messages {
	margin-bottom: 8px;
	font-size: 14px;
	line-height: 1.4;
}
