/* ============================================================
   Khymenko Booking Form — Design System v2.0 "Sage & Clay"
   Узгоджено з khymenko-custom-styles.php v2.0
   ============================================================ */

.khy-booking-wrap {
	font-family: var(--body, "Inter Tight", -apple-system, sans-serif);
	max-width: 100%;
}

.khy-booking-form {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

/* Honeypot field — повністю прихований */
.khy-booking-hp {
	position: absolute !important;
	left: -10000px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

.khy-booking-field {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.khy-booking-field label {
	font-family: var(--body, "Inter Tight", sans-serif);
	font-size: 14px;
	font-weight: 500;
	color: var(--ink, #2A2A28);
	letter-spacing: 0.01em;
}

.khy-required {
	color: var(--clay, #B87E5F);
	font-weight: 500;
	margin-left: 2px;
}

.khy-booking-form input[type="text"],
.khy-booking-form input[type="email"],
.khy-booking-form input[type="tel"],
.khy-booking-form select,
.khy-booking-form textarea {
	width: 100%;
	padding: 14px 16px;
	border: 1px solid var(--line, #E2DCD0);
	border-radius: 6px;
	font-size: 16px;     /* >= 16px — щоб iOS не зумив на focus */
	font-family: var(--body, "Inter Tight", sans-serif);
	color: var(--ink, #2A2A28);
	background: var(--surface, #FFFFFF);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	box-sizing: border-box;
	min-height: 44px;    /* WCAG touch target */
}

.khy-booking-form input::placeholder,
.khy-booking-form textarea::placeholder {
	color: var(--ink-mute, #8A8A82);
}

.khy-booking-form select {
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='none' stroke='%235A5A55' stroke-width='1.5' d='M1 1l5 5 5-5'/></svg>");
	background-repeat: no-repeat;
	background-position: right 16px center;
	padding-right: 44px;
	cursor: pointer;
}

.khy-booking-form textarea {
	resize: vertical;
	min-height: 100px;
	line-height: 1.55;
}

.khy-booking-form input:focus,
.khy-booking-form select:focus,
.khy-booking-form textarea:focus {
	outline: none;
	border-color: var(--sage, #6B7E6A);
	box-shadow: 0 0 0 3px rgba(107, 126, 106, 0.12);
}

/* Error state — поле з помилкою */
.khy-booking-field.has-error input,
.khy-booking-field.has-error select,
.khy-booking-field.has-error textarea {
	border-color: #B85F5F;
	background: #FCF6F4;
}

.khy-booking-error {
	display: none;
	font-size: 13px;
	color: #B85F5F;
	font-weight: 500;
	padding-left: 4px;
}

.khy-booking-field.has-error .khy-booking-error {
	display: block;
}

/* Submit button — ink primary (premium, тихий) */
.khy-booking-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	min-height: 52px;
	padding: 14px 32px;
	background-color: var(--ink, #2A2A28);
	color: var(--bg, #F7F4EE);
	border: 1px solid var(--ink, #2A2A28);
	border-radius: 999px;
	font-size: 15px;
	font-weight: 500;
	font-family: var(--body, "Inter Tight", sans-serif);
	letter-spacing: 0.01em;
	cursor: pointer;
	transition: background-color 0.2s ease;
	margin-top: 8px;
	box-shadow: none;
}

.khy-booking-submit:hover:not(:disabled) {
	background-color: var(--sage-deep, #4D5F4D);
	border-color: var(--sage-deep, #4D5F4D);
}

.khy-booking-submit:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Spinner — sage кольори */
.khy-booking-spinner {
	display: none;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(247, 244, 238, 0.3);
	border-top-color: var(--bg, #F7F4EE);
	border-radius: 50%;
	animation: khy-spin 0.7s linear infinite;
}

.khy-booking-form.is-loading .khy-booking-spinner {
	display: inline-block;
}

@keyframes khy-spin {
	to { transform: rotate(360deg); }
}

.khy-booking-required-note {
	font-size: 13px;
	color: var(--ink-mute, #8A8A82);
	margin: 8px 0 0;
	text-align: center;
	font-style: italic;
	font-family: var(--body, "Inter Tight", sans-serif);
}

/* Success state — тиха картка bg-soft, без gradient */
.khy-booking-success {
	background: var(--bg-soft, #EFEAE0);
	border: 1px solid var(--line, #E2DCD0);
	border-radius: 8px;
	padding: 48px 32px;
	text-align: center;
	animation: khy-fadeIn 0.4s ease-out;
}

@keyframes khy-fadeIn {
	from { opacity: 0; transform: translateY(10px); }
	to   { opacity: 1; transform: translateY(0); }
}

.khy-booking-success-emoji {
	display: none; /* прибираємо emoji — sage style без декору */
}

.khy-booking-success-title {
	font-family: var(--display, "Fraunces", serif);
	font-size: 32px;
	font-weight: 400;
	color: var(--ink, #2A2A28);
	margin: 0 0 16px;
	line-height: 1.2;
	letter-spacing: -0.02em;
}

.khy-booking-success-text {
	font-size: 16px;
	color: var(--ink-soft, #5A5A55);
	line-height: 1.6;
	margin: 0 0 24px;
	font-family: var(--body, "Inter Tight", sans-serif);
}

.khy-booking-success-contacts {
	font-size: 14px;
	color: var(--ink-mute, #8A8A82);
	line-height: 1.7;
	margin: 0;
	padding-top: 24px;
	border-top: 1px solid var(--line, #E2DCD0);
	font-family: var(--body, "Inter Tight", sans-serif);
}

.khy-booking-success-contacts a {
	color: var(--sage-deep, #4D5F4D);
	font-weight: 500;
	text-decoration: none;
	transition: color 0.2s ease;
}

.khy-booking-success-contacts a:hover {
	color: var(--ink, #2A2A28);
	text-decoration: underline;
}

/* Mobile */
@media (max-width: 640px) {
	.khy-booking-form { gap: 16px; }
	.khy-booking-success { padding: 36px 24px; }
	.khy-booking-success-title { font-size: 26px; }
}
