/*
 * La Galga Gris · section-contact.css
 * Split form / info panel para la página de contacto.
 */

.lgg-contact {
	padding-block: clamp(2rem, 5vw, 4rem) clamp(3rem, 6vw, 5rem);
}

.lgg-contact__grid {
	max-width: var(--container-wide);
	margin-inline: auto;
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2.5rem, 5vw, 4rem);
	align-items: start;
}
@media (min-width: 960px) {
	.lgg-contact__grid { grid-template-columns: 1.3fr 1fr; }
}

/* ── Form col ───────────────────────────────────────────────────── */
.lgg-contact__form-col { display: flex; flex-direction: column; gap: var(--sp-5); }
.lgg-contact__head { display: flex; flex-direction: column; gap: var(--sp-2); }
.lgg-contact__title {
	margin: 0;
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: var(--fw-medium);
	line-height: 1.1;
	letter-spacing: var(--ls-display);
	text-wrap: balance;
}
.lgg-contact__lead { margin: 0; max-width: 56ch; }

.lgg-contact__form {
	display: flex;
	flex-direction: column;
	gap: var(--sp-4);
	padding: var(--sp-5);
	background: var(--color-bg-card);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-lg);
}
@media (min-width: 640px) {
	.lgg-contact__form { padding: var(--sp-6); }
}

.lgg-contact__form-row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sp-3);
}
@media (min-width: 640px) {
	.lgg-contact__form-row { grid-template-columns: 1fr 1fr; }
}

.lgg-contact__consent {
	flex-direction: row !important;
	gap: var(--sp-2);
	align-items: flex-start;
}
.lgg-contact__consent-label {
	display: flex;
	gap: var(--sp-2);
	font-size: var(--fz-small);
	color: var(--color-ink-secondary);
	cursor: pointer;
	line-height: 1.5;
}
.lgg-contact__consent-label input[type="checkbox"] {
	margin-top: 3px;
	accent-color: var(--color-accent);
	width: 16px; height: 16px;
	flex: 0 0 auto;
}
.lgg-contact__consent-label a {
	color: var(--color-ink-primary);
	text-decoration: underline;
	text-underline-offset: 2px;
}
.lgg-contact__consent-label a:hover { color: var(--color-accent); }

.lgg-contact__honeypot {
	position: absolute !important;
	left: -9999px !important;
	height: 0 !important; width: 0 !important;
	overflow: hidden !important;
}

.lgg-contact__actions {
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
	align-items: flex-start;
	margin-top: var(--sp-2);
}
.lgg-contact__status {
	margin: 0;
	min-height: 1.2em;
}
.lgg-contact__status.is-success { color: var(--color-success); font-weight: var(--fw-semibold); }
.lgg-contact__status.is-error   { color: var(--color-danger);  font-weight: var(--fw-semibold); }
.lgg-contact__status.is-loading { color: var(--color-ink-muted); }

/* ── Info col ───────────────────────────────────────────────────── */
.lgg-contact__info-col {
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
}

.lgg-contact__media {
	margin: 0;
}
.lgg-contact__media .lgg-ratio {
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--color-bg-subtle);
	box-shadow: var(--shadow-md);
}
.lgg-contact__media .lgg-ratio img {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform var(--dur-hero) var(--ease-emphasized);
}
.lgg-contact__media:hover .lgg-ratio img { transform: scale(1.04); }
@media (prefers-reduced-motion: reduce) {
	.lgg-contact__media:hover .lgg-ratio img { transform: none; }
}

.lgg-contact__info { display: flex; flex-direction: column; gap: var(--sp-4); }
.lgg-contact__info-h {
	margin: 0;
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: var(--fw-medium);
	line-height: 1.15;
}

.lgg-contact__channels {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
}
.lgg-contact__channels a {
	display: flex;
	align-items: center;
	gap: var(--sp-3);
	padding: var(--sp-3);
	background: var(--color-bg-card);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-md);
	color: var(--color-ink-primary);
	text-decoration: none;
	transition: border-color var(--dur-fast) var(--ease-standard),
				background var(--dur-fast) var(--ease-standard),
				transform var(--dur-fast) var(--ease-emphasized);
}
.lgg-contact__channels a:hover {
	border-color: var(--color-accent);
	background: var(--color-bg-base);
	transform: translateX(4px);
}
@media (prefers-reduced-motion: reduce) {
	.lgg-contact__channels a:hover { transform: none; }
}

.lgg-contact__ch-icon {
	width: 36px; height: 36px;
	border-radius: 50%;
	background: var(--color-accent-soft);
	color: var(--color-accent-hover);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
}

.lgg-contact__ch-body { display: flex; flex-direction: column; gap: 1px; }
.lgg-contact__ch-body strong {
	font-family: var(--font-body);
	font-weight: var(--fw-semibold);
	font-size: var(--fz-small);
}
.lgg-contact__ch-value {
	font-family: var(--font-mono);
	font-size: 0.85rem;
	color: var(--color-ink-secondary);
}
.lgg-contact__ch-body small {
	color: var(--color-ink-muted);
	font-size: var(--fz-micro);
	margin-top: 2px;
}

/* ── Hours ──────────────────────────────────────────────────────── */
.lgg-contact__hours {
	padding-top: var(--sp-3);
	border-top: 1px solid var(--color-border-subtle);
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
}
.lgg-contact__hours dl {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.lgg-contact__hours dl > div {
	display: flex;
	justify-content: space-between;
	padding: 4px 0;
	border-bottom: 1px dashed var(--color-border-subtle);
}
.lgg-contact__hours dl > div:last-child { border-bottom: 0; }
.lgg-contact__hours dt {
	font-size: var(--fz-small);
	color: var(--color-ink-secondary);
}
.lgg-contact__hours dd {
	margin: 0;
	font-family: var(--font-mono);
	font-size: var(--fz-small);
	color: var(--color-ink-primary);
	font-weight: var(--fw-medium);
}
