/* ════════════════════════════════════════════════════════════════════
   BioCode — Courses Archive (/courses/)
   "Field-guide editorial" — a light, warm, botanical-science catalogue.
     · Warm bone paper, ink-black text, deep botanical green accent.
     · Newsreader serif for display + card titles; Hanken Grotesk body.
     · Asymmetric light hero w/ a catalogue index-card.
     · Tutor's left filter sidebar is flattened into a horizontal pill
       toolbar (checkbox → pill via :has()), grid goes full-width 3-up.
     · Membership pitch becomes an inverted green closing band.
   Scoped to .ca-* + .course-archive-page. Loaded only here (functions.php).
   ════════════════════════════════════════════════════════════════════ */

:root {
	--g-deep:   #154d37;
	--g:        #1d6b4f;
	--g-soft:   #2f8a67;
	--g-tint:   #eef4ef;
	--clay:     #bd6a36;

	--ink:      #1a1c16;
	--ink-2:    #33372c;
	--muted:    #6a6f60;
	--faint:    #9a9e8d;

	--bone:     #f6f2e9;
	--paper:    #fffdf8;
	--cream:    #f3eee2;
	--line:     #e6e0d2;
	--line-2:   #efeadd;

	--serif:    "Newsreader", Georgia, "Times New Roman", serif;
	--sans:     "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

	--r-sm:     10px;
	--r:        16px;
	--r-lg:     22px;
	--sh-sm:    0 1px 2px rgba(26,28,22,.05);
	--sh-md:    0 8px 26px rgba(26,28,22,.07), 0 2px 8px rgba(26,28,22,.05);
	--sh-lg:    0 30px 64px rgba(21,77,55,.16), 0 10px 26px rgba(26,28,22,.08);
	--ease:     cubic-bezier(.22,.61,.36,1);
	--tr:       .3s var(--ease);
}

/* Page field */
.post-type-archive-courses,
.tax-course-category,
.tax-course-tag {
	background: var(--bone);
	font-family: var(--sans);
}

.ca-wrap {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 28px;
	width: 100%;
	box-sizing: border-box;
}
.ca-hero,
.ca-band {
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
}

/* ─── Buttons ─────────────────────────────────────────────────────────── */
.ca-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sans);
	font-weight: 600;
	font-size: .98rem;
	line-height: 1;
	text-decoration: none;
	padding: 14px 24px;
	border-radius: var(--r-sm);
	border: 1px solid transparent;
	cursor: pointer;
	transition: transform var(--tr), background var(--tr), color var(--tr), border-color var(--tr);
}
.ca-btn-primary { background: var(--g); color: #fff !important; box-shadow: 0 10px 26px rgba(29,107,79,.22); }
.ca-btn-primary:hover { background: var(--g-deep); transform: translateY(-2px); color: #fff !important; }
.ca-btn-ghost { background: transparent; color: var(--ink) !important; border-color: rgba(26,28,22,.22); }
.ca-btn-ghost:hover { border-color: var(--g); color: var(--g) !important; }
.ca-btn-onlight { background: var(--cream); color: var(--g-deep) !important; }
.ca-btn-onlight:hover { background: #fff; transform: translateY(-2px); color: var(--g-deep) !important; }

/* ─────────────────────────────────────────────────────────────────────
   HERO — light, asymmetric
   ───────────────────────────────────────────────────────────────────── */
.ca-hero {
	background: var(--bone);
	border-bottom: 1px solid var(--line);
	padding: 68px 0 52px;
	overflow: hidden;
}
.ca-hero-tex {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(29,107,79,.13) 1.1px, transparent 1.1px);
	background-size: 22px 22px;
	-webkit-mask-image: radial-gradient(100% 80% at 80% 0%, #000, transparent 72%);
	        mask-image: radial-gradient(100% 80% at 80% 0%, #000, transparent 72%);
	opacity: .7;
	pointer-events: none;
}
.ca-hero-inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1.55fr .9fr;
	gap: 56px;
	align-items: center;
}
.ca-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	font-size: .8rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--g);
	margin-bottom: 22px;
}
.ca-eyebrow-dot {
	width: 7px; height: 7px; border-radius: 50%;
	background: var(--clay);
	box-shadow: 0 0 0 4px rgba(189,106,54,.16);
}
.ca-hero-title {
	font-family: var(--serif);
	font-size: clamp(2.5rem, 5.2vw, 4rem);
	font-weight: 500;
	line-height: 1.04;
	letter-spacing: -0.02em;
	color: var(--ink);
	margin: 0 0 22px;
}
.ca-hero-title em {
	font-style: italic;
	font-weight: 500;
	color: var(--g);
}
.ca-hero-sub {
	max-width: 560px;
	font-size: clamp(1.04rem, 1.5vw, 1.18rem);
	line-height: 1.64;
	color: var(--muted);
	margin: 0 0 32px;
}
.ca-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; }

/* Catalogue index-card */
.ca-indexcard {
	position: relative;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	box-shadow: var(--sh-md);
	padding: 30px 30px 12px;
	margin-top: 14px;
}
.ca-indexcard-tab {
	position: absolute;
	top: -14px; left: 28px;
	font-family: var(--serif);
	font-style: italic;
	font-size: .92rem;
	color: #fff;
	background: var(--g);
	padding: 5px 16px;
	border-radius: 999px;
	box-shadow: 0 8px 18px rgba(29,107,79,.26);
}
.ca-stats {
	list-style: none;
	margin: 0; padding: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
}
.ca-stat {
	padding: 18px 6px;
	border-bottom: 1px solid var(--line-2);
}
.ca-stat:nth-child(odd) { border-right: 1px solid var(--line-2); padding-right: 18px; }
.ca-stat:nth-child(even) { padding-left: 18px; }
.ca-stat-num {
	display: block;
	font-family: var(--serif);
	font-size: 2.3rem;
	font-weight: 600;
	line-height: 1;
	color: var(--g-deep);
	margin-bottom: 7px;
	letter-spacing: -0.01em;
}
.ca-stat-lbl {
	font-size: .72rem;
	font-weight: 600;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--faint);
}

/* ─────────────────────────────────────────────────────────────────────
   CATALOGUE HEAD
   ───────────────────────────────────────────────────────────────────── */
.ca-grid-wrap { padding-top: 34px; padding-bottom: 24px; }
.ca-catalog-head { margin-bottom: 20px; }
.ca-catalog-title {
	font-family: var(--serif);
	font-size: clamp(1.7rem, 2.6vw, 2.2rem);
	font-weight: 500;
	letter-spacing: -0.015em;
	color: var(--ink);
	margin: 0 0 6px;
}
.ca-catalog-note { font-size: 1rem; color: var(--muted); margin: 0; }

.ca-grid-wrap .tutor-courses-wrap.tutor-container {
	padding-left: 0;
	padding-right: 0;
	max-width: 100%;
}
/* ─────────────────────────────────────────────────────────────────────
   FILTER
   · Desktop (≥1200px): flatten Tutor's sidebar into a horizontal pill toolbar.
   · Mobile  (<1200px): keep Tutor's native off-canvas DRAWER (a real popup),
     surfaced by a restyled "Filter by topic" button.
   Pill / search / title / clear / sort styling is shared by both modes.
   ───────────────────────────────────────────────────────────────────── */

/* ---- shared styling (applies in toolbar AND drawer) ---- */
.ca-grid-wrap .tutor-course-filter-container .tutor-widget-title {
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--faint);
	margin: 0 0 12px;
}
.ca-grid-wrap .tutor-widget-search .tutor-form-wrap { position: relative; display: block; }
/* Keep Tutor's centred 40px icon box (left:0) — only recolor it.
   (Re-positioning it while Tutor keeps width:40px is what caused the overlap.) */
.ca-grid-wrap .tutor-widget-search .tutor-form-icon { color: var(--faint); }
/* Tutor sets padding/border/radius on .tutor-form-control with !important,
   so our pill styling must use !important too. 44px clears the icon. */
.ca-grid-wrap .tutor-widget-search input[name="keyword"] {
	width: 100%;
	border: 1px solid var(--line) !important;
	border-radius: 999px !important;
	padding: 11px 18px 11px 44px !important;
	background: var(--bone) !important;
	font-family: var(--sans);
	font-size: .92rem !important;
	transition: border-color var(--tr), background var(--tr);
}
.ca-grid-wrap .tutor-widget-search input[name="keyword"]:focus {
	outline: none;
	border-color: var(--g) !important;
	background: #fff !important;
}
/* checkbox lists → pill rows */
.ca-grid-wrap .tutor-course-filter-container .tutor-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0; padding: 0;
	list-style: none;
}
.ca-grid-wrap .tutor-course-filter-container .tutor-list-item { margin: 0 !important; list-style: none; }
.ca-grid-wrap .tutor-course-filter-container .tutor-list-item label {
	display: inline-flex;
	align-items: center;
	cursor: pointer;
	font-family: var(--sans);
	font-size: .85rem;
	font-weight: 500;
	line-height: 1;
	color: var(--ink-2);
	background: var(--bone);
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 9px 15px;
	transition: all var(--tr);
}
.ca-grid-wrap .tutor-course-filter-container .tutor-list-item .tutor-form-check-input {
	position: absolute;
	opacity: 0;
	width: 0; height: 0; margin: 0;
	pointer-events: none;
}
.ca-grid-wrap .tutor-course-filter-container .tutor-list-item label:hover {
	border-color: var(--g-soft);
	color: var(--g-deep);
	background: var(--g-tint);
}
.ca-grid-wrap .tutor-course-filter-container .tutor-list-item label:has(.tutor-form-check-input:checked) {
	background: var(--g);
	border-color: var(--g);
	color: #fff;
}
/* Clear-all link — flat text button (overrides Tutor's green-fill hover) */
.ca-grid-wrap .tutor-widget-course-filter .tutor-btn,
.ca-grid-wrap .tutor-widget-course-filter .tutor-btn:hover,
.ca-grid-wrap .tutor-widget-course-filter .tutor-btn:focus {
	background: transparent;
	border-color: transparent;
	box-shadow: none;
	font-weight: 600;
	font-size: .85rem;
	padding: 8px 6px;
}
.ca-grid-wrap .tutor-widget-course-filter .tutor-btn { color: var(--clay); }
.ca-grid-wrap .tutor-widget-course-filter .tutor-btn:hover { color: var(--g-deep); text-decoration: underline; }
/* Sort select (above grid) */
.ca-grid-wrap .tutor-col-xl-9 > div > .tutor-course-filter { text-align: left !important; margin-bottom: 12px; }
.ca-grid-wrap .tutor-col-xl-9 br { display: none; }
.ca-grid-wrap select[name="course_order"] {
	font-family: var(--sans);
	font-size: .9rem;
	color: var(--ink);
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 10px 38px 10px 16px;
	background-color: var(--paper);
}

/* ---- DESKTOP ≥1200px: in-flow horizontal pill toolbar ---- */
@media (min-width: 1200px) {
	.ca-grid-wrap .tutor-row { display: block; margin: 0; }
	.ca-grid-wrap .tutor-course-filter-container.tutor-col-3,
	.ca-grid-wrap .tutor-col-xl-9 { width: 100%; max-width: 100%; flex: none; padding: 0; }

	.ca-grid-wrap .tutor-course-filter-container {
		position: static; inset: auto; width: 100%; z-index: auto; overflow: visible;
		margin-bottom: 22px;
		background: var(--paper);
		border: 1px solid var(--line);
		border-radius: var(--r);
		box-shadow: var(--sh-sm);
		padding: 20px 24px;
	}
	.ca-grid-wrap .tutor-course-filter-container .tutor-course-filter { background: transparent; padding: 0; }
	.ca-grid-wrap .tutor-course-filter-form {
		display: flex; flex-wrap: wrap; align-items: flex-start; gap: 18px 24px;
	}
	.ca-grid-wrap .tutor-course-filter-container .tutor-widget { margin: 0 !important; }
	/* Row 1: search GROWS to fill, then type + clear sit to its right (no gap).
	   Row 2: full-width category pills. */
	.ca-grid-wrap .tutor-widget-search { flex: 1 1 auto; min-width: 260px; order: 0; }
	.ca-grid-wrap .tutor-widget-course-price { flex: 0 0 auto; order: 1; }
	.ca-grid-wrap .tutor-widget-course-filter { flex: 0 0 auto; order: 2; align-self: flex-end; }
	.ca-grid-wrap .tutor-widget-course-categories { flex: 1 1 100%; order: 3; }

	/* native mobile chrome stays hidden at desktop (belt-and-braces) */
	.ca-grid-wrap [tutor-toggle-course-filter],
	.ca-grid-wrap .tutor-courses-wrap > .tutor-d-xl-none { display: none !important; }
}

/* ---- MOBILE <1200px: native off-canvas drawer + "Filter by topic" button ---- */
@media (max-width: 1199px) {
	.ca-grid-wrap .tutor-courses-wrap > .tutor-d-xl-none { display: block !important; margin: 0 0 4px; }
	.ca-grid-wrap .tutor-courses-wrap > .tutor-d-xl-none .tutor-d-flex { justify-content: flex-start; }
	.ca-grid-wrap .tutor-courses-wrap > .tutor-d-xl-none .tutor-fs-3 { display: none; }
	.ca-grid-wrap a[tutor-toggle-course-filter] {
		display: inline-flex; align-items: center; gap: 9px;
		width: auto; height: auto;
		background: var(--g); color: #fff !important;
		border: 0; border-radius: 999px; padding: 12px 20px;
		font-family: var(--sans); font-weight: 600; font-size: .95rem;
		box-shadow: 0 10px 26px rgba(29,107,79,.22);
	}
	.ca-grid-wrap a[tutor-toggle-course-filter]::after { content: "Filter by topic"; }

	/* drawer panel — Tutor positions it fixed; refine the inside */
	.ca-grid-wrap .tutor-course-filter-container { width: min(360px, 88vw) !important; }
	.ca-grid-wrap .tutor-course-filter-container .tutor-course-filter-form { display: block; }
	.ca-grid-wrap .tutor-course-filter-container .tutor-widget { margin: 0 0 28px !important; }
	.ca-grid-wrap .tutor-course-filter-container .tutor-widget-search input[name="keyword"] { background: #fff; }
}

/* ─────────────────────────────────────────────────────────────────────
   GRID — full-width, 3-up, editorial cards
   ───────────────────────────────────────────────────────────────────── */
.ca-grid-wrap .tutor-course-list.tutor-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 26px;
}

.course-archive-page .tutor-course-card,
.ca-grid-wrap .tutor-card.tutor-course-card {
	position: relative;
	display: flex;
	flex-direction: column;
	height: 100%;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	overflow: hidden;
	background: var(--paper);
	box-shadow: var(--sh-sm);
	transition: transform var(--tr), box-shadow var(--tr), border-color var(--tr);
}
.ca-grid-wrap .tutor-card.tutor-course-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--sh-lg);
	border-color: rgba(29,107,79,.4);
}

/* Thumbnail */
.ca-grid-wrap .tutor-course-thumbnail { overflow: hidden; position: relative; }
.ca-grid-wrap .tutor-course-thumbnail::after {
	content: "";
	position: absolute; inset: 0;
	background: linear-gradient(to top, rgba(21,77,55,.16), transparent 44%);
	pointer-events: none;
}
.ca-grid-wrap .tutor-course-thumbnail img { transition: transform .6s var(--ease); }
.ca-grid-wrap .tutor-card.tutor-course-card:hover .tutor-course-thumbnail img { transform: scale(1.06); }

/* Bookmark */
.ca-grid-wrap .tutor-course-bookmark { position: absolute; top: 13px; right: 13px; z-index: 2; }
.ca-grid-wrap .tutor-course-bookmark .tutor-iconic-btn {
	background: rgba(255,253,248,.94);
	backdrop-filter: blur(8px);
	border: 1px solid var(--line);
	box-shadow: var(--sh-sm);
	color: var(--ink);
	transition: all var(--tr);
}
.ca-grid-wrap .tutor-course-bookmark .tutor-iconic-btn:hover { color: var(--g); transform: scale(1.08); }

/* Body */
.ca-grid-wrap .tutor-card-body {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	padding: 20px 22px 6px;
}

/* Rating */
.ca-grid-wrap .tutor-course-ratings { margin-bottom: 12px; }
.ca-grid-wrap .tutor-ratings-stars [class*="tutor-icon-star"] { font-size: 15px; color: var(--clay); }
.ca-grid-wrap .tutor-ratings-average,
.ca-grid-wrap .tutor-ratings-count { font-size: .82rem; color: var(--muted); }

/* Title — editorial serif */
.ca-grid-wrap .tutor-course-name,
.ca-grid-wrap h3.tutor-course-name {
	font-family: var(--serif);
	font-size: 1.26rem;
	font-weight: 600;
	color: var(--ink);
	line-height: 1.22;
	letter-spacing: -0.01em;
	margin: 0 0 14px;
}
.ca-grid-wrap .tutor-course-name a {
	color: var(--ink);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	transition: color var(--tr);
}
.ca-grid-wrap .tutor-course-name a:hover { color: var(--g); }

/* Category chips — small-caps editorial tags */
.ca-grid-wrap .ca-card-cats { display: flex; flex-wrap: wrap; gap: 7px; margin: 0 0 16px; }
.ca-grid-wrap .ca-chip {
	display: inline-flex;
	align-items: center;
	font-family: var(--sans);
	font-size: .68rem;
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	line-height: 1;
	padding: 6px 10px;
	border-radius: 6px;
	color: var(--g-deep);
	background: var(--g-tint);
	border: 1px solid rgba(29,107,79,.16);
	text-decoration: none;
	transition: all var(--tr);
	white-space: nowrap;
}
.ca-grid-wrap a.ca-chip:hover { color: #fff; background: var(--g); border-color: var(--g); }
.ca-grid-wrap .ca-chip-more { color: var(--faint); background: var(--bone); border-color: var(--line); }

/* Meta row */
.ca-grid-wrap .ca-card-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px 18px;
	margin-top: auto;
	padding: 14px 0 0;
	border-top: 1px solid var(--line-2);
}
.ca-grid-wrap .ca-card-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: .82rem;
	font-weight: 500;
	color: var(--muted);
}
.ca-grid-wrap .ca-card-meta-item [class*="tutor-icon"] { font-size: 15px; color: var(--g); }

/* Footer */
.ca-grid-wrap .tutor-card-footer { padding: 16px 22px 20px; border-top: 0; }
.ca-grid-wrap .tutor-card-footer .price,
.ca-grid-wrap .list-item-price .price {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--ink);
}
.ca-grid-wrap .subscription-details { color: var(--faint); font-size: .8rem; font-weight: 500; }

.ca-grid-wrap .tutor-btn { border-radius: var(--r-sm); font-weight: 600; transition: all var(--tr); }
.ca-grid-wrap .tutor-btn-primary {
	background-color: var(--g);
	border-color: var(--g);
	color: #fff;
}
.ca-grid-wrap .tutor-btn-outline-primary {
	background: transparent;
	color: var(--g);
	border-color: rgba(29,107,79,.45);
}
/* Add to Cart / Enroll Course — same flat hover as Clear-All & pagination */
.ca-grid-wrap .tutor-btn-outline-primary:hover,
.ca-grid-wrap .tutor-btn-outline-primary:focus {
	background: transparent;
	border-color: var(--g);
	color: var(--g-deep);
	text-decoration: underline;
}

/* hide any stock author/avatar that might render */
.ca-grid-wrap .tutor-meta-course-by-cat,
.ca-grid-wrap .tutor-card-body .tutor-avatar { display: none !important; }

/* Pagination — centred, count above a row of number buttons */
.ca-grid-wrap .tutor-pagination {
	width: 100%;
	margin: 48px 0 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
}
.ca-grid-wrap .tutor-pagination-hints .tutor-fs-7 { font-size: .86rem; color: var(--muted); }
.ca-grid-wrap .tutor-pagination-hints .tutor-color-black { color: var(--ink); }
.ca-grid-wrap .tutor-pagination-numbers {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.ca-grid-wrap .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 13px;
	border: 1px solid var(--line);
	border-radius: var(--r-sm);
	background: var(--paper);
	color: var(--ink);
	font-family: var(--sans);
	font-weight: 600;
	text-decoration: none;
	transition: all var(--tr);
}
/* current page stays solid green w/ white text in every state */
.ca-grid-wrap .tutor-pagination-numbers .page-numbers.current,
.ca-grid-wrap .tutor-pagination-numbers .page-numbers.current:hover,
.ca-grid-wrap .tutor-pagination-numbers .page-numbers.current:focus {
	background: var(--g);
	border-color: var(--g);
	color: #fff;
	text-decoration: none;
}
/* other pages: flat hover, same treatment as Clear-All */
.ca-grid-wrap .page-numbers:not(.current):hover {
	background: transparent;
	border-color: var(--g);
	color: var(--g-deep);
	text-decoration: underline;
}

/* ─────────────────────────────────────────────────────────────────────
   MEMBERSHIP — inverted green closing band
   ───────────────────────────────────────────────────────────────────── */
.ca-band {
	background: linear-gradient(160deg, var(--g-deep) 0%, #103b2b 100%);
	color: var(--cream);
	padding: 52px 0;
	overflow: hidden;
}
.ca-band-tex {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255,255,255,.07) 1.1px, transparent 1.1px);
	background-size: 24px 24px;
	-webkit-mask-image: radial-gradient(90% 90% at 90% 100%, #000, transparent 70%);
	        mask-image: radial-gradient(90% 90% at 90% 100%, #000, transparent 70%);
	pointer-events: none;
}
.ca-band-inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1.5fr auto;
	gap: 52px;
	align-items: center;
}
.ca-band-eyebrow {
	display: inline-flex;
	align-items: center;
	font-size: .74rem;
	font-weight: 700;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: #ffd9a8;
	background: rgba(189,106,54,.22);
	border: 1px solid rgba(255,217,168,.3);
	padding: 6px 13px;
	border-radius: 999px;
	margin-bottom: 18px;
}
.ca-band-title {
	font-family: var(--serif);
	font-size: clamp(1.9rem, 3.4vw, 2.9rem);
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: #fff;
	margin: 0 0 16px;
}
.ca-band-title em { font-style: italic; color: #9fe0c0; }
.ca-band-text {
	font-size: 1.08rem;
	line-height: 1.6;
	color: #cfe3d7;
	max-width: 600px;
	margin: 0 0 22px;
}
.ca-band-text strong { color: #fff; font-weight: 600; }
.ca-band-feats {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 11px 26px;
}
.ca-band-feats li {
	position: relative;
	padding-left: 26px;
	font-size: .95rem;
	font-weight: 500;
	color: #e7f1ea;
}
.ca-band-feats li::before {
	content: "";
	position: absolute;
	left: 0; top: 0;
	width: 18px; height: 18px;
	border-radius: 50%;
	background: #9fe0c0;
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='4 12 10 18 20 6'/%3E%3C/svg%3E") center/11px no-repeat;
	        mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='4 12 10 18 20 6'/%3E%3C/svg%3E") center/11px no-repeat;
}

.ca-band-aside {
	text-align: center;
	min-width: 250px;
	background: rgba(255,255,255,.05);
	border: 1px solid rgba(255,255,255,.14);
	border-radius: var(--r-lg);
	padding: 30px 32px;
	backdrop-filter: blur(4px);
}
.ca-band-price {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 4px;
	flex-wrap: wrap;
	margin-bottom: 20px;
}
.ca-band-from {
	width: 100%;
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: #9fe0c0;
	margin-bottom: 5px;
}
.ca-band-amount {
	font-family: var(--serif);
	font-size: 3rem;
	font-weight: 600;
	line-height: 1;
	color: #fff;
	letter-spacing: -0.02em;
}
.ca-cur { font-size: 1.4rem; font-weight: 500; vertical-align: top; color: #9fe0c0; }
.ca-band-per { font-size: .95rem; color: #cfe3d7; font-weight: 500; }
.ca-band-btn { width: 100%; box-sizing: border-box; margin-top: 4px; }
.ca-band-note { font-size: .78rem; color: #a9c6b6; margin: 14px 0 0; }

/* ─────────────────────────────────────────────────────────────────────
   RESPONSIVE
   ───────────────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
	.ca-hero-inner { grid-template-columns: 1fr; gap: 38px; }
	.ca-indexcard { max-width: 460px; }
	.ca-grid-wrap .tutor-course-list.tutor-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.ca-band-inner { grid-template-columns: 1fr; gap: 30px; }
	.ca-band-aside { justify-self: start; min-width: 280px; }
}
@media (max-width: 620px) {
	.ca-hero { padding: 56px 0 52px; }
	.ca-band { padding: 54px 0; }
	.ca-grid-wrap .tutor-course-list.tutor-grid { grid-template-columns: minmax(0, 1fr); }
	.ca-hero-actions .ca-btn { flex: 1 1 100%; }
	.ca-band-feats { flex-direction: column; gap: 10px; }
	/* Keep the category pill row tidy on phones */
	.ca-grid-wrap .tutor-course-filter-container .tutor-list-item label { font-size: .82rem; padding: 8px 13px; }
}

/* ════════════════════════════════════════════════════════════════════
   DISCOVERY SECTIONS — finder · featured rail · social proof · FAQ
   ════════════════════════════════════════════════════════════════════ */

/* Full-bleed bands */
.ca-feat,
.ca-proof {
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
}

/* Shared section heading */
.ca-section-head { text-align: center; max-width: 680px; margin: 0 auto 30px; }
.ca-section-head-left { text-align: left; margin: 0; }
.ca-kicker {
	display: inline-block;
	font-size: .76rem;
	font-weight: 700;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--g);
	margin-bottom: 12px;
}
.ca-section-title {
	font-family: var(--serif);
	font-size: clamp(1.7rem, 3vw, 2.4rem);
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--ink);
	margin: 0;
}
.ca-section-title em { font-style: italic; color: var(--g); }
.ca-section-sub { font-size: 1.05rem; color: var(--muted); margin: 12px 0 0; }

/* ─── FINDER ─── */
.ca-finder { padding: 48px 0 4px; }
.ca-finder-card {
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	box-shadow: var(--sh-md);
	overflow: hidden;
}
.ca-finder-tabs {
	display: flex;
	gap: 4px;
	padding: 8px 8px 0;
	border-bottom: 1px solid var(--line);
	background: var(--cream);
}
.ca-tab {
	appearance: none;
	border: 0;
	background: transparent;
	font-family: var(--sans);
	font-size: .95rem;
	font-weight: 600;
	color: var(--muted);
	padding: 14px 20px;
	cursor: pointer;
	border-radius: 10px 10px 0 0;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	transition: all var(--tr);
}
.ca-tab:hover { color: var(--g-deep); }
.ca-tab.is-active {
	background: var(--paper);
	color: var(--g-deep);
	border-bottom-color: var(--g);
}
.ca-panel { padding: 30px 32px 34px; }
.ca-panel[hidden] { display: none; }

/* Quiz */
.ca-q { margin-bottom: 22px; }
.ca-q-label {
	display: block;
	font-size: .95rem;
	font-weight: 600;
	color: var(--ink);
	margin-bottom: 12px;
}
.ca-q-label b {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px; height: 22px;
	margin-right: 10px;
	font-size: .78rem;
	color: #fff;
	background: var(--g);
	border-radius: 50%;
}
.ca-q-opts { display: flex; flex-wrap: wrap; gap: 9px; }
.ca-opt {
	appearance: none;
	font-family: var(--sans);
	font-size: .9rem;
	font-weight: 500;
	color: var(--ink-2);
	background: var(--bone);
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 10px 17px;
	cursor: pointer;
	transition: all var(--tr);
}
.ca-opt:hover { border-color: var(--g-soft); color: var(--g-deep); background: var(--g-tint); }
.ca-opt.is-active { background: var(--g); border-color: var(--g); color: #fff; }

.ca-quiz-actions { display: flex; align-items: center; gap: 16px; margin-top: 26px; }
.ca-quiz-reset {
	appearance: none; border: 0; background: transparent;
	font-family: var(--sans); font-weight: 600; font-size: .9rem;
	color: var(--clay); cursor: pointer; padding: 8px 4px;
}
.ca-quiz-reset:hover { color: var(--g-deep); text-decoration: underline; }

.ca-quiz-result { margin-top: 24px; }
.ca-quiz-result[hidden] { display: none; }
.ca-result-card {
	background: var(--g-tint);
	border: 1px solid rgba(29,107,79,.18);
	border-radius: var(--r);
	padding: 26px 28px;
}
.ca-result-kicker {
	display: block;
	font-size: .74rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
	color: var(--g); margin-bottom: 8px;
}
.ca-result-lead { font-family: var(--serif); font-size: 1.5rem; color: var(--ink); margin: 0 0 18px; }
.ca-result-lead strong { color: var(--g-deep); font-weight: 600; }
.ca-result-count { font-family: var(--sans); font-size: .9rem; color: var(--muted); font-weight: 500; }
.ca-result-refine {
	display: flex; flex-wrap: wrap; align-items: center; gap: 9px;
	margin-top: 18px; padding-top: 16px; border-top: 1px solid rgba(29,107,79,.16);
}
.ca-result-refine > span { font-size: .85rem; font-weight: 600; color: var(--muted); }
.ca-rchip {
	font-size: .82rem; font-weight: 600; color: var(--g-deep);
	background: var(--paper); border: 1px solid rgba(29,107,79,.22);
	border-radius: 999px; padding: 7px 13px; text-decoration: none; transition: all var(--tr);
}
.ca-rchip:hover { background: var(--g); border-color: var(--g); color: #fff; }

/* Search panel — icon lives inside a relative field so it stays in the bar */
.ca-search { display: flex; gap: 12px; align-items: stretch; }
.ca-search-field { position: relative; flex: 1 1 auto; min-width: 0; }
.ca-search-ico {
	position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
	color: var(--faint); font-size: 17px; line-height: 1; pointer-events: none; z-index: 2;
}
.ca-search input[type="search"] {
	width: 100%;
	box-sizing: border-box;
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 14px 18px 14px 44px;
	font-family: var(--sans); font-size: 1rem;
	background: var(--bone);
}
.ca-search input[type="search"]:focus { outline: none; border-color: var(--g); background: #fff; }
.ca-search .ca-btn { flex: 0 0 auto; }
.ca-search-hint { font-size: .9rem; color: var(--muted); margin: 16px 0 0; }
.ca-search-hint a { color: var(--g-deep); font-weight: 600; text-decoration: none; margin-right: 4px; }
.ca-search-hint a:hover { text-decoration: underline; }

/* Browse tiles */
.ca-cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 10px; }
.ca-cat-tile {
	display: flex; flex-direction: column; gap: 3px;
	padding: 14px 16px;
	background: var(--bone);
	border: 1px solid var(--line);
	border-radius: var(--r);
	text-decoration: none;
	transition: all var(--tr);
}
.ca-cat-tile:hover {
	background: var(--paper);
	border-color: var(--g);
	transform: translateY(-3px);
	box-shadow: var(--sh-md);
}
.ca-cat-name { font-family: var(--serif); font-size: 1.02rem; font-weight: 600; line-height: 1.2; color: var(--ink); }
.ca-cat-count { font-size: .82rem; color: var(--muted); font-weight: 500; }

/* ─── FEATURED RAIL ─── */
.ca-feat {
	background: var(--paper);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	padding: 48px 0 52px;
	margin-top: 0;
}
.ca-feat-head {
	display: flex; align-items: flex-end; justify-content: space-between; gap: 20px;
	margin-bottom: 26px;
}
.ca-feat-all {
	flex: 0 0 auto;
	font-weight: 600; font-size: .95rem; color: var(--g-deep);
	text-decoration: none; white-space: nowrap;
}
.ca-feat-all:hover { color: var(--g); text-decoration: underline; }
.ca-rail.ca-grid-wrap { padding: 0; }
.ca-rail-track {
	display: flex;
	gap: 22px;
	overflow-x: auto;
	padding: 14px max(28px, calc((100vw - 1240px) / 2 + 28px)) 28px;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}
.ca-rail-track > .tutor-card.tutor-course-card {
	flex: 0 0 330px;
	max-width: 330px;
	scroll-snap-align: start;
}

/* ─── SOCIAL PROOF BAND ─── */
.ca-proof {
	background: linear-gradient(160deg, var(--g) 0%, var(--g-deep) 100%);
	color: #fff;
	padding: 52px 0;
	margin-top: 0;
	overflow: hidden;
}
.ca-proof-tex {
	position: absolute; inset: 0;
	background-image: radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px);
	background-size: 22px 22px;
	-webkit-mask-image: radial-gradient(80% 80% at 15% 50%, #000, transparent 75%);
	        mask-image: radial-gradient(80% 80% at 15% 50%, #000, transparent 75%);
	pointer-events: none;
}
.ca-proof-inner {
	position: relative; z-index: 1;
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
	text-align: center;
}
.ca-proof-item { display: flex; flex-direction: column; gap: 8px; }
.ca-proof-num {
	font-family: var(--serif);
	font-size: clamp(2rem, 3.6vw, 2.9rem);
	font-weight: 600; line-height: 1; color: #fff; letter-spacing: -0.01em;
}
.ca-proof-star { color: #ffd9a8; margin-left: 2px; }
.ca-proof-lbl {
	font-size: .8rem; font-weight: 600; letter-spacing: .08em;
	text-transform: uppercase; color: #bfe0cf;
}

/* ─── FAQ ─── */
.ca-faq { padding: 52px 0 64px; }
.ca-faq-list { max-width: 820px; margin: 6px auto 0; }
.ca-faq-item {
	border: 1px solid var(--line);
	border-radius: var(--r);
	background: var(--paper);
	margin-bottom: 12px;
	overflow: hidden;
}
.ca-faq-item[open] { border-color: rgba(29,107,79,.35); box-shadow: var(--sh-sm); }
.ca-faq-item summary {
	display: flex; align-items: center; justify-content: space-between; gap: 16px;
	padding: 20px 24px;
	cursor: pointer;
	list-style: none;
	font-family: var(--sans); font-size: 1.05rem; font-weight: 600; color: var(--ink);
}
.ca-faq-item summary::-webkit-details-marker { display: none; }
.ca-faq-ico { position: relative; flex: 0 0 auto; width: 18px; height: 18px; }
.ca-faq-ico::before,
.ca-faq-ico::after {
	content: ""; position: absolute; background: var(--g);
	border-radius: 2px; transition: transform var(--tr), opacity var(--tr);
}
.ca-faq-ico::before { top: 8px; left: 0; width: 18px; height: 2px; }
.ca-faq-ico::after { left: 8px; top: 0; width: 2px; height: 18px; }
.ca-faq-item[open] .ca-faq-ico::after { transform: scaleY(0); opacity: 0; }
.ca-faq-a {
	padding: 0 24px 22px;
	font-size: 1rem; line-height: 1.62; color: var(--muted);
}

/* ─── DISCOVERY RESPONSIVE ─── */
@media (max-width: 760px) {
	.ca-finder { padding: 52px 0 4px; }
	.ca-panel { padding: 24px 20px 28px; }
	.ca-cat-grid { grid-template-columns: 1fr 1fr; }
	.ca-feat-head { flex-direction: column; align-items: flex-start; gap: 10px; }
	.ca-proof-inner { grid-template-columns: 1fr 1fr; gap: 30px 16px; }
	.ca-finder-tabs { overflow-x: auto; }
	.ca-tab { white-space: nowrap; padding: 13px 15px; }
}
@media (max-width: 480px) {
	.ca-cat-grid { grid-template-columns: 1fr; }
	.ca-search { flex-direction: column; }
	.ca-search .ca-btn { width: 100%; }
}

/* ─── Collapsible finder (details / summary) ─── */
.ca-finder-d > summary { list-style: none; }
.ca-finder-d > summary::-webkit-details-marker { display: none; }
.ca-finder-d > summary::marker { content: ""; }
.ca-finder-summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	cursor: pointer;
	padding: 20px 26px;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	box-shadow: var(--sh-sm);
	transition: border-color var(--tr), box-shadow var(--tr);
}
.ca-finder-summary:hover { border-color: var(--g); box-shadow: var(--sh-md); }
.ca-finder-d[open] .ca-finder-summary { margin-bottom: 22px; }
.ca-finder-summary-main { display: flex; flex-direction: column; gap: 5px; }
.ca-finder-summary .ca-kicker { margin: 0; }
.ca-finder-summary-title {
	font-family: var(--serif);
	font-size: clamp(1.3rem, 2.4vw, 1.7rem);
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.01em;
	color: var(--ink);
}
.ca-finder-chev {
	flex: 0 0 auto;
	width: 13px; height: 13px;
	border-right: 2.5px solid var(--g);
	border-bottom: 2.5px solid var(--g);
	transform: rotate(45deg);
	transition: transform var(--tr);
}
.ca-finder-d[open] .ca-finder-chev { transform: rotate(-135deg); }
.ca-finder-sub { margin: 0 0 18px; }

/* ─── Instant in-page search results ─── */
.ca-search-results { margin-top: 14px; }
.ca-search-results:empty { display: none; }
.ca-search-result {
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding: 11px 15px;
	margin-bottom: 8px;
	border: 1px solid var(--line);
	border-radius: var(--r-sm);
	background: var(--paper);
	text-decoration: none;
	transition: all var(--tr);
}
.ca-search-result:hover { border-color: var(--g); background: var(--g-tint); transform: translateX(2px); }
.ca-sr-title { font-weight: 600; font-size: .95rem; color: var(--ink); line-height: 1.3; }
.ca-sr-cat { font-size: .78rem; color: var(--muted); }
.ca-search-empty { font-size: .92rem; color: var(--muted); margin: 4px 0 0; }

/* Hero "free courses" entry point */
.ca-hero-aside {
	margin: 16px 0 0;
	font-size: .95rem;
	color: var(--muted);
}
.ca-hero-aside a {
	color: var(--g-deep);
	font-weight: 600;
	text-decoration: none;
	border-bottom: 1px solid rgba(29,107,79,.35);
	transition: border-color var(--tr), color var(--tr);
}
.ca-hero-aside a:hover { color: var(--g); border-bottom-color: var(--g); }

/* ════════════════════════════════════════════════════════════════════
   ENHANCEMENTS — learning paths · trust strip · testimonials · sticky CTA
   ════════════════════════════════════════════════════════════════════ */

/* ─── Learning paths ─── */
.ca-paths { padding: 52px 0 8px; }
.ca-paths-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(258px, 1fr));
	gap: 20px;
	margin-top: 30px;
}
.ca-path-card {
	display: flex;
	flex-direction: column;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	box-shadow: var(--sh-sm);
	padding: 26px 24px;
	transition: transform var(--tr), box-shadow var(--tr), border-color var(--tr);
}
.ca-path-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); border-color: rgba(29,107,79,.3); }
.ca-path-label { font-size: .72rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--g); margin-bottom: 10px; }
.ca-path-title { font-family: var(--serif); font-size: 1.3rem; font-weight: 600; line-height: 1.2; color: var(--ink); margin: 0 0 8px; }
.ca-path-blurb { font-size: .92rem; line-height: 1.5; color: var(--muted); margin: 0 0 18px; }
.ca-path-steps { list-style: none; margin: 0 0 18px; padding: 0; flex: 1 1 auto; }
.ca-path-steps li { margin-bottom: 9px; }
.ca-path-steps a { display: flex; gap: 11px; align-items: flex-start; font-size: .9rem; line-height: 1.35; color: var(--ink-2); text-decoration: none; transition: color var(--tr); }
.ca-path-steps a:hover { color: var(--g); }
.ca-path-step-n {
	flex: 0 0 auto; width: 21px; height: 21px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 50%; background: var(--g-tint); color: var(--g-deep);
	font-size: .72rem; font-weight: 700; border: 1px solid rgba(29,107,79,.2);
}
.ca-path-start { margin-top: auto; font-weight: 600; font-size: .92rem; color: var(--g-deep); text-decoration: none; }
.ca-path-start:hover { color: var(--g); text-decoration: underline; }

/* ─── Trust strip ─── */
.ca-trust { padding: 36px 0; border-top: 1px solid var(--line); }
.ca-trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
.ca-trust-item { display: flex; gap: 13px; align-items: flex-start; }
.ca-trust-ico { flex: 0 0 auto; font-size: 23px; color: var(--g); margin-top: 1px; }
.ca-trust-title { font-family: var(--sans); font-size: 1rem; font-weight: 700; color: var(--ink); margin: 0 0 4px; }
.ca-trust-text { font-size: .87rem; line-height: 1.45; color: var(--muted); margin: 0; }

/* ─── Testimonials ─── */
.ca-quotes { padding: 56px 0; }
.ca-quotes-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 30px; }
.ca-quote-card {
	display: flex; flex-direction: column;
	background: var(--paper); border: 1px solid var(--line);
	border-radius: var(--r-lg); box-shadow: var(--sh-sm);
	padding: 26px 26px 24px;
}
.ca-quote-stars { color: var(--clay); letter-spacing: 2px; font-size: .95rem; margin-bottom: 12px; }
.ca-quote-body { font-family: var(--serif); font-style: italic; font-size: 1.06rem; line-height: 1.5; color: var(--ink); margin: 0 0 18px; }
.ca-quote-foot { margin-top: auto; display: flex; flex-direction: column; gap: 2px; }
.ca-quote-author { font-weight: 700; font-size: .92rem; color: var(--ink); }
.ca-quote-course { font-size: .8rem; color: var(--muted); text-decoration: none; }
.ca-quote-course:hover { color: var(--g); text-decoration: underline; }

/* ─── Sticky all-access CTA ─── */
.ca-sticky {
	position: fixed; left: 0; right: 0; bottom: 0; z-index: 9990;
	background: linear-gradient(100deg, var(--g-deep), #103b2b);
	color: #fff;
	box-shadow: 0 -10px 34px rgba(0,0,0,.20);
	transform: translateY(110%);
	transition: transform .38s var(--ease);
}
.ca-sticky.is-visible { transform: translateY(0); }
.ca-sticky-inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 12px 28px; }
.ca-sticky-text { margin: 0; font-size: .98rem; color: #e7f1ea; }
.ca-sticky-text strong { color: #fff; }
.ca-sticky-actions { display: flex; align-items: center; gap: 10px; flex: 0 0 auto; }
.ca-sticky .ca-btn-primary { box-shadow: none; padding: 11px 20px; }
.ca-sticky-close {
	appearance: none; border: 0; background: transparent; cursor: pointer;
	color: #9fe0c0; font-size: 1.5rem; line-height: 1; padding: 4px 8px; border-radius: 8px;
	transition: color var(--tr), background var(--tr);
}
.ca-sticky-close:hover { color: #fff; background: rgba(255,255,255,.08); }

/* ─── Enhancements responsive ─── */
@media (max-width: 900px) {
	.ca-trust-grid { grid-template-columns: 1fr 1fr; }
	.ca-quotes-grid { grid-template-columns: 1fr; max-width: 580px; margin-left: auto; margin-right: auto; }
}
@media (max-width: 560px) {
	.ca-trust-grid { grid-template-columns: 1fr; }
	.ca-sticky-inner { flex-direction: column; gap: 10px; padding: 12px 18px; text-align: center; }
	.ca-sticky-text { font-size: .9rem; }
}
