/**
 * Quick Links Widget
 *
 * Styles for the TAMUK Quick Links Elementor widget.
 * Supports four visual styles: pills, underline, cards, minimal.
 *
 * @package TAMUK_Foundation
 * @since   1.0.0
 */

/* ==========================================================
   Design tokens (scoped fallbacks)
   ========================================================== */
:root {
	--tamuk-ql-blue: var(--tamuk-blue, #003399);
	--tamuk-ql-blue-light: var(--tamuk-blue-lightest, #e8eef8);
	--tamuk-ql-gold: var(--tamuk-gold, #FCC10F);
	--tamuk-ql-gray-200: var(--tamuk-gray-200, #e5e7eb);
	--tamuk-ql-gray-400: var(--tamuk-gray-400, #9ca3af);
	--tamuk-ql-radius-md: var(--radius-md, 0.5rem);
	--tamuk-ql-shadow-sm: var(--shadow-sm, 0 1px 2px rgba(0, 0, 0, 0.05));
	--tamuk-ql-shadow-md: var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, 0.1));
}

/* ==========================================================
   Base
   ========================================================== */
.tamuk-ql {
	width: 100%;
	padding: var(--space-3, 0.75rem) var(--gutter, 1rem);
	box-sizing: border-box;
}

.tamuk-ql-list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3, 0.75rem);
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Alignment */
.tamuk-ql-list--left {
	justify-content: flex-start;
}

.tamuk-ql-list--center {
	justify-content: center;
}

.tamuk-ql-list--right {
	justify-content: flex-end;
}

/* Links */
.tamuk-ql-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	text-decoration: none;
	font-family: var(--font-body, 'Source Sans 3', sans-serif);
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	line-height: 1.4;
	transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
	color: var(--tamuk-ql-blue);
}

.tamuk-ql-link:focus-visible {
	outline: 2px solid var(--tamuk-ql-gold);
	outline-offset: 2px;
	border-radius: 2px;
}

/* Icons */
.tamuk-ql-icon {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

/* Divider */
.tamuk-ql-divider {
	width: 1px;
	height: 20px;
	background: currentColor;
	opacity: 0.2;
	align-self: center;
	flex-shrink: 0;
}

/* ==========================================================
   Style: Pills
   ========================================================== */
.tamuk-ql--pills .tamuk-ql-link {
	padding: 0.4rem 1rem;
	border-radius: 9999px;
	background: var(--tamuk-ql-blue-light);
	color: var(--tamuk-ql-blue);
}

.tamuk-ql--pills .tamuk-ql-link:hover {
	background: var(--tamuk-ql-blue);
	color: #fff;
}

.tamuk-ql--pills .tamuk-ql-item--highlight .tamuk-ql-link {
	background: var(--tamuk-ql-blue);
	color: #fff;
}

.tamuk-ql--pills .tamuk-ql-item--highlight .tamuk-ql-link:hover {
	background: var(--tamuk-ql-gold);
	color: var(--tamuk-ql-blue);
}

/* ==========================================================
   Style: Underline
   ========================================================== */
.tamuk-ql--underline .tamuk-ql-link {
	padding: 0.4rem 0.25rem;
	background: none;
	border-bottom: 2px solid transparent;
	border-radius: 0;
	color: var(--tamuk-ql-blue);
}

.tamuk-ql--underline .tamuk-ql-link:hover {
	border-bottom-color: var(--tamuk-ql-gold);
	color: var(--tamuk-ql-blue);
}

.tamuk-ql--underline .tamuk-ql-item--highlight .tamuk-ql-link {
	border-bottom-color: var(--tamuk-ql-gold);
}

.tamuk-ql--underline .tamuk-ql-item--highlight .tamuk-ql-link:hover {
	border-bottom-color: var(--tamuk-ql-blue);
}

/* ==========================================================
   Style: Cards
   ========================================================== */
.tamuk-ql--cards .tamuk-ql-link {
	padding: 0.75rem 1.25rem;
	background: #fff;
	border: 1px solid var(--tamuk-ql-gray-200);
	border-radius: var(--tamuk-ql-radius-md);
	box-shadow: var(--tamuk-ql-shadow-sm);
	color: var(--tamuk-ql-blue);
}

.tamuk-ql--cards .tamuk-ql-link:hover {
	transform: translateY(-2px);
	box-shadow: var(--tamuk-ql-shadow-md);
	border-top: 3px solid var(--tamuk-ql-gold);
	color: var(--tamuk-ql-blue);
}

.tamuk-ql--cards .tamuk-ql-item--highlight .tamuk-ql-link {
	border-top: 3px solid var(--tamuk-ql-gold);
	background: #fefdf5;
}

.tamuk-ql--cards .tamuk-ql-item--highlight .tamuk-ql-link:hover {
	box-shadow: var(--tamuk-ql-shadow-md);
	transform: translateY(-2px);
}

.tamuk-ql--cards .tamuk-ql-icon {
	width: 18px;
	height: 18px;
}

/* ==========================================================
   Style: Minimal
   ========================================================== */
.tamuk-ql--minimal .tamuk-ql-list {
	gap: var(--space-2, 0.5rem);
}

.tamuk-ql--minimal .tamuk-ql-link {
	padding: 0.2rem 0.4rem;
	font-size: var(--text-xs, 0.8125rem);
	font-weight: 600;
	color: var(--tamuk-ql-blue);
	background: none;
	border-radius: 0;
}

.tamuk-ql--minimal .tamuk-ql-link:hover {
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-color: var(--tamuk-ql-gold);
}

.tamuk-ql--minimal .tamuk-ql-item--highlight .tamuk-ql-link {
	font-weight: 700;
}

/* ==========================================================
   Entrance animation
   ========================================================== */
.tamuk-ql-item {
	opacity: 0;
	transform: translateY(8px);
	animation: tamukQlFadeIn 0.35s ease forwards;
}

/* Stagger each item */
.tamuk-ql-item:nth-child(1)  { animation-delay: 0s; }
.tamuk-ql-item:nth-child(2)  { animation-delay: 0.04s; }
.tamuk-ql-item:nth-child(3)  { animation-delay: 0.08s; }
.tamuk-ql-item:nth-child(4)  { animation-delay: 0.12s; }
.tamuk-ql-item:nth-child(5)  { animation-delay: 0.16s; }
.tamuk-ql-item:nth-child(6)  { animation-delay: 0.20s; }
.tamuk-ql-item:nth-child(7)  { animation-delay: 0.24s; }
.tamuk-ql-item:nth-child(8)  { animation-delay: 0.28s; }
.tamuk-ql-item:nth-child(9)  { animation-delay: 0.32s; }
.tamuk-ql-item:nth-child(10) { animation-delay: 0.36s; }

@keyframes tamukQlFadeIn {
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
	.tamuk-ql-item {
		opacity: 1;
		transform: none;
		animation: none;
	}
}

/* ==========================================================
   Responsive — Tablet (max-width: 768px)
   ========================================================== */
@media (max-width: 768px) {
	.tamuk-ql {
		padding: var(--space-3, 0.75rem) var(--space-4, 1rem);
	}

	/* All styles: wrap and center */
	.tamuk-ql-list {
		justify-content: center !important;
		gap: var(--space-2, 0.5rem);
	}

	/* Hide dividers on mobile */
	.tamuk-ql-divider {
		display: none;
	}

	/* Pills: full-width stacking */
	.tamuk-ql--pills .tamuk-ql-list {
		flex-direction: column;
	}

	.tamuk-ql--pills .tamuk-ql-link {
		width: 100%;
		justify-content: center;
		padding: 0.65rem 1rem;
		font-size: var(--text-base, 1rem);
	}

	/* Underline: wrap with bigger touch targets */
	.tamuk-ql--underline .tamuk-ql-list {
		flex-wrap: wrap;
		gap: var(--space-1, 0.25rem) var(--space-3, 0.75rem);
	}

	.tamuk-ql--underline .tamuk-ql-link {
		padding: 0.5rem 0.25rem;
		font-size: var(--text-base, 1rem);
	}

	/* Cards: 2-column grid */
	.tamuk-ql--cards .tamuk-ql-list {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-2, 0.5rem);
	}

	.tamuk-ql--cards .tamuk-ql-link {
		width: 100%;
		justify-content: center;
		text-align: center;
		padding: 0.75rem 0.75rem;
	}

	/* Minimal: wrap with spacing */
	.tamuk-ql--minimal .tamuk-ql-list {
		flex-wrap: wrap;
		justify-content: center !important;
	}

	.tamuk-ql--minimal .tamuk-ql-link {
		font-size: var(--text-sm, 0.875rem);
		padding: 0.4rem 0.5rem;
	}
}

/* ==========================================================
   Responsive — Small Mobile (max-width: 480px)
   ========================================================== */
@media (max-width: 480px) {
	.tamuk-ql {
		padding-left: var(--space-3, 0.75rem);
		padding-right: var(--space-3, 0.75rem);
	}

	/* Cards: single column */
	.tamuk-ql--cards .tamuk-ql-list {
		grid-template-columns: 1fr;
	}

	/* Underline: stack vertically */
	.tamuk-ql--underline .tamuk-ql-list {
		flex-direction: column;
		align-items: stretch;
	}

	.tamuk-ql--underline .tamuk-ql-link {
		justify-content: center;
		border-bottom: none;
		background: var(--tamuk-ql-blue-light);
		border-radius: var(--tamuk-ql-radius-md);
		padding: 0.6rem 1rem;
	}

	.tamuk-ql--underline .tamuk-ql-link:hover {
		background: var(--tamuk-ql-blue);
		color: #fff;
	}
}
