/**
 * Course Single — redesigned presentation.
 *
 * Fresh, self-contained stylesheet for the LearnDash course page (course.php),
 * scoped under .aws-course and loaded only on sfwd-courses, so lesson/topic/quiz
 * pages (learndash-course.css) are untouched. Uses the theme design tokens.
 */

/* LearnDash injects the course into .entry-content.is-layout-constrained, which
   caps its .learndash child at the theme content width. Let it span full width
   so the inner .container sets the max-width and the grid gets real room. */
.wp-block-post-content.is-layout-constrained > .learndash {
	max-width: none;
}

.aws-course {
	--crs-border: #ece6db;
	--crs-radius: 16px;
	--crs-shadow: 0 10px 30px rgba( 11, 11, 11, 0.05 );
	--crs-muted: #6b7280;
	padding: var( --space-40-16, 2rem ) 0 var( --space-64-30, 4rem );
	color: var( --color-dark, #0b0b0b );
}

/* ── Grid ───────────────────────────────────────────────────────────────── */
.aws-course__grid {
	display: grid;
	grid-template-columns: minmax( 0, 1fr );
	gap: 28px;
	align-items: start;
}

@media ( min-width: 992px ) {
	.aws-course__grid {
		grid-template-columns: minmax( 0, 1fr ) 360px;
		gap: 40px;
	}
}

.aws-course__main {
	min-width: 0;
}

.aws-course__aside {
	min-width: 0;
}

.aws-course__sidebar {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

@media ( min-width: 992px ) {
	.aws-course__sidebar {
		position: sticky;
		top: 100px;
	}
}

@media ( max-width: 991.98px ) {
	.aws-course__aside {
		order: -1;
	}
}

/* ── Shared type helpers ────────────────────────────────────────────────── */
.aws-course__eyebrow {
	margin: 0 0 12px;
	font-family: var( --font-red-hat, sans-serif );
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var( --color-primary-dark, #a87e45 );
}

.aws-course__h2 {
	margin: 0 0 1rem;
	font-size: clamp( 1.5rem, 1.15rem + 1.3vw, 1.9rem );
	line-height: 1.15;
}

.aws-course__muted {
	color: var( --crs-muted );
}

/* ── Tabs ───────────────────────────────────────────────────────────────── */
.aws-course__tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 4px 26px;
	border-bottom: 1px solid var( --crs-border );
	margin-bottom: 26px;
}

.aws-course__tab {
	appearance: none;
	background: none;
	border: 0;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	padding: 10px 2px;
	font-family: var( --font-red-hat, sans-serif );
	font-size: 0.98rem;
	font-weight: 600;
	color: var( --crs-muted );
	cursor: pointer;
	transition: color 160ms ease, border-color 160ms ease;
}

.aws-course__tab:hover {
	color: var( --color-dark, #0b0b0b );
}

.aws-course__tab.is-active {
	color: var( --color-primary-dark, #a87e45 );
	border-bottom-color: var( --color-primary, #c39454 );
}

.aws-course__panel[hidden] {
	display: none;
}

/* ── Prose ──────────────────────────────────────────────────────────────── */
.aws-course__prose {
	font-size: 1.02rem;
	line-height: 1.75;
	color: #33383f;
}

.aws-course__prose > * + * {
	margin-top: 1.1em;
}

.aws-course__prose a {
	color: var( --color-primary-dark, #a87e45 );
	text-decoration: underline;
}

/* ── Feature cards ──────────────────────────────────────────────────────── */
.aws-course__features {
	display: grid;
	grid-template-columns: repeat( 3, 1fr );
	gap: 18px;
	margin-top: 28px;
	padding-top: 28px;
	border-top: 1px solid var( --crs-border );
	text-align: center;
}

@media ( max-width: 575.98px ) {
	.aws-course__features {
		grid-template-columns: 1fr;
		gap: 22px;
	}
}

.aws-course__feature-ico {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	margin-bottom: 12px;
	border-radius: 50%;
	background: #f7efe2;
}

.aws-course__feature-ico .aws-course__i {
	width: 24px;
	height: 24px;
	fill: var( --color-primary, #c39454 );
}

.aws-course__feature h3 {
	margin: 0 0 4px;
	font-size: 1rem;
}

.aws-course__feature p {
	margin: 0;
	font-size: 0.88rem;
	color: var( --crs-muted );
}

/* ── Credits table (Overview credits tab) ───────────────────────────────── */
.aws-course__credit-total {
	margin: 0 0 14px;
	font-size: 1.15rem;
	font-weight: 700;
	color: var( --color-primary-dark, #a87e45 );
}

.aws-course__credits {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.92rem;
}

.aws-course__credits th {
	text-align: left;
	font-family: var( --font-red-hat, sans-serif );
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: var( --crs-muted );
	padding: 0 0 8px;
	border-bottom: 1px solid var( --crs-border );
}

.aws-course__credits th:last-child,
.aws-course__credits td:last-child {
	text-align: right;
}

.aws-course__credits td {
	padding: 10px 0;
	border-bottom: 1px solid #f2efe8;
}

.aws-course__credits tr:last-child td {
	border-bottom: 0;
}

/* ── Faculty ────────────────────────────────────────────────────────────── */
.aws-course__faculty {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.aws-course__faculty-name {
	display: block;
	font-weight: 700;
}

.aws-course__faculty-role {
	display: block;
	font-size: 0.9rem;
	color: var( --crs-muted );
}

.aws-course__faculty-bio {
	margin: 6px 0 0;
	font-size: 0.92rem;
	color: #33383f;
}

/* ── Course content ─────────────────────────────────────────────────────── */
.aws-course__curriculum {
	margin-top: 40px;
}

.aws-course__curriculum-head {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 4px 16px;
	margin-bottom: 18px;
}

.aws-course__curriculum-head .aws-course__h2 {
	margin: 0;
	width: 100%;
}

.aws-course__curriculum-meta {
	margin: 0;
	margin-right: auto;
	font-family: var( --font-red-hat, sans-serif );
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var( --crs-muted );
}

.aws-course__req-flag {
	font-size: 0.72rem;
	font-weight: 600;
	color: var( --crs-muted );
}

.aws-course__steplist {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

/* Section heading grouping lessons within the curriculum. */
.aws-course__section-title {
	margin: 22px 0 2px;
	font-family: var( --font-red-hat, sans-serif );
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var( --color-primary-dark, #a87e45 );
}

.aws-course__section-title:first-child {
	margin-top: 0;
}

.aws-course__steplist--quizzes {
	margin-top: 22px;
}

.aws-course__steplist-heading {
	margin: 0 0 10px;
	font-family: var( --font-red-hat, sans-serif );
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	color: var( --crs-muted );
}

.aws-course__step {
	border: 1px solid var( --crs-border );
	border-radius: 12px;
	background: #fff;
	transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.aws-course__step:hover {
	border-color: var( --color-primary, #c39454 );
	box-shadow: 0 8px 22px rgba( 11, 11, 11, 0.07 );
	transform: translateY( -1px );
}

.aws-course__step-link {
	display: grid;
	grid-template-columns: auto minmax( 0, 1fr ) auto;
	align-items: center;
	gap: 16px;
	padding: 14px 18px;
	text-decoration: none;
	color: inherit;
}

.aws-course__step-index {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background: #f7efe2;
	color: var( --color-primary-dark, #a87e45 );
	font-family: var( --font-red-hat, sans-serif );
	font-weight: 700;
	font-size: 0.9rem;
	flex: 0 0 auto;
}

.aws-course__step.is-completed .aws-course__step-index {
	background: #e6f4ea;
	color: #1e8449;
}

.aws-course__step-body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.aws-course__step-type {
	font-family: var( --font-red-hat, sans-serif );
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var( --color-primary-dark, #a87e45 );
}

.aws-course__step-title {
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.35;
}

.aws-course__step:hover .aws-course__step-title {
	color: var( --color-primary-dark, #a87e45 );
}

.aws-course__step-title--locked {
	color: #aeb4bd;
	filter: blur( 3px );
	user-select: none;
}

/* Completion checkbox indicator */
.aws-course__check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border: 1.5px solid #d7dbe0;
	border-radius: 5px;
	background: #fff;
	color: #fff;
	font-size: 0.8rem;
	line-height: 1;
	flex: 0 0 auto;
}

.aws-course__check.is-done {
	background: var( --color-primary, #c39454 );
	border-color: var( --color-primary, #c39454 );
}

.aws-course__check.is-progress {
	border-color: var( --color-primary, #c39454 );
}

.aws-course__check.is-locked {
	border: 0;
	background: none;
	color: inherit;
	font-size: 0.9rem;
}

.aws-course__step-notice {
	padding: 0 18px 12px 68px;
	font-size: 0.85rem;
	color: var( --crs-muted );
}

.aws-course__topics {
	border-top: 1px solid #f0ebe1;
	padding: 6px 18px 12px 68px;
	display: block;
}

.aws-course__topics ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.aws-course__topics li a {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 7px 0;
	color: #4b5563;
	text-decoration: none;
	font-size: 0.94rem;
}

.aws-course__topics li a:hover {
	color: var( --color-primary-dark, #a87e45 );
}

.aws-course__topics li.topic-completed .aws-course__topic-status {
	color: #1e8449;
}

.aws-course__cert-note {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin: 18px 0 0;
	padding: 14px 18px;
	border-radius: 12px;
	background: #faf6ee;
	border: 1px solid #efe2cd;
	font-size: 0.9rem;
	color: #6a5b3e;
}

.aws-course__cert-note .aws-course__i {
	width: 18px;
	height: 18px;
	flex: 0 0 auto;
	margin-top: 1px;
	fill: var( --color-primary-dark, #a87e45 );
}

/* ── Sidebar cards ──────────────────────────────────────────────────────── */
.aws-course__card {
	background: #fff;
	border: 1px solid var( --crs-border );
	border-radius: 18px;
	padding: 22px 24px;
	box-shadow: var( --crs-shadow );
}

.aws-course__card-title {
	margin: 0 0 16px;
	font-size: 1.15rem;
}

/* Action card */
.aws-course__action {
	border: 2px solid var( --color-primary, #c39454 );
	box-shadow: 0 14px 34px rgba( 195, 148, 84, 0.16 );
}

.aws-course__action .aws-course__eyebrow {
	margin-bottom: 6px;
}

.aws-course__action-title {
	margin: 0 0 16px;
	font-size: 1.2rem;
	line-height: 1.3;
}

.aws-course__action-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
}

/* At a glance */
.aws-course__glance {
	list-style: none;
	margin: 0;
	padding: 0;
}

.aws-course__glance li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: 12px 0;
	border-bottom: 1px solid #f2efe8;
}

.aws-course__glance li:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.aws-course__glance li:first-child {
	padding-top: 0;
}

.aws-course__glance-key {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: #33383f;
}

.aws-course__glance-key .aws-course__i {
	width: 18px;
	height: 18px;
	fill: var( --color-primary, #c39454 );
	flex: 0 0 auto;
}

.aws-course__glance-val {
	font-weight: 700;
	font-family: var( --font-red-hat, sans-serif );
}

/* Credits earned */
.aws-course__credit-big {
	margin: 0;
	font-family: var( --font-red-hat, sans-serif );
	font-size: 2.4rem;
	font-weight: 800;
	line-height: 1;
	color: var( --color-dark, #0b0b0b );
}

.aws-course__credit-sub {
	margin: 4px 0 16px;
	font-size: 0.9rem;
	color: var( --crs-muted );
}

.aws-course__link-btn {
	appearance: none;
	background: none;
	border: 0;
	padding: 14px 0 0;
	font-family: var( --font-red-hat, sans-serif );
	font-size: 0.9rem;
	font-weight: 600;
	color: var( --color-primary-dark, #a87e45 );
	cursor: pointer;
}

.aws-course__link-btn:hover {
	text-decoration: underline;
}

/* CLE status card */
.aws-course__meta {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 14px;
	margin: 0 0 12px;
	font-size: 0.95rem;
	color: var( --crs-muted );
}

.aws-course__meta-val {
	font-weight: 700;
	color: var( --color-dark, #0b0b0b );
	text-align: right;
}

.aws-course__status {
	margin: 0 0 12px;
}

.aws-course .cle-status-badge {
	display: inline-block;
	padding: 4px 12px;
	border-radius: 999px;
	font-size: 0.8rem;
	font-weight: 600;
	background: #f0f0f1;
	color: #555;
}

.aws-course .cle-status-badge.cle-status--active {
	background: #e6f4ea;
	color: #1e8449;
}

.aws-course .cle-status-badge.cle-status--pending {
	background: #fdf3e6;
	color: #b26a00;
}

.aws-course__notice {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin: 16px 0 0;
	padding: 14px 16px;
	border-radius: 12px;
	background: #f7f5f0;
	font-size: 0.82rem;
	line-height: 1.55;
	color: var( --crs-muted );
}

.aws-course__notice .aws-course__i {
	width: 16px;
	height: 16px;
	flex: 0 0 auto;
	margin-top: 2px;
	fill: #9aa2ac;
}

/* Need help */
.aws-course__help-text {
	margin: 0 0 16px;
	font-size: 0.92rem;
	line-height: 1.6;
	color: #33383f;
}

.aws-course__support {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 11px 16px;
	border: 1px solid var( --crs-border );
	border-radius: 10px;
	font-family: var( --font-red-hat, sans-serif );
	font-weight: 600;
	font-size: 0.92rem;
	color: var( --color-dark, #0b0b0b );
	text-decoration: none;
	transition: border-color 160ms ease, color 160ms ease;
}

.aws-course__support .aws-course__i {
	width: 18px;
	height: 18px;
	fill: currentColor;
}

.aws-course__support:hover {
	border-color: var( --color-primary, #c39454 );
	color: var( --color-primary-dark, #a87e45 );
}

/* ── Access gate in the sidebar (no-access, styled by learndash-course.css) ─ */
.aws-course__aside .aws-learndash-preview,
.aws-course__aside .aws-learndash-preview__gate {
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0 !Important;
}

.aws-course__aside .aws-learndash-locked-content {
	max-width: none;
	margin: 0;
	border-radius: 18px;
	box-shadow: var( --crs-shadow );
	text-align: left;
}

/* ── Small screens ──────────────────────────────────────────────────────── */
@media ( max-width: 575.98px ) {
	.aws-course__card {
		padding: 20px;
	}

	.aws-course__step-link {
		gap: 12px;
		padding: 12px 14px;
	}

	.aws-course__step-notice,
	.aws-course__topics {
		padding-left: 14px;
	}
}
