/*
 * ANCIC Resources Page
 *
 * Styles for all five resources shortcodes:
 *   .ancic-res-hero        — hero banner with statistics
 *   .ancic-res-search      — full-width search bar
 *   .ancic-res-filters     — filter bar (selects + active chips)
 *   .ancic-res-grid        — resource card grid + empty state
 *   .ancic-res-pagination  — paginator with prev/next + page numbers
 *
 * Depends on: ancic-custom.css (tokens + buttons + badges)
 *             ancic-cards.css  (.ancic-card-resource)
 */


/* =============================================================
   SHARED SECTION RHYTHM
   ============================================================= */

.ancic-res-hero,
.ancic-res-search,
.ancic-res-filters,
.ancic-res-grid,
.ancic-res-pagination {
	width: 100%;
}

.ancic-res__wrap {
	max-width: 1200px;
	margin-inline: auto;
	padding-inline: var(--sp-6, 1.5rem);
	width: 100%;
	box-sizing: border-box;
}

/*
 * FULL-BLEED ESCAPE
 *
 * When placed inside an Elementor container (or any boxed wrapper),
 * sections that need edge-to-edge backgrounds use this technique
 * to break out of the parent's max-width.
 *
 * Usage: add class  ancic-res--full-bleed  to the <section>.
 * The shortcodes add it automatically on the hero, search and filters.
 */
.ancic-res--full-bleed {
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	width: 100vw;
	max-width: 100vw;
}

/* When Elementor wraps the shortcode in a widget, inherit the bleed correctly */
.elementor-widget-shortcode:has(.ancic-res--full-bleed) {
	overflow: visible !important;
}

.elementor-widget-shortcode:has(.ancic-res--full-bleed),
.elementor-column:has(.ancic-res--full-bleed),
.e-con:has(.ancic-res--full-bleed) {
	overflow: visible !important;
}


/* =============================================================
   1. HERO
   ============================================================= */

.ancic-res-hero {
	background: linear-gradient(135deg, var(--ancic-blue, #00A1D7) 0%, #005f80 100%);
	padding: var(--sp-16, 4rem) 0 var(--sp-12, 3rem);
	overflow: hidden;
}

.ancic-res-hero__inner {
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: var(--sp-12, 3rem);
	align-items: center;
}

.ancic-res-hero__content {
	display: flex;
	flex-direction: column;
	gap: var(--sp-6, 1.5rem);
}

.ancic-res-hero__content .ancic-eyebrow {
	color: var(--ancic-blue-light, #cceef9);
	font-size: var(--text-xs, 0.75rem);
	font-weight: 700;
	letter-spacing: var(--tracking-widest, 0.1em);
	text-transform: uppercase;
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
}

.ancic-res-hero__title {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	font-weight: 800;
	line-height: var(--leading-tight, 1.2);
	letter-spacing: var(--tracking-tight, -0.025em);
	color: var(--ancic-white, #fff);
	margin: 0;
}

.ancic-res-hero__lead {
	font-family: var(--font-body, Georgia, serif);
	font-size: var(--text-lg, 1.125rem);
	line-height: var(--leading-relaxed, 1.75);
	color: rgba(255, 255, 255, 0.82);
	margin: 0;
	max-width: 52ch;
}

.ancic-res-hero__stats {
	display: flex;
	gap: var(--sp-8, 2rem);
	padding-top: var(--sp-4, 1rem);
	border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.ancic-res-hero__stat {
	display: flex;
	flex-direction: column;
	gap: var(--sp-1, 0.25rem);
}

.ancic-res-hero__stat-number {
	font-family: var(--font-ui);
	font-size: var(--text-2xl, 1.5rem);
	font-weight: 800;
	color: var(--ancic-white, #fff);
	letter-spacing: var(--tracking-tight);
	line-height: 1;
}

.ancic-res-hero__stat-label {
	font-family: var(--font-ui);
	font-size: var(--text-xs, 0.75rem);
	color: rgba(255, 255, 255, 0.65);
	letter-spacing: var(--tracking-wide);
}

.ancic-res-hero__visual {
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0.9;
}

.ancic-res-hero__visual svg {
	width: 100%;
	max-width: 380px;
	height: auto;
	border-radius: var(--r-xl, 16px);
	filter: drop-shadow(0 8px 32px rgba(0,0,0,.2));
}


/* =============================================================
   2. SEARCH BAR
   ============================================================= */

.ancic-res-search {
	background-color: var(--ancic-surface, #f5f5f7);
	border-bottom: 1px solid var(--ancic-rule, #e5e5ea);
	padding: var(--sp-6, 1.5rem) 0;
}

.ancic-res-search__form {
	width: 100%;
}

.ancic-res-search__bar {
	display: flex;
	align-items: center;
	background-color: var(--ancic-white, #fff);
	border: 1px solid var(--ancic-rule, #e5e5ea);
	border-radius: var(--r-xl, 16px);
	padding: var(--sp-2, 0.5rem) var(--sp-2, 0.5rem) var(--sp-2, 0.5rem) var(--sp-5, 1.25rem);
	gap: var(--sp-3, 0.75rem);
	box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,.07));
	transition: box-shadow var(--dur-base, 220ms) var(--ease-out), border-color var(--dur-base, 220ms);
}

.ancic-res-search__bar:focus-within {
	border-color: var(--ancic-blue, #00A1D7);
	box-shadow: 0 0 0 3px rgba(0, 161, 215, 0.15), var(--shadow-sm);
}

.ancic-res-search__icon {
	flex-shrink: 0;
	color: var(--ancic-ink-faint, #8e8e93);
	transition: color var(--dur-fast, 120ms);
}

.ancic-res-search__bar:focus-within .ancic-res-search__icon {
	color: var(--ancic-blue, #00A1D7);
}

.ancic-res-search__input {
	flex: 1;
	border: 0;
	outline: 0;
	background: transparent;
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: var(--text-base, 1rem);
	color: var(--ancic-ink, #1c1c1e);
	line-height: 1.5;
	padding: var(--sp-2, 0.5rem) 0;
	min-width: 0;
}

.ancic-res-search__input::placeholder {
	color: var(--ancic-ink-faint, #8e8e93);
}

.ancic-res-search__input::-webkit-search-cancel-button {
	display: none;
}

.ancic-res-search__clear {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border: 0;
	background: transparent;
	color: var(--ancic-ink-faint, #8e8e93);
	cursor: pointer;
	border-radius: var(--r-md, 6px);
	padding: 0;
	transition: color var(--dur-fast), background-color var(--dur-fast);
}

.ancic-res-search__clear:hover {
	color: var(--ancic-ink-mid, #3a3a3c);
	background-color: var(--ancic-surface, #f5f5f7);
}

.ancic-res-search__submit {
	flex-shrink: 0;
	white-space: nowrap;
}


/* =============================================================
   3. FILTER BAR
   ============================================================= */

.ancic-res-filters {
	background-color: var(--ancic-white, #fff);
	border-bottom: 1px solid var(--ancic-rule, #e5e5ea);
	padding: var(--sp-5, 1.25rem) 0;
}

.ancic-res-filters__inner {
	display: flex;
	align-items: flex-end;
	gap: var(--sp-4, 1rem);
	flex-wrap: wrap;
}

.ancic-res-filters__groups {
	display: flex;
	gap: var(--sp-4, 1rem);
	flex-wrap: wrap;
	flex: 1;
	min-width: 0;
}

.ancic-res-filters__group {
	display: flex;
	flex-direction: column;
	gap: var(--sp-1, 0.25rem);
	min-width: 180px;
	flex: 1;
}

.ancic-res-filters__group-label {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: var(--text-xs, 0.75rem);
	font-weight: 700;
	color: var(--ancic-ink-light, #636366);
	letter-spacing: var(--tracking-wide, 0.03em);
	text-transform: uppercase;
}

.ancic-res-filters__select-wrap {
	position: relative;
}

.ancic-res-filters__select {
	appearance: none;
	-webkit-appearance: none;
	width: 100%;
	padding: var(--sp-3, 0.75rem) var(--sp-8, 2rem) var(--sp-3, 0.75rem) var(--sp-4, 1rem);
	border: 1px solid var(--ancic-rule, #e5e5ea);
	border-radius: var(--r-lg, 10px);
	background-color: var(--ancic-surface, #f5f5f7);
	font-family: var(--font-ui);
	font-size: var(--text-sm, 0.875rem);
	color: var(--ancic-ink-mid, #3a3a3c);
	cursor: pointer;
	line-height: 1.4;
	transition:
		border-color var(--dur-base, 220ms),
		box-shadow var(--dur-base, 220ms),
		background-color var(--dur-base, 220ms);
}

.ancic-res-filters__select:focus {
	outline: 0;
	border-color: var(--ancic-blue, #00A1D7);
	box-shadow: 0 0 0 3px rgba(0, 161, 215, 0.15);
	background-color: var(--ancic-white, #fff);
}

.ancic-res-filters__select:hover {
	border-color: var(--ancic-blue-light, #d6e4f0);
}

.ancic-res-filters__select-caret {
	position: absolute;
	right: var(--sp-3, 0.75rem);
	top: 50%;
	transform: translateY(-50%);
	pointer-events: none;
	color: var(--ancic-ink-faint, #8e8e93);
}

.ancic-res-filters__reset {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2, 0.5rem);
	font-family: var(--font-ui);
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--ancic-ink-light, #636366);
	text-decoration: none;
	padding: var(--sp-3, 0.75rem) var(--sp-4, 1rem);
	border: 1px solid var(--ancic-rule, #e5e5ea);
	border-radius: var(--r-lg, 10px);
	background-color: var(--ancic-surface, #f5f5f7);
	white-space: nowrap;
	transition:
		color var(--dur-fast),
		border-color var(--dur-fast),
		background-color var(--dur-fast);
	align-self: flex-end;
}

.ancic-res-filters__reset:hover {
	color: var(--ancic-danger, #991b1b);
	border-color: var(--ancic-danger, #991b1b);
	background-color: var(--ancic-danger-bg, #fef2f2);
}

.ancic-res-filters__active-chips {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-2, 0.5rem);
	padding-top: var(--sp-4, 1rem);
	width: 100%;
	border-top: 1px solid var(--ancic-rule, #e5e5ea);
	margin-top: var(--sp-1, 0.25rem);
}

.ancic-res-filters__active-label {
	font-family: var(--font-ui);
	font-size: var(--text-xs, 0.75rem);
	font-weight: 700;
	color: var(--ancic-ink-faint, #8e8e93);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	margin-right: var(--sp-1, 0.25rem);
}

.ancic-res-filters__chip {
	display: inline-flex;
	align-items: center;
	font-family: var(--font-ui);
	font-size: var(--text-xs, 0.75rem);
	font-weight: 600;
	color: var(--ancic-blue, #1a3a5c);
	background-color: var(--ancic-blue-faint, #f0f5fa);
	border: 1px solid var(--ancic-blue-light, #d6e4f0);
	border-radius: var(--r-pill, 9999px);
	padding: 0.3em 0.85em;
	line-height: 1;
}


/* =============================================================
   4. RESOURCE GRID
   ============================================================= */

.ancic-res-grid {
	background-color: var(--ancic-white, #fff);
	padding: var(--sp-8, 2rem) 0 var(--sp-12, 3rem);
}

.ancic-res-grid__meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--sp-6, 1.5rem);
	padding-bottom: var(--sp-4, 1rem);
	border-bottom: 1px solid var(--ancic-rule, #e5e5ea);
}

.ancic-res-grid__count {
	font-family: var(--font-ui);
	font-size: var(--text-sm, 0.875rem);
	color: var(--ancic-ink-light, #636366);
	margin: 0;
}

.ancic-res-grid__count strong {
	color: var(--ancic-ink, #1c1c1e);
}

/* Grid layout */
.ancic-res-grid__list {
	display: grid;
	gap: var(--sp-5, 1.25rem);
}

.ancic-res-grid__list--cols-1 {
	grid-template-columns: 1fr;
}

.ancic-res-grid__list--cols-2 {
	grid-template-columns: repeat(2, 1fr);
}

.ancic-res-grid__list--cols-3 {
	grid-template-columns: repeat(3, 1fr);
}

.ancic-res-grid__list--cols-4 {
	grid-template-columns: repeat(4, 1fr);
}

/* For 3-col grids, force resource cards to stack vertically */
.ancic-res-grid__list--cols-3 .ancic-card-resource,
.ancic-res-grid__list--cols-4 .ancic-card-resource {
	flex-direction: column;
}

.ancic-res-grid__list--cols-3 .ancic-card-resource .ancic-card-resource__icon,
.ancic-res-grid__list--cols-4 .ancic-card-resource .ancic-card-resource__icon {
	width: auto;
	padding: var(--sp-5, 1.25rem) var(--sp-5, 1.25rem) 0;
	align-items: flex-start;
	justify-content: flex-start;
}

.ancic-res-grid__list--cols-3 .ancic-card-resource .ancic-card-resource__body,
.ancic-res-grid__list--cols-4 .ancic-card-resource .ancic-card-resource__body {
	padding-top: var(--sp-4, 1rem);
}

/* Empty state */
.ancic-res-grid__empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--sp-4, 1rem);
	padding: var(--sp-16, 4rem) var(--sp-6, 1.5rem);
	background-color: var(--ancic-surface, #f5f5f7);
	border-radius: var(--r-xl, 16px);
	border: 1px dashed var(--ancic-rule, #e5e5ea);
}

.ancic-res-grid__empty-icon {
	color: var(--ancic-ink-faint, #8e8e93);
}

.ancic-res-grid__empty-title {
	font-family: var(--font-ui);
	font-size: var(--text-xl, 1.25rem);
	font-weight: 700;
	color: var(--ancic-ink-mid, #3a3a3c);
	margin: 0;
}

.ancic-res-grid__empty-desc {
	font-family: var(--font-body, Georgia, serif);
	font-size: var(--text-base, 1rem);
	color: var(--ancic-ink-light, #636366);
	margin: 0;
	max-width: 40ch;
}


/* =============================================================
   5. PAGINATION
   ============================================================= */

.ancic-res-pagination {
	background-color: var(--ancic-surface, #f5f5f7);
	border-top: 1px solid var(--ancic-rule, #e5e5ea);
	padding: var(--sp-8, 2rem) 0;
}

.ancic-res-pagination__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--sp-2, 0.5rem);
	flex-wrap: wrap;
}

.ancic-res-pagination__prev,
.ancic-res-pagination__next {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2, 0.5rem);
	font-family: var(--font-ui);
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--ancic-blue, #1a3a5c);
	text-decoration: none;
	padding: var(--sp-2, 0.5rem) var(--sp-4, 1rem);
	border: 1px solid var(--ancic-rule, #e5e5ea);
	border-radius: var(--r-lg, 10px);
	background-color: var(--ancic-white, #fff);
	transition:
		color var(--dur-fast, 120ms),
		border-color var(--dur-fast),
		background-color var(--dur-fast),
		box-shadow var(--dur-fast);
}

.ancic-res-pagination__prev:hover,
.ancic-res-pagination__next:hover {
	color: var(--ancic-blue, #00A1D7);
	border-color: var(--ancic-blue-light, #cceef9);
	background-color: var(--ancic-blue-faint, #e8f7fd);
}

.ancic-res-pagination__prev--disabled,
.ancic-res-pagination__next--disabled {
	color: var(--ancic-ink-faint, #8e8e93);
	cursor: default;
	pointer-events: none;
	background-color: transparent;
}

.ancic-res-pagination__pages {
	display: flex;
	align-items: center;
	gap: var(--sp-1, 0.25rem);
}

.ancic-res-pagination__page {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 var(--sp-2, 0.5rem);
	border: 1px solid var(--ancic-rule, #e5e5ea);
	border-radius: var(--r-lg, 10px);
	background-color: var(--ancic-white, #fff);
	font-family: var(--font-ui);
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--ancic-ink-mid, #3a3a3c);
	text-decoration: none;
	transition:
		color var(--dur-fast),
		border-color var(--dur-fast),
		background-color var(--dur-fast);
}

.ancic-res-pagination__page:hover {
	color: var(--ancic-blue, #1a3a5c);
	border-color: var(--ancic-blue-light, #d6e4f0);
	background-color: var(--ancic-blue-faint, #f0f5fa);
}

.ancic-res-pagination__page--current {
	color: var(--ancic-white, #fff);
	background-color: var(--ancic-blue, #1a3a5c);
	border-color: var(--ancic-blue, #1a3a5c);
	cursor: default;
	pointer-events: none;
}

.ancic-res-pagination__ellipsis {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ancic-ink-faint, #8e8e93);
	letter-spacing: 0.05em;
}

.ancic-res-pagination__summary {
	text-align: center;
	font-family: var(--font-ui);
	font-size: var(--text-xs, 0.75rem);
	color: var(--ancic-ink-faint, #8e8e93);
	margin: var(--sp-4, 1rem) 0 0;
}

.ancic-res-pagination__summary strong {
	color: var(--ancic-ink-mid, #3a3a3c);
}


/* =============================================================
   RESPONSIVE
   ============================================================= */

@media screen and (max-width: 1024px) {
	.ancic-res-hero__inner {
		grid-template-columns: 1fr;
	}

	.ancic-res-hero__visual {
		display: none;
	}

	.ancic-res-hero__stats {
		gap: var(--sp-6, 1.5rem);
	}

	.ancic-res-grid__list--cols-3 {
		grid-template-columns: repeat(2, 1fr);
	}

	.ancic-res-grid__list--cols-4 {
		grid-template-columns: repeat(2, 1fr);
	}

	.ancic-res-filters__group {
		min-width: 150px;
	}
}

@media screen and (max-width: 719px) {
	.ancic-res-hero {
		padding: var(--sp-10, 2.5rem) 0 var(--sp-8, 2rem);
	}

	.ancic-res-hero__stats {
		flex-wrap: wrap;
		gap: var(--sp-5, 1.25rem);
	}

	.ancic-res-search__bar {
		flex-wrap: wrap;
		gap: var(--sp-2, 0.5rem);
		border-radius: var(--r-lg, 10px);
	}

	.ancic-res-search__submit {
		width: 100%;
		justify-content: center;
	}

	.ancic-res-filters__inner {
		flex-direction: column;
		align-items: stretch;
	}

	.ancic-res-filters__groups {
		flex-direction: column;
	}

	.ancic-res-filters__group {
		min-width: 0;
		flex: none;
		width: 100%;
	}

	.ancic-res-filters__reset {
		align-self: flex-start;
	}

	.ancic-res-grid__list--cols-2,
	.ancic-res-grid__list--cols-3,
	.ancic-res-grid__list--cols-4 {
		grid-template-columns: 1fr;
	}

	.ancic-res-pagination__inner {
		gap: var(--sp-1, 0.25rem);
	}

	.ancic-res-pagination__prev span:not([class]),
	.ancic-res-pagination__next span:not([class]) {
		display: none;
	}
}


/* =============================================================
   ELEMENTOR COMPATIBILITY
   ============================================================= */

.elementor-widget-shortcode .ancic-res-hero,
.elementor-widget-shortcode .ancic-res-search,
.elementor-widget-shortcode .ancic-res-filters,
.elementor-widget-shortcode .ancic-res-grid,
.elementor-widget-shortcode .ancic-res-pagination {
	width: 100%;
}

.elementor-editor-active .ancic-res-filters__select {
	pointer-events: none;
}


/* =============================================================
   REDUCED MOTION
   ============================================================= */

@media (prefers-reduced-motion: reduce) {
	.ancic-res-search__bar,
	.ancic-res-filters__select,
	.ancic-res-pagination__page,
	.ancic-res-pagination__prev,
	.ancic-res-pagination__next {
		transition: none;
	}
}
