/* ==========================================================================
   Contact Form (AJAX) — styling για partnership inquiry
   ========================================================================== */

/* Dedicated Contact page layout */
.contact-page__grid {
	display: grid;
	grid-template-columns: .9fr 1.3fr;
	gap: 48px;
	align-items: start;
}
.contact-page__info h3 {
	font-size: 1.15rem;
	margin: 0 0 18px;
	color: var(--text);
}
.contact-page__info .partner-closing__quote {
	margin-top: 28px;
}
.contact-page__form {
	width: 100%;
	max-width: 100%;
	min-width: 0;
}
@media (max-width: 860px) {
	.contact-page__grid {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	/* Extra spacing on mobile between quote και form */
	.contact-page__info .partner-closing__quote { margin-bottom: 16px; }
}

/* Partner contact wrapper (embedded in partners mold) */
.partner-contact {
	margin-top: 40px;
	padding: 36px;
	background: var(--surface);
	border: 1px solid var(--border-strong);
	border-radius: var(--radius-lg);
	display: grid;
	grid-template-columns: .9fr 1.1fr;
	gap: 36px;
	align-items: start;
	backdrop-filter: blur(10px);
}
.partner-contact__intro h3 {
	font-size: 1.3rem;
	margin: 0 0 10px;
	color: var(--text);
	text-transform: none;
	letter-spacing: 0;
}
.partner-contact__intro p {
	color: var(--text-muted);
	font-size: .95rem;
	margin: 0 0 20px;
	line-height: 1.6;
}
.partner-contact__meta {
	list-style: none;
	margin: 0; padding: 0;
	display: flex; flex-direction: column; gap: 12px;
}
.partner-contact__meta li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: .92rem;
	color: var(--text);
	font-family: var(--font-mono);
}
.partner-contact__meta span { color: var(--accent); width: 18px; }
.partner-contact__meta a { color: var(--text); }
.partner-contact__meta a:hover { color: var(--accent); }

/* Form */
.contact-form {
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.contact-form--compact .contact-form__header { display: none; }

.contact-form__header h3 {
	font-size: 1.25rem;
	margin: 0 0 6px;
}
.contact-form__header p {
	color: var(--text-muted);
	font-size: .92rem;
	margin: 0;
}

.contact-form__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

.contact-field,
.contact-consent {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.contact-field--full { grid-column: 1 / -1; }

.contact-field__label {
	font-family: var(--font-mono);
	font-size: .72rem;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--text-muted);
}
.contact-field__label em {
	color: var(--accent-warm);
	font-style: normal;
	margin-left: 4px;
}

.contact-field input,
.contact-field select,
.contact-field textarea {
	width: 100%;
	padding: 12px 14px;
	background: var(--bg-elev-2);
	border: 1px solid var(--border);
	border-radius: 10px;
	color: var(--text);
	font-family: inherit;
	font-size: .95rem;
	transition: border-color .2s, background .2s, box-shadow .2s;
	outline: none;
}
.contact-field textarea {
	resize: vertical;
	min-height: 110px;
	font-family: inherit;
	line-height: 1.5;
}
.contact-field select {
	appearance: none;
	-webkit-appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--text-muted) 50%), linear-gradient(135deg, var(--text-muted) 50%, transparent 50%);
	background-position: calc(100% - 20px) center, calc(100% - 14px) center;
	background-size: 6px 6px;
	background-repeat: no-repeat;
	padding-right: 36px;
	cursor: pointer;
}
.contact-field select option { background: var(--bg-elev-1); color: var(--text); }

.contact-field input:focus,
.contact-field select:focus,
.contact-field textarea:focus {
	border-color: var(--accent);
	background: var(--bg-elev-3);
	box-shadow: 0 0 0 3px rgba(20,184,166,.15);
}

.contact-field--error input,
.contact-field--error select,
.contact-field--error textarea {
	border-color: var(--danger);
	background: rgba(255,71,71,.04);
}
.contact-field--error input:focus,
.contact-field--error select:focus,
.contact-field--error textarea:focus {
	box-shadow: 0 0 0 3px rgba(255,71,71,.12);
}

.contact-field__err {
	display: block;
	min-height: 0;
	font-size: .78rem;
	color: var(--danger);
	overflow: hidden;
	transition: min-height .2s;
}
.contact-field__err[data-shown] { min-height: 1.2em; }

/* Consent checkbox */
.contact-consent {
	flex-direction: row;
	align-items: flex-start;
	gap: 10px;
	padding: 14px 16px;
	background: var(--bg-elev-2);
	border: 1px solid var(--border);
	border-radius: 10px;
}
.contact-consent input[type="checkbox"] {
	width: 18px; height: 18px;
	flex-shrink: 0;
	margin-top: 2px;
	accent-color: var(--accent);
	cursor: pointer;
}
.contact-consent > span {
	font-size: .85rem;
	color: var(--text-muted);
	line-height: 1.5;
}
.contact-consent.contact-field--error {
	border-color: var(--danger);
	background: rgba(255,71,71,.04);
}

/* Submit row */
.contact-form__submit {
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
}
.contact-form__submit .btn {
	min-width: 200px;
}
.contact-form__submit .btn:disabled {
	opacity: .65;
	cursor: wait;
	transform: none !important;
}

.contact-form__status {
	font-size: .9rem;
	flex: 1;
	min-width: 200px;
	padding: 10px 14px;
	border-radius: 8px;
	font-family: var(--font-mono);
}
.contact-form__status:empty { display: none; }
.contact-form__status[data-kind="success"] {
	background: rgba(0,214,143,.08);
	color: var(--success);
	border: 1px solid rgba(0,214,143,.3);
}
.contact-form__status[data-kind="error"] {
	background: rgba(255,71,71,.08);
	color: var(--danger);
	border: 1px solid rgba(255,71,71,.3);
}

@media (max-width: 860px) {
	.partner-contact { grid-template-columns: 1fr; padding: 24px; gap: 24px; }
	.contact-form__grid { grid-template-columns: 1fr; }
}
