/**
 * Welcome Section Widget
 *
 * Styles for the TAMUK Welcome Elementor widget.
 * Uses theme design tokens from variables.css.
 *
 * @package TAMUK_Foundation
 * @since   1.0.0
 */

/* ===========================
   Container
   =========================== */
.tamuk-welcome {
	max-width: var(--container-xl, 1280px);
	margin: 0 auto;
	padding-left: var(--gutter, 1.5rem);
	padding-right: var(--gutter, 1.5rem);
}

/* ===========================
   Text Block
   =========================== */
.tamuk-welcome__text {
	text-align: center;
	margin-bottom: var(--space-12, 3rem);
	/* Entrance */
	opacity: 0;
	animation: tamuk-welcome-fade-up 0.6s ease 0.15s forwards;
}

.tamuk-welcome__heading {
	font-family: var(--font-heading, 'Cinzel', serif);
	font-weight: var(--weight-bold, 700);
	font-size: clamp(1.5rem, 3.5vw, 2.25rem);
	color: var(--tamuk-blue, #003399);
	letter-spacing: var(--tracking-wide, 0.025em);
	line-height: var(--leading-tight, 1.25);
	margin: 0 0 var(--space-4, 1rem);
	position: relative;
	display: inline-block;
	padding-bottom: var(--space-4, 1rem);
}

.tamuk-welcome__heading::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 3.5rem;
	height: 3px;
	background: var(--tamuk-gold, #FCC10F);
	border-radius: var(--radius-full, 9999px);
}

.tamuk-welcome__body {
	font-family: var(--font-body, 'Source Sans 3', sans-serif);
	font-weight: var(--weight-regular, 400);
	font-size: var(--text-base, 1.0625rem);
	color: var(--tamuk-gray-700, #374151);
	line-height: var(--leading-relaxed, 1.75);
	max-width: 820px;
	margin: var(--space-6, 1.5rem) auto 0;
}

.tamuk-welcome__body p {
	margin: 0 0 var(--space-4, 1rem);
}

.tamuk-welcome__body p:last-child {
	margin-bottom: 0;
}

@keyframes tamuk-welcome-fade-up {
	from {
		opacity: 0;
		transform: translateY(16px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.tamuk-welcome__text {
		opacity: 1;
		animation: none;
	}
}

/* ===========================
   Quick Links Grid
   =========================== */
.tamuk-welcome__links {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-5, 1.25rem);
}

/* ===========================
   Link Card
   =========================== */
.tamuk-welcome__link {
	display: flex;
	align-items: center;
	gap: var(--space-4, 1rem);
	padding: var(--space-5, 1.25rem) var(--space-5, 1.25rem);
	background: var(--tamuk-white, #FFFFFF);
	border-radius: var(--radius-lg, 0.75rem);
	border: 1px solid var(--color-border, #E5E7EB);
	text-decoration: none;
	transition:
		box-shadow var(--transition-base, 0.2s ease),
		transform var(--transition-base, 0.2s ease),
		border-color var(--transition-base, 0.2s ease);
	/* Entrance */
	opacity: 0;
	animation: tamuk-welcome-fade-up 0.5s ease forwards;
}

.tamuk-welcome__link:nth-child(1) { animation-delay: 0.3s; }
.tamuk-welcome__link:nth-child(2) { animation-delay: 0.4s; }
.tamuk-welcome__link:nth-child(3) { animation-delay: 0.5s; }
.tamuk-welcome__link:nth-child(4) { animation-delay: 0.6s; }
.tamuk-welcome__link:nth-child(n+5) { animation-delay: 0.65s; }

.tamuk-welcome__link:hover {
	box-shadow: var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, 0.1));
	transform: translateY(-3px);
	border-color: var(--tamuk-gold, #FCC10F);
}

@media (prefers-reduced-motion: reduce) {
	.tamuk-welcome__link {
		opacity: 1;
		animation: none;
	}
}

/* Icon circle */
.tamuk-welcome__link-icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	background: var(--tamuk-blue, #003399);
	border-radius: var(--radius-full, 9999px);
	color: var(--tamuk-gold, #FCC10F);
	transition: background var(--transition-base, 0.2s ease);
}

.tamuk-welcome__link-icon svg {
	width: 1.25rem;
	height: 1.25rem;
}

.tamuk-welcome__link:hover .tamuk-welcome__link-icon {
	background: var(--tamuk-blue-dark, #002266);
}

/* Text block */
.tamuk-welcome__link-text {
	display: flex;
	flex-direction: column;
	gap: 1px;
	flex: 1;
	min-width: 0;
}

.tamuk-welcome__link-label {
	font-family: var(--font-body, 'Source Sans 3', sans-serif);
	font-weight: var(--weight-bold, 700);
	font-size: var(--text-base, 1rem);
	color: var(--tamuk-gray-800, #1F2937);
	line-height: var(--leading-snug, 1.375);
}

.tamuk-welcome__link-desc {
	font-family: var(--font-body, 'Source Sans 3', sans-serif);
	font-weight: var(--weight-regular, 400);
	font-size: var(--text-sm, 0.875rem);
	color: var(--color-text-muted, #6B7280);
	line-height: var(--leading-normal, 1.5);
}

/* Arrow */
.tamuk-welcome__link-arrow {
	flex-shrink: 0;
	color: var(--tamuk-gray-300, #D1D5DB);
	transition: color var(--transition-base, 0.2s ease), transform var(--transition-base, 0.2s ease);
}

.tamuk-welcome__link-arrow svg {
	width: 1.125rem;
	height: 1.125rem;
}

.tamuk-welcome__link:hover .tamuk-welcome__link-arrow {
	color: var(--tamuk-blue, #003399);
	transform: translateX(3px);
}

/* ===========================
   Responsive — Tablet
   =========================== */
@media (max-width: 1024px) {
	.tamuk-welcome__links {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ===========================
   Responsive — Mobile
   =========================== */
@media (max-width: 640px) {
	.tamuk-welcome__links {
		grid-template-columns: 1fr;
		gap: var(--space-3, 0.75rem);
	}

	.tamuk-welcome__link {
		padding: var(--space-4, 1rem);
	}

	.tamuk-welcome__link-icon {
		width: 2.25rem;
		height: 2.25rem;
	}

	.tamuk-welcome__link-icon svg {
		width: 1rem;
		height: 1rem;
	}

	.tamuk-welcome__heading {
		font-size: var(--text-xl, 1.5rem);
	}

	.tamuk-welcome__body {
		font-size: var(--text-sm, 0.9375rem);
	}
}
