/* ============================================================
   CSS Variables
   ============================================================ */

:root {
	/* Brand colours */
	--color-primary: #006dff;
	--color-primary-hover: #005bd7;
	--color-accent: #ff7875;
	--color-text-dark: #111846;
	--color-bg-light: #f1f5fc;
	--color-navy: #16215b;
	--color-cert-bg: #1f299c;

	/* Typography */
	--font-size-xs: 12px;
	--font-size-sm: 13px;
	--font-size-base: 14px;
	--font-size-md: 15px;
	--font-size-lg: 16px;
	--font-size-hero: 40px;
	--font-size-display: 50px;

	/* Spacing */
	--border-radius-sm: 3px;
	--border-radius-md: 4px;
	--border-radius-lg: 16px;

	/* Shadows */
	--shadow-sm: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	--shadow-md: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);

	/* Transitions */
	--transition-fast: 0.15s;
	--transition-base: 0.2s;
	--ease-out: cubic-bezier(0.4, 0, 0.2, 1);
	--ease-in-out: cubic-bezier(0, 0, 0.2, 1);
}

/* ============================================================
   Header
   ============================================================ */

#header .header-center-img {
	padding-left: 30px;
	height: 30px;
}

/* ============================================================
   Hero / Ribbon
   ============================================================ */

.tt1-background {
	margin-bottom: 0px !important;
	border-bottom: 10px solid var(--color-accent);
}

.full-screen-ribbon {
	background-color: var(--color-bg-light) !important;
}

.fs-ribbon-text {
	font-size: var(--font-size-md);
}

/* ============================================================
   Catalog
   ============================================================ */

#catalog-content {
	background-color: var(--color-bg-light);
	padding: 0;
	width: 100%;
	text-align: center;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: nowrap;
	flex-direction: column;
}

#catalog-courses {
	justify-content: center;
	padding: 40px 0;
}

/* ============================================================
   Course card (coursebox)
   ============================================================ */

a.coursebox-container {
	border: none !important;
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow-sm);
}

a.coursebox-container:hover {
	box-shadow: var(--shadow-md);
	transition-property: box-shadow;
	transition-timing-function: var(--ease-out);
	transition-duration: var(--transition-fast);
}

a.coursebox-container img {
	transition-timing-function: var(--ease-in-out);
	transition-duration: var(--transition-base);
}

a.coursebox-container:hover img {
	transform: scale(1.05);
	transition-property: transform;
	transition-timing-function: var(--ease-in-out);
	transition-duration: var(--transition-base);
}

a.coursebox-container .coursebox-text {
	color: var(--color-text-dark);
}

a.coursebox-container .coursebox-text-description {
	font-size: var(--font-size-sm);
	color: var(--color-text-dark);
}

/* Path / series badges */

a.coursebox-container.sj-path .coursebox-callout:before {
	content: 'Path';
	left: 0;
	background-color: var(--color-accent);
	color: white;
	border-radius: var(--border-radius-md);
	padding: 4px 5px;
	font-size: var(--font-size-xs);
	font-weight: normal;
	position: relative;
	float: left;
}

a.coursebox-container.sj-course-series .course-series-count,
a.coursebox-container.sj-course-series .path-item-count,
a.coursebox-container.sj-path .course-series-count,
a.coursebox-container.sj-path .path-item-count {
	text-transform: uppercase;
	font-size: var(--font-size-xs);
	font-weight: bold;
	color: var(--color-accent) !important;
}

/* ============================================================
   Buttons / Links
   ============================================================ */

a.ribbon-button-link {
	border-radius: var(--border-radius-sm) !important;
	padding: 15px 0 !important;
	background-color: var(--color-primary) !important;
	font-size: var(--font-size-lg);
}

a.ribbon-button-link:hover {
	background-color: var(--color-primary-hover) !important;
}

.login-link {
	border-radius: var(--border-radius-sm) !important;
	background-color: var(--color-primary) !important;
	font-size: var(--font-size-sm);
	color: white;
	font-weight: bold;
	padding: 10px 20px !important;
}

.login-link:hover {
	color: white !important;
	background-color: var(--color-primary-hover) !important;
}

/* ============================================================
   Responsive
   ============================================================ */

@media only screen and (max-width: 874px) {
	#header .header-center-img {
		padding-left: 0px;
		height: 34px;
	}
}

@media only screen and (min-width: 64em) {
	.search .catalog-center-width,
	.list-view .catalog-center-width,
	.expandable-view .catalog-center-width {
		max-width: 1200px;
		padding: 0 20px;
	}
}

/* ============================================================
   Inner course page
   ============================================================ */

/* Hero banner */

:is(.sj-page-detail, .sj-page-curriculum) .top-row-grey.top-row-white-v2.padding-side.row-v2 {
	background-color: var(--color-navy);
	margin-bottom: 20px !important;
	border-bottom: 10px solid var(--color-accent);
}

:is(.sj-page-detail, .sj-page-curriculum) .top-row-grey.top-row-white-v2 h1 {
	color: white;
	font-size: var(--font-size-hero);
	line-height: var(--font-size-hero);
}

:is(.sj-page-detail, .sj-page-curriculum) .top-row-grey.top-row-white-v2 h2,
:is(.sj-page-detail, .sj-page-curriculum) .top-row-grey.top-row-white-v2 p {
	color: white;
}

:is(.sj-page-detail, .sj-page-curriculum) .top-row-grey.top-row-white-v2 .signin {
	margin-top: 50px;
}

/* Hero banner — label overrides */

:is(.sj-page-detail, .sj-page-curriculum) .top-row-grey.top-row-white-v2.padding-top.padding-side.row-v2 label,
:is(.sj-page-detail, .sj-page-curriculum) .top-row-grey.top-row-white-v2.padding-top.padding-side.row-v2 label h5 {
	color: white;
	font-size: var(--font-size-xs);
}

:is(.sj-page-detail, .sj-page-curriculum) .top-row-grey.top-row-white-v2.padding-top.padding-side.row-v2 label div span {
	background-color: white;
}

/* Purchase / enrolment */

:is(.sj-page-detail, .sj-page-curriculum) .dp-summary-wrapper,
:is(.sj-page-detail, .sj-page-curriculum) .cp-summary-wrapper {
	border: none;
}

:is(.sj-page-detail, .sj-page-curriculum) .purchase-button-wrapper > .sj-save-toggle-row-alignment {
	display: inline-flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-content: center;
	align-items: center;
}

:is(.sj-page-detail, .sj-page-curriculum) span.sj-text-already-purchased {
	margin-right: 20px;
	font-size: var(--font-size-base);
}

/* Bundle / course list */

:is(.sj-page-detail, .sj-page-curriculum) .row-v2 {
	max-width: none;
}

:is(.sj-page-detail, .sj-page-curriculum) #dp-details-bundle {
	max-width: 1260px;
	width: 100%;
	margin: 0 auto;
}

:is(.sj-page-detail, .sj-page-curriculum) .sj-courseboxes-v2 {
	max-width: none;
	background-color: var(--color-bg-light);
	padding: 0;
	width: 100%;
	text-align: center;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: nowrap;
	flex-direction: column;
}

:is(.sj-page-detail, .sj-page-curriculum) .list-view a.course {
	padding: 30px;
}

:is(.sj-page-detail, .sj-page-curriculum) .dp-row-flex-v2 {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}

/* Promo image */

.dp-promo-image img {
	border-radius: var(--border-radius-lg);
}

/* Catalog list view */

.sj-page-catalog .top-row.sj-courseboxes-v2.list-view {
	max-width: none;
	background-color: var(--color-bg-light);
}

/* Curriculum progress bar */

#path-curriculum-progress-bar-annotation span {
	text-align: center;
	position: relative !important;
	font-size: var(--font-size-sm);
}

/* Get Certified page */

body.sj-page-catalog div#main-container[data-tags='certificate'] {
	& h1 {
		font-size: var(--font-size-display);
		margin-bottom: 0;
	}

	& #catalog-content {
		max-width: 1200px;
		padding: 0 20px;
	}

	& #catalog-courses {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		gap: 24px;

		@media (max-width: 1200px) {
			grid-template-columns: repeat(3, 1fr);
		}

		@media (max-width: 900px) {
			grid-template-columns: repeat(2, 1fr);
		}

		@media (max-width: 600px) {
			grid-template-columns: 1fr;
		}
	}

	& #catalog-courses > a {
		width: 100%;
		padding: 20px;
	}

	& #catalog-courses > a .coursebox-text {
		margin: 0;
	}

	& #catalog-courses > a .coursebox-image {
		height: 175px;
		max-height: 175px;
		width: 100%;
		float: none;
		margin-bottom: 20px;
		margin-right: 0 !important;
	}

	& #catalog-courses > a .coursebox-image img {
		width: 100%;
		height: 175px;
		max-height: 175px;
		object-fit: contain;
		background-color: var(--color-cert-bg);
	}

	& #catalog-courses > a .coursebox-text-description {
		width: 100%;
		margin: 10px 0 !important;
	}
}
