/**
 * File: assets/css/pages/contact/cards.css
 * Description: Contact cards and location/remote work panels.
 *
 * MAGIDA CONTACT PAGE PASS 14.0:
 * - Adds premium clickable contact cards using existing global contact details.
 */

/* CHANGE: Shared lower-contact spacing and styled section kickers so the page matches the approved premium section language. */
.magida-contact-section {
	position: relative;
	padding: clamp(4.5rem, 7vw, 7rem) 0;
}

.magida-contact-section + .magida-contact-section {
	padding-top: clamp(3.75rem, 6vw, 6rem);
}

.magida-contact-section .magida-section-heading,
.magida-contact-form-copy,
.magida-contact-visit__copy {
	min-width: 0;
}

.magida-contact-section .magida-section-heading {
	max-width: 980px;
	margin-bottom: clamp(2rem, 4vw, 3.25rem);
}

.magida-contact-section .magida-section-kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.85rem;
	margin: 0 0 clamp(0.8rem, 1.4vw, 1rem);
	font-size: clamp(0.78rem, 1vw, 0.9rem);
	font-weight: 900;
	line-height: 1.1;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--magida-accent);
	text-shadow: 0 0 18px rgba(0, 214, 255, 0.24);
}

.magida-contact-section .magida-section-kicker::before {
	content: "";
	width: clamp(1.6rem, 3vw, 2.35rem);
	height: 2px;
	border-radius: 999px;
	background: linear-gradient(
		90deg,
		var(--magida-accent),
		rgba(117, 94, 255, 0.92)
	);
	box-shadow: 0 0 16px rgba(0, 214, 255, 0.34);
	flex: 0 0 auto;
}

.magida-contact-section .magida-section-heading h2,
.magida-contact-form-copy h2,
.magida-contact-visit__shell h2 {
	margin-top: 0;
}

.magida-contact-card-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(1.25rem, 2.4vw, 1.75rem);
	margin-top: 0; /* CHANGE: The section heading now controls the vertical rhythm. */
}

.magida-contact-card {
	position: relative;
	display: flex;
	min-height: 260px;
	flex-direction: column;
	justify-content: space-between;
	gap: 18px;
	padding: clamp(24px, 3vw, 34px);
	border: 1px solid rgba(190, 189, 229, 0.16);
	border-radius: 28px;
	background:
		radial-gradient(
			circle at 88% 88%,
			rgba(5, 223, 254, 0.14),
			transparent 34%
		),
		linear-gradient(145deg, rgba(12, 15, 26, 0.9), rgba(6, 8, 17, 0.9));
	color: var(--magida-white);
	text-decoration: none;
	overflow: hidden;
	min-width: 0; /* CHANGE: Prevent long values from forcing card clipping. */
	transition:
		transform var(--magida-transition),
		border-color var(--magida-transition),
		box-shadow var(--magida-transition);
}

.magida-contact-card::after {
	content: "";
	position: absolute;
	right: -36px;
	bottom: -36px;
	width: 128px;
	height: 128px;
	border: 1px solid rgba(5, 223, 254, 0.24);
	border-radius: 50%;
}

.magida-contact-card:hover,
.magida-contact-card:focus-visible {
	border-color: rgba(5, 223, 254, 0.44);
	box-shadow: var(--magida-glow-soft);
	transform: translateY(-6px);
}

.magida-contact-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border: 1px solid rgba(5, 223, 254, 0.28);
	border-radius: 18px;
	background: rgba(5, 223, 254, 0.08);
	color: var(--magida-cyan);
}

.magida-contact-card__icon svg {
	width: 22px;
	height: 22px;
}

.magida-contact-card__label {
	color: var(--magida-cyan);
	font-family: var(--magida-font-heading);
	font-size: 0.75rem;
	font-weight: 900;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.magida-contact-card strong {
	display: block; /* CHANGE: Allows max-width and wrapping rules to work consistently. */
	max-width: 100%; /* CHANGE: Constrain long contact values to the card width. */
	font-family: var(--magida-font-heading);
	font-size: clamp(1.15rem, 1.6vw, 1.45rem);
	line-height: 1.1;
	letter-spacing: -0.04em;
	overflow-wrap: anywhere; /* CHANGE: Stop the email address from clipping on desktop/tablet. */
	word-break: normal;
}

.magida-contact-card__description {
	color: var(--magida-text-soft);
	font-size: 0.98rem;
	line-height: 1.75;
}

.magida-contact-visit__shell {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(300px, 0.6fr);
	gap: 28px;
	align-items: stretch;
	padding: clamp(28px, 5vw, 56px);
	border: 1px solid rgba(190, 189, 229, 0.16);
	border-radius: 34px;
	background:
		radial-gradient(
			circle at 80% 20%,
			rgba(124, 106, 251, 0.16),
			transparent 34%
		),
		linear-gradient(145deg, rgba(12, 15, 26, 0.84), rgba(6, 8, 17, 0.92));
	overflow: hidden;
}

.magida-contact-visit__shell h2 {
	max-width: 760px;
	margin: 0;
	color: var(--magida-white);
	font-family: var(--magida-font-heading);
	font-size: clamp(2.2rem, 5vw, 5.2rem);
	line-height: 0.94;
	letter-spacing: -0.08em;
}

.magida-contact-visit__shell p {
	max-width: 760px;
	margin: 24px 0 0;
	color: var(--magida-text-soft);
	font-size: clamp(1rem, 1.4vw, 1.25rem);
	line-height: 1.8;
}

.magida-contact-visit__panel {
	display: flex;
	min-height: 260px;
	flex-direction: column;
	justify-content: flex-end;
	gap: 16px;
	padding: clamp(24px, 4vw, 40px);
	border: 1px solid rgba(5, 223, 254, 0.26);
	border-radius: 28px;
	background:
		radial-gradient(
			circle at 74% 28%,
			rgba(5, 223, 254, 0.16),
			transparent 34%
		),
		rgba(5, 8, 18, 0.78);
}

.magida-contact-visit__panel span,
.magida-contact-visit__panel small {
	font-family: var(--magida-font-heading);
	font-weight: 900;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.magida-contact-visit__panel span {
	color: var(--magida-cyan);
	font-size: 0.78rem;
}

.magida-contact-visit__panel strong {
	color: var(--magida-white);
	font-family: var(--magida-font-heading);
	font-size: clamp(1.7rem, 3vw, 2.8rem);
	line-height: 1.05;
	letter-spacing: -0.06em;
}

.magida-contact-visit__panel small {
	color: var(--magida-text-muted);
	font-size: 0.74rem;
	line-height: 1.8;
}

@media (max-width: 1080px) {
	.magida-contact-card-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.magida-contact-visit__shell {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.magida-contact-card-grid {
		grid-template-columns: 1fr;
	}

	.magida-contact-card {
		min-height: 220px;
	}
}

/* CHANGE: Contact lower-section spacing and long-value handling for tablet/mobile. */
@media (max-width: 900px) {
	.magida-contact-section {
		padding: clamp(3.25rem, 8vw, 5rem) 0;
	}

	.magida-contact-section + .magida-contact-section {
		padding-top: clamp(3rem, 7vw, 4.5rem);
	}
}

@media (max-width: 640px) {
	.magida-contact-section .magida-section-kicker {
		gap: 0.65rem;
		letter-spacing: 0.1em;
	}

	.magida-contact-card strong {
		font-size: clamp(1.1rem, 6vw, 1.35rem);
	}
}

/* MAGIDA HUMAN MEDIA CONTACT PASS 23.5.7:
   Optional human/studio visual for the existing Contact visit panel only. */
.magida-contact-visit__panel--has-media {
	justify-content: space-between;
	padding: clamp(18px, 3vw, 26px);
}

.magida-contact-visit__panel-copy {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.magida-contact-visit-media {
	position: relative;
	z-index: 1;
	min-height: clamp(170px, 18vw, 230px);
	margin: 0;
	border: 1px solid rgba(190, 189, 229, 0.16);
	border-radius: 24px;
	background:
		radial-gradient(
			circle at 80% 10%,
			rgba(5, 223, 254, 0.18),
			transparent 40%
		),
		rgba(6, 8, 17, 0.56);
	box-shadow: 0 18px 54px rgba(0, 0, 0, 0.28);
	overflow: hidden;
}

.magida-contact-visit-media::after {
	/* MAGIDA HUMAN MEDIA CONTACT PASS 23.5.7: Theme overlay keeps real imagery inside the cinematic Magida look. */
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, transparent 42%, rgba(6, 8, 17, 0.42)),
		radial-gradient(
			circle at 88% 18%,
			rgba(5, 223, 254, 0.18),
			transparent 36%
		);
	pointer-events: none;
}

.magida-contact-visit-media__image,
.magida-contact-visit-media img {
	display: block;
	width: 100%;
	height: 100%;
	min-height: inherit;
	object-fit: cover;
	filter: saturate(0.94) contrast(1.03);
	transform: scale(1.01);
}

@media (max-width: 1080px) {
	.magida-contact-visit__panel--has-media {
		min-height: auto;
	}

	.magida-contact-visit-media {
		min-height: clamp(220px, 38vw, 340px);
	}
}

@media (max-width: 640px) {
	.magida-contact-visit__panel--has-media {
		padding: 18px;
	}

	.magida-contact-visit-media {
		min-height: 220px;
		border-radius: 22px;
	}
}

/* MAGIDA CONTACT MAP PASS 23.6.1:
   Optional map block for the existing Contact visit/location panel only. */
.magida-contact-visit__panel--has-map {
	justify-content: space-between;
	padding: clamp(18px, 3vw, 26px);
}

.magida-contact-map {
	position: relative;
	z-index: 1;
	display: grid;
	/* MAGIDA CONTACT MAP PASS 23.6.1.1: Keep the map card constrained inside narrow mobile panels. */
	width: 100%;
	max-width: 100%;
	min-width: 0;
	box-sizing: border-box;
	gap: 16px;
	padding: clamp(14px, 2vw, 18px);
	border: 1px solid rgba(190, 189, 229, 0.14);
	border-radius: 26px;
	background:
		radial-gradient(
			circle at 18% 8%,
			rgba(112, 72, 255, 0.18),
			transparent 34%
		),
		radial-gradient(
			circle at 88% 18%,
			rgba(5, 223, 254, 0.14),
			transparent 36%
		),
		rgba(6, 8, 17, 0.58);
	box-shadow: 0 18px 58px rgba(0, 0, 0, 0.3);
	overflow: hidden;
}

.magida-contact-map::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		135deg,
		rgba(255, 255, 255, 0.08),
		transparent 32%,
		rgba(5, 223, 254, 0.07)
	);
	opacity: 0.72;
	pointer-events: none;
}

.magida-contact-map__frame,
.magida-contact-map__content {
	position: relative;
	z-index: 1;
}

.magida-contact-map__frame {
	/* MAGIDA CONTACT MAP PASS 23.6.1.1: Explicit width/min-width prevents aspect-ratio from forcing overflow on phones. */
	width: 100%;
	max-width: 100%;
	min-width: 0;
	box-sizing: border-box;
	min-height: 210px;
	aspect-ratio: 16 / 10;
	border: 1px solid rgba(190, 189, 229, 0.16);
	border-radius: 22px;
	background: rgba(10, 13, 28, 0.72);
	overflow: hidden;
}

.magida-contact-map__frame iframe {
	display: block;
	width: 100% !important;
	height: 100% !important;
	min-height: inherit;
	border: 0;
	filter: saturate(0.92) contrast(1.04);
}

.magida-contact-map__frame--static {
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.055) 1px, transparent 1px),
		linear-gradient(0deg, rgba(255, 255, 255, 0.055) 1px, transparent 1px),
		radial-gradient(
			circle at 50% 50%,
			rgba(112, 72, 255, 0.28),
			transparent 42%
		),
		rgba(7, 10, 22, 0.82);
	background-size:
		38px 38px,
		38px 38px,
		auto,
		auto;
}

.magida-contact-map__frame--static::after {
	content: "";
	position: absolute;
	inset: 14%;
	border: 1px dashed rgba(5, 223, 254, 0.34);
	border-radius: 999px;
	box-shadow:
		0 0 0 38px rgba(112, 72, 255, 0.055),
		0 0 60px rgba(5, 223, 254, 0.16);
}

.magida-contact-map__orbit {
	position: absolute;
	border: 1px solid rgba(190, 189, 229, 0.14);
	border-radius: 999px;
}

.magida-contact-map__orbit--one {
	inset: 22% 18%;
}

.magida-contact-map__orbit--two {
	inset: 34% 28%;
}

.magida-contact-map__pin {
	position: absolute;
	top: 50%;
	left: 50%;
	display: grid;
	width: 54px;
	height: 54px;
	place-items: center;
	border: 1px solid rgba(5, 223, 254, 0.44);
	border-radius: 18px;
	background: linear-gradient(
		135deg,
		rgba(5, 223, 254, 0.22),
		rgba(112, 72, 255, 0.2)
	);
	box-shadow: 0 18px 40px rgba(5, 223, 254, 0.16);
	transform: translate(-50%, -50%) rotate(-6deg);
}

.magida-contact-map__pin svg {
	width: 28px;
	height: 28px;
	fill: var(--magida-text-strong);
}

.magida-contact-map__content {
	display: grid;
	gap: 8px;
}

.magida-contact-map__content span {
	color: var(--magida-accent-cyan);
	font-size: 0.68rem;
	font-weight: 800;
	letter-spacing: 0.13em;
	text-transform: uppercase;
}

.magida-contact-map__content strong {
	color: var(--magida-text-strong);
	font-family: var(--magida-font-display);
	font-size: clamp(1.08rem, 2vw, 1.35rem);
	line-height: 1.2;
}

.magida-contact-map__content p {
	max-width: 44rem;
	margin: 0;
	color: var(--magida-text-muted);
	font-size: 0.86rem;
	line-height: 1.75;
}

.magida-contact-map__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
	min-height: 40px;
	margin-top: 4px;
	padding: 0 15px;
	border: 1px solid rgba(5, 223, 254, 0.28);
	border-radius: 999px;
	color: var(--magida-text-strong);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.04em;
	text-decoration: none;
	transition:
		transform 0.22s ease,
		border-color 0.22s ease,
		background 0.22s ease;
}

.magida-contact-map__link:hover,
.magida-contact-map__link:focus-visible {
	border-color: rgba(5, 223, 254, 0.58);
	background: rgba(5, 223, 254, 0.09);
	transform: translateY(-2px);
}

@media (max-width: 1080px) {
	.magida-contact-visit__panel--has-map {
		min-height: auto;
	}

	.magida-contact-map__frame {
		min-height: clamp(220px, 38vw, 340px);
	}
}

@media (max-width: 640px) {
	.magida-contact-visit__panel--has-map {
		padding: 18px;
	}

	.magida-contact-map {
		/* MAGIDA CONTACT MAP PASS 23.6.1.1: Reduce the inner padding/gap so the static map breathes inside phone-width cards. */
		gap: 14px;
		padding: 12px;
		border-radius: 24px;
	}

	.magida-contact-map__frame {
		/* MAGIDA CONTACT MAP PASS 23.6.1.1: Mobile frame must size from available width, not from a large minimum height. */
		aspect-ratio: 4 / 3;
		min-height: 0;
		border-radius: 20px;
	}

	.magida-contact-map__pin {
		/* MAGIDA CONTACT MAP PASS 23.6.1.1: Slightly smaller pin prevents edge pressure inside narrow mockups. */
		width: 48px;
		height: 48px;
		border-radius: 16px;
	}

	.magida-contact-map__pin svg {
		width: 24px;
		height: 24px;
	}
}

/* MAGIDA CONTACT RHYTHM POLISH PASS 24.1.40:
   Tightens Contact lower sections, protects long email values, and makes the visit media crop safer. */
.magida-contact-section {
	padding: clamp(3.75rem, 5.8vw, 5.9rem) 0;
}

.magida-contact-section + .magida-contact-section {
	padding-top: clamp(2.75rem, 4.4vw, 4.6rem);
}

.magida-contact-section .magida-section-heading {
	margin-bottom: clamp(1.65rem, 3vw, 2.45rem);
}

.magida-contact-card-grid {
	gap: clamp(1rem, 1.8vw, 1.45rem);
}

.magida-contact-card {
	min-height: 238px;
	gap: 14px;
	padding: clamp(22px, 2.4vw, 30px);
}

.magida-contact-card__icon {
	width: 48px;
	height: 48px;
	border-radius: 16px;
}

.magida-contact-card strong {
	font-size: clamp(1.08rem, 1.22vw, 1.3rem);
	line-height: 1.14;
}

.magida-contact-card[href^="mailto:"] strong {
	font-size: clamp(0.98rem, 1.05vw, 1.08rem);
	letter-spacing: -0.045em;
	overflow-wrap: normal;
	word-break: normal;
}

.magida-contact-card__description {
	font-size: 0.95rem;
	line-height: 1.68;
}

.magida-contact-visit__shell {
	grid-template-columns: minmax(0, 1fr) minmax(300px, 0.52fr);
	gap: clamp(22px, 3vw, 34px);
	align-items: start;
	padding: clamp(28px, 4vw, 48px);
}

.magida-contact-visit__shell p {
	margin-top: 20px;
}

.magida-contact-visit__panel,
.magida-contact-visit__panel--has-media,
.magida-contact-visit__panel--has-map {
	gap: 14px;
	padding: clamp(18px, 2.4vw, 24px);
}

.magida-contact-visit__panel-copy {
	gap: 12px;
}

.magida-contact-visit-media {
	min-height: clamp(150px, 13vw, 198px);
}

.magida-contact-visit-media__image,
.magida-contact-visit-media img {
	object-fit: contain;
	object-position: center top;
	transform: none;
}

.magida-contact-map {
	gap: 12px;
	padding: clamp(12px, 1.6vw, 16px);
}

.magida-contact-map__frame {
	min-height: 175px;
	aspect-ratio: 16 / 9;
}

@media (min-width: 1280px) {
	.magida-contact-card[href^="mailto:"] strong {
		white-space: nowrap;
	}
}

@media (max-width: 1180px) {
	.magida-contact-card[href^="mailto:"] strong {
		white-space: normal;
		overflow-wrap: anywhere;
	}
}

@media (max-width: 1080px) {
	.magida-contact-visit__shell {
		grid-template-columns: 1fr;
	}

	.magida-contact-visit-media,
	.magida-contact-map__frame {
		min-height: clamp(210px, 34vw, 320px);
	}
}

@media (max-width: 900px) {
	.magida-contact-section {
		padding: clamp(3rem, 7vw, 4.4rem) 0;
	}

	.magida-contact-section + .magida-contact-section {
		padding-top: clamp(2.5rem, 6vw, 3.7rem);
	}
}

@media (max-width: 640px) {
	.magida-contact-card {
		min-height: 205px;
	}

	.magida-contact-card strong,
	.magida-contact-card[href^="mailto:"] strong {
		font-size: clamp(1.02rem, 5vw, 1.22rem);
		white-space: normal;
		overflow-wrap: anywhere;
	}

	.magida-contact-visit__shell {
		padding: 22px;
		border-radius: 28px;
	}

	.magida-contact-visit-media {
		min-height: 190px;
	}
}

/* MAGIDA CONTACT RHYTHM FOLLOW-UP PASS 24.1.41:
   Gently tightens Contact section-to-section spacing after visual QA. */
.magida-contact-section {
	padding: clamp(3.35rem, 5vw, 5.25rem) 0;
}

.magida-contact-section + .magida-contact-section {
	padding-top: clamp(2.15rem, 3.5vw, 3.65rem);
}

.magida-contact-section .magida-section-heading {
	margin-bottom: clamp(1.45rem, 2.55vw, 2.15rem);
}

.magida-contact-visit {
	padding-top: clamp(2rem, 3.35vw, 3.4rem);
}

@media (max-width: 900px) {
	.magida-contact-section {
		padding: clamp(2.75rem, 6.4vw, 4rem) 0;
	}

	.magida-contact-section + .magida-contact-section,
	.magida-contact-visit {
		padding-top: clamp(2.15rem, 5.2vw, 3.25rem);
	}
}

@media (max-width: 640px) {
	.magida-contact-section {
		padding: clamp(2.45rem, 8vw, 3.4rem) 0;
	}

	.magida-contact-section + .magida-contact-section,
	.magida-contact-visit {
		padding-top: clamp(1.9rem, 7vw, 2.8rem);
	}
}
