/*
Theme Name: Astra VSU Child
Theme URI: http://localhost/vsu
Description: Astra child theme for the Virginia State University course portal.
Author: OpenAI
Template: astra
Version: 1.0.0
Text Domain: astra-vsu-child
*/

:root {
	--tg-blue: #0047bb;
	--tg-blue-dark: #0b2753;
	--tg-blue-deep: #031531;
	--tg-gold: #ffad06;
	--tg-gold-soft: #ffd46f;
	--tg-ink: #11213d;
	--tg-text: #41526f;
	--tg-surface: #ffffff;
	--tg-surface-alt: #f2f5fb;
	--tg-border: rgba(3, 21, 49, 0.1);
	--tg-shadow: 0 24px 60px rgba(3, 21, 49, 0.14);
	--tg-shadow-soft: 0 14px 32px rgba(3, 21, 49, 0.12);
	--tg-radius: 22px;
	--tg-container: min(90%, calc(100vw - 32px));
	/* --tg-container: min(1140px, calc(100vw - 32px)); */
}

*,
:after,
:before {
	box-sizing: unset;
}

ol,
ul {
	margin: 0 0 1.5em 0em;
}

html {
	scroll-behavior: smooth;
}

body {
	background:
		radial-gradient(circle at top left, rgba(255, 173, 6, 0.18), transparent 24%),
		radial-gradient(circle at top right, rgba(0, 71, 187, 0.16), transparent 28%),
		linear-gradient(180deg, #eff4ff 0%, #f7f9fd 32%, #ffffff 100%);
	color: var(--tg-text);
	font-family: "PT Sans", "Segoe UI", sans-serif;
}

body.tg-scrolled .tg-header-shell {
	box-shadow: 0 18px 42px rgba(3, 21, 49, 0.14);
}

a {
	transition: color 0.2s ease, opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.tg-container {
	width: var(--tg-container);
	margin: 0 auto;
}

.screen-reader-text {
	position: absolute;
	left: -9999px;
}

.tg-header-shell {
	position: sticky;
	top: 0;
	z-index: 90;
	background: rgba(255, 255, 255, 0.94);
	backdrop-filter: blur(16px);
	border-bottom: 1px solid rgba(3, 21, 49, 0.08);
}

.top_header {
	background:
		linear-gradient(90deg, rgba(0, 71, 187, 0.98), rgba(11, 39, 83, 0.98));
	color: #fff;
}

.tg-topbar-shell {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	min-height: 48px;
}

.bluetabs,
.bluetabs ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.tg-topnav-list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
}

.tg-topnav-list>li {
	display: inline-flex;
	align-items: center;
}

.bluetabs li a,
.tg-topnav-shortcode,
.tg-topnav-widget {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	padding: 6px 16px;
	border-radius: 999px;
	color: #fff;
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.88rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-decoration: none;
	text-transform: uppercase;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.12);
}

.bluetabs li a:hover,
.tg-topnav-shortcode:hover,
.tg-topnav-widget:hover {
	color: #fff;
	transform: translateY(-1px);
	background: rgba(255, 173, 6, 0.16);
	border-color: rgba(255, 212, 111, 0.5);
}

.tg-topnav-shortcode .ld-login-modal,
.tg-topnav-shortcode a,
.tg-topnav-widget a,
.tg-login-trigger {
	color: inherit;
	text-decoration: none;
}

.tg-login-trigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	padding: 6px 16px;
	border: 0;
	background: transparent;
	color: inherit;
	font: inherit;
	text-transform: inherit;
	letter-spacing: inherit;
	cursor: pointer;
}

.tg-topnav-widget .widgets_on_page,
.tg-topnav-widget .widgets_on_page ul,
.tg-topnav-widget .widget {
	margin: 0;
	padding: 0;
	list-style: none;
}

body.tg-modal-open {
	overflow: hidden;
}

.tg-login-modal[hidden] {
	display: none !important;
}

.tg-login-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
}

.tg-login-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(3, 21, 49, 0.72);
	backdrop-filter: blur(6px);
}

.tg-login-modal__dialog {
	position: relative;
	z-index: 1;
	width: min(520px, calc(100vw - 28px));
	margin: min(10vh, 72px) auto 0;
	padding: 28px;
	border-radius: 24px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(242, 245, 251, 0.98));
	box-shadow: 0 30px 80px rgba(3, 21, 49, 0.32);
}

.tg-login-modal__close {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 40px;
	height: 40px;
	border: 0;
	border-radius: 50%;
	background: rgba(3, 21, 49, 0.08);
	color: var(--tg-ink);
	font-size: 1.8rem;
	line-height: 1;
	cursor: pointer;
}

.tg-login-modal__brand {
	padding-right: 28px;
}

.tg-login-modal__brand img {
	max-width: 180px;
	height: auto;
	margin-bottom: 18px;
}

.tg-login-modal__eyebrow {
	margin: 0 0 8px;
	color: var(--tg-blue);
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.85rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.tg-login-modal__brand h2 {
	margin: 0 0 10px;
	font-size: clamp(1.8rem, 3vw, 2.35rem);
	color: var(--tg-ink);
}

.tg-login-modal__brand p {
	margin: 0 0 18px;
	color: var(--tg-text);
}

.tg-login-modal__form .login-username,
.tg-login-modal__form .login-password,
.tg-login-modal__form .login-remember,
.tg-login-modal__form .login-submit {
	margin-bottom: 16px;
}

.tg-login-modal__form label {
	display: block;
	margin-bottom: 8px;
	color: var(--tg-ink);
	font-weight: 700;
}

.tg-login-modal__form input[type="text"],
.tg-login-modal__form input[type="password"] {
	height: 52px;
	border-radius: 16px;
	border: 1px solid rgba(3, 21, 49, 0.14);
	background: #fff;
}

.tg-login-modal__form .login-submit input[type="submit"] {
	width: 80%;
	min-height: 52px;
	border: 0;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--tg-blue), var(--tg-blue-dark));
	color: #fff;
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.tg-login-modal__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 12px;
	font-size: 0.95rem;
}

.tg-login-modal__actions a {
	color: var(--tg-blue);
	text-decoration: none;
}

.tg-login-modal__actions a:hover {
	color: var(--tg-blue-dark);
}

.tg-login-modal__register {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 10px 18px;
	border-radius: 999px;
	background: rgba(0, 71, 187, 0.08);
	font-weight: 700;
}

.tg-login-modal.is-course-intent .tg-login-modal__dialog {
	border: 2px solid rgba(255, 173, 6, 0.35);
}

.tg-login-modal.is-course-intent .tg-login-modal__register {
	background: linear-gradient(135deg, var(--tg-gold), #ffcb5b);
	color: var(--tg-blue-deep);
	box-shadow: 0 14px 28px rgba(255, 173, 6, 0.3);
}

.tg-login-modal.is-course-intent .tg-login-modal__register:hover {
	color: var(--tg-blue-deep);
	transform: translateY(-1px);
}

.header {
	display: grid;
	grid-template-columns: minmax(300px, 240px) minmax(0, 1fr) minmax(250px, 290px);
	align-items: center;
	gap: 24px;
	padding: 18px 0;
}

.logo img {
	width: 100%;
	height: auto;
	max-width: 220px;
}

.tg-main-navigation .menu,
.tg-main-navigation ul,
.tg-user-navigation .menu,
.tg-user-navigation ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: end;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.tg-main-navigation a,
.tg-user-navigation a {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 14px;
	border-radius: 999px;
	color: var(--tg-ink);
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.98rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	text-decoration: none;
	text-transform: uppercase;
}

.tg-main-navigation a::after,
.tg-user-navigation a::after {
	content: "";
	position: absolute;
	left: 16px;
	right: 16px;
	bottom: 8px;
	height: 2px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--tg-gold), var(--tg-blue));
	transform: scaleX(0);
	transform-origin: center;
	transition: transform 0.25s ease;
}

.tg-main-navigation a:hover,
.tg-user-navigation a:hover,
.tg-main-navigation .current-menu-item>a,
.tg-user-navigation .current-menu-item>a {
	color: var(--tg-blue);
	background: rgba(0, 71, 187, 0.06);
}

.tg-main-navigation a:hover::after,
.tg-user-navigation a:hover::after,
.tg-main-navigation .current-menu-item>a::after,
.tg-user-navigation .current-menu-item>a::after {
	transform: scaleX(1);
}

.searchk {
	display: flex;
	justify-content: flex-end;
}

.tg-search-form {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100%;
	max-width: 320px;
	padding: 6px 6px 6px 16px;
	border: 1px solid rgba(3, 21, 49, 0.12);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.94);
	box-shadow:
		0 16px 34px rgba(3, 21, 49, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.tg-search-form input[type="search"] {
	width: 100%;
	border: 0;
	background: transparent;
	color: var(--tg-ink);
	font-size: 0.98rem;
	padding: 0;
	box-shadow: none;
}

.tg-search-form input[type="search"]:focus {
	outline: none;
}

.tg-search-form button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-width: 108px;
	height: 42px;
	border: 0;
	padding: 0 16px;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--tg-gold), #f29100);
	color: var(--tg-blue-deep);
	cursor: pointer;
	box-shadow: 0 10px 24px rgba(242, 145, 0, 0.24);
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.84rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.tg-search-form button:hover {
	transform: translateY(-1px) scale(1.02);
}

.tg-search-label {
	line-height: 1;
}

.tg-home-hero {
	position: relative;
	padding: 28px 0 0;
}

.tg-slider-shell {
	position: relative;
	width: var(--tg-container);
	margin: 0 auto 24px;
	border-radius: calc(var(--tg-radius) + 4px);
	overflow: hidden;
	box-shadow: var(--tg-shadow);
}

.tg-slider-shell::after {
	content: "";
	position: absolute;
	inset: auto 0 0;
	height: 84px;
	background: linear-gradient(180deg, transparent, rgba(3, 21, 49, 0.2));
	pointer-events: none;
}

.tg-page-hero {
	padding: 28px 0 10px;
}

.inner_intro_base {
	width: var(--tg-container);
	margin: 0 auto;
}

.inner_intro_pic {
	overflow: hidden;
	border-radius: calc(var(--tg-radius) + 2px);
	box-shadow: var(--tg-shadow);
}

.inner_intro_pic img {
	display: block;
	width: 100%;
	height: clamp(210px, 28vw, 320px);
	object-fit: cover;
}

.site-content .ast-container {
	width: var(--tg-container);
	padding-top: 24px;
	padding-bottom: 24px;
	display: block !important;
}

.ast-container {
	max-width: 100% !important;
}

.site-content .entry-title,
.site-content .archive-title,
.site-content h1,
.site-content h2,
.site-content h3,
.site-content h4,
.site-content h5,
.site-content h6 {
	color: var(--tg-ink);
	font-family: "Oswald", "Segoe UI", sans-serif;
}

.tg-home-stage {
	padding: 10px 0 0;
}

.top_2,
.tg-home-intro {
	display: grid;
	grid-template-columns: minmax(0, 1.15fr);
	gap: 28px;
	align-items: stretch;
}

.tg-panel {
	position: relative;
	padding: 30px;
	border: 1px solid rgba(3, 21, 49, 0.08);
	border-radius: calc(var(--tg-radius) + 2px);
	background: rgba(255, 255, 255, 0.88);
	box-shadow: var(--tg-shadow-soft);
	overflow: hidden;
}

.tg-panel::before {
	content: "";
	position: absolute;
	inset: 0 auto auto 0;
	width: 180px;
	height: 180px;
	background: radial-gradient(circle, rgba(255, 173, 6, 0.18), transparent 68%);
	pointer-events: none;
}

.tg-panel-copy {
	min-height: 100%;
}

.tg-panel-copy h2:first-child,
.tg-panel-copy .widget-title {
	margin-top: 0;
	color: var(--tg-blue);
	font-size: clamp(1.8rem, 2vw, 2.4rem);
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.tg-panel-copy p,
.tg-panel-copy li {
	font-size: 1.04rem;
	line-height: 1.8;
}

.tg-panel-video iframe,
.tg-panel-video embed,
.tg-panel-video video,
.tg-panel-video .video,
.tg-panel-video .widget {
	width: 100%;
}

.tg-panel-video iframe,
.tg-panel-video video,
.tg-panel-video embed {
	min-height: 320px;
	border: 0;
	border-radius: calc(var(--tg-radius) - 6px);
	box-shadow: 0 20px 50px rgba(3, 21, 49, 0.16);
}

.tg-panel-video {
	display: none;
}

.tg-course-showcase {
	padding: 12px 0 10px;
}

.tg-section-card {
	position: relative;
	padding: 34px;
	margin-top: 24px;
	border-radius: calc(var(--tg-radius) + 4px);
	background: linear-gradient(135deg, rgba(11, 39, 83, 0.98), rgba(0, 71, 187, 0.92));
	box-shadow: var(--tg-shadow);
	color: #fff;
	overflow: hidden;
}

.tg-section-card::before,
.tg-section-card::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.08);
}

.tg-section-card::before {
	top: -90px;
	right: -20px;
	width: 220px;
	height: 220px;
}

.tg-section-card::after {
	bottom: -70px;
	left: -40px;
	width: 180px;
	height: 180px;
}

.tg-section-header {
	position: relative;
	z-index: 1;
	display: flex;
	flex-wrap: wrap;
	align-items: end;
	justify-content: space-between;
	gap: 14px;
	margin-bottom: 28px;
}

.tg-section-header h2,
.tg-section-header p {
	margin: 0;
	color: inherit;
}

.tg-section-header h2 {
	font-size: clamp(1.8rem, 2vw, 2.4rem);
	text-transform: uppercase;
}

.tg-course-grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 18px;
}

.tg-course-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.14);
	border: 1px solid rgba(255, 255, 255, 0.14);
	backdrop-filter: blur(8px);
	box-shadow: 0 16px 36px rgba(3, 21, 49, 0.16);
}

.tg-course-card:hover {
	transform: translateY(-5px);
	background: rgba(255, 255, 255, 0.2);
}

.tg-course-card__media {
	display: block;
	aspect-ratio: 16 / 9;
}

.tg-course-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tg-course-card__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 14px;
	padding: 22px;
}

.tg-course-card__tag {
	display: inline-flex;
	align-self: flex-start;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.16);
	color: var(--tg-gold-soft);
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.tg-course-card h3 {
	margin: 0;
	font-size: 1.2rem;
	color: #fff;
}

.tg-course-card p {
	margin: 0;
	color: rgba(255, 255, 255, 0.86);
	line-height: 1.7;
}

.tg-course-directory {
	padding: 12px 0 40px;
}

.tg-course-directory__intro h1 {
	margin: 0 0 10px;
	color: #fff;
}

.tg-course-directory__intro p {
	max-width: 760px;
	margin: 0;
	color: rgba(255, 255, 255, 0.84);
}

.tg-course-directory__eyebrow {
	margin: 0 0 12px;
	color: var(--tg-gold-soft);
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.86rem;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.tg-course-directory__stats {
	display: grid;
	place-items: center;
	gap: 4px;
	min-width: 168px;
	padding: 18px 22px;
	border-radius: 20px;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.16);
	text-align: center;
}

.tg-course-directory__stat-value {
	color: #fff;
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 2.5rem;
	font-weight: 600;
	line-height: 1;
}

.tg-course-directory__stat-label {
	color: rgba(255, 255, 255, 0.78);
	font-size: 0.9rem;
}

.tg-course-catalog {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 22px;
	margin-top: 24px;
}

.tg-course-catalog__card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border-radius: 22px;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(3, 21, 49, 0.08);
	box-shadow: var(--tg-shadow-soft);
}

.tg-course-catalog__card:hover {
	transform: translateY(-4px);
	box-shadow: var(--tg-shadow);
}

.tg-course-catalog__media {
	display: block;
	aspect-ratio: 16 / 9;
	background: linear-gradient(135deg, rgba(0, 71, 187, 0.2), rgba(255, 173, 6, 0.18));
}

.tg-course-catalog__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.tg-course-catalog__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 14px;
	padding: 22px;
}

.tg-course-catalog__tag {
	display: inline-flex;
	align-self: flex-start;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(0, 71, 187, 0.08);
	color: var(--tg-blue);
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.8rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.tg-course-catalog__body h2 {
	margin: 0;
	font-size: 1.28rem;
	line-height: 1.35;
}

.tg-course-catalog__body h2 a {
	color: var(--tg-ink);
	text-decoration: none;
}

.tg-course-catalog__body p {
	margin: 0;
	color: var(--tg-text);
	line-height: 1.7;
}

.tg-course-catalog__body .tg-button {
	margin-top: auto;
	align-self: flex-start;
}

.tg-course-directory__empty {
	margin-top: 24px;
	padding: 26px;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.94);
	box-shadow: var(--tg-shadow-soft);
}

.tg-button,
.tg-course-card a,
.moduleBox .right-column .grayBox a.read_article,
.moduleBox .right-column .grayBox a.assignment,
.tg-category-card__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 22px;
	border-radius: 75px;
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.95rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-decoration: none;
	text-transform: uppercase;
	cursor: pointer;
}

.tg-button,
.tg-category-card__button,
.moduleBox .right-column .grayBox a.read_article {
	color: #fff;
	background: linear-gradient(135deg, var(--tg-blue), var(--tg-blue-dark));
	border: 1px solid rgba(255, 255, 255, 0.18);
	box-shadow: 0 14px 30px rgba(0, 71, 187, 0.24);
}

.tg-button:hover,
.tg-category-card__button:hover,
.moduleBox .right-column .grayBox a.read_article:hover {
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 18px 36px rgba(0, 71, 187, 0.32);
}

.moduleBox .right-column .grayBox a.assignment {
	color: var(--tg-blue) !important;
	background: #fff;
	border: 1px solid rgba(0, 71, 187, 0.22);
}

.moduleBox .right-column .grayBox a.assignment:hover {
	color: #fff !important;
	background: linear-gradient(135deg, var(--tg-gold), #f29100);
	border-color: transparent;
	box-shadow: 0 16px 34px rgba(242, 145, 0, 0.24);
}

.tg-page-shell .entry-content,
.tg-page-shell .entry-summary,
.site-content article {
	line-height: 1.8;
}

.cat_panal,
.tg-category-shell .archive-header {
	margin-bottom: 22px;
}

.tg-category-grid {
	display: grid;
	gap: 18px;
}

.tg-category-card {
	display: grid;
	grid-template-columns: minmax(90px, 140px) minmax(0, 1fr) auto;
	gap: 22px;
	align-items: center;
	padding: 24px;
	border: 1px solid var(--tg-border);
	border-radius: calc(var(--tg-radius) - 2px);
	background: rgba(255, 255, 255, 0.92);
	box-shadow: var(--tg-shadow-soft);
}

.tg-category-card__media img {
	display: block;
	width: 100%;
	max-width: 128px;
	height: auto;
	border-radius: 16px;
	object-fit: cover;
}

.tg-category-card__content h2,
.tg-category-card__content h3 {
	margin: 0 0 10px;
	font-size: clamp(1.35rem, 1.8vw, 1.7rem);
}

.tg-category-card__content p {
	margin: 0;
	line-height: 1.75;
}

.tg-archive-list article {
	padding: 24px 28px;
	margin-bottom: 18px;
	border-radius: calc(var(--tg-radius) - 2px);
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid var(--tg-border);
	box-shadow: var(--tg-shadow-soft);
}

.tg-archive-list .entry-title {
	margin-bottom: 10px;
}

.tg-archive-list .read-more,
.tg-archive-list .more-link {
	display: inline-flex;
	margin-top: 14px;
}

.top_panel {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	padding: 22px;
	margin-bottom: 26px;
	border: 1px solid rgba(0, 71, 187, 0.08);
	border-radius: calc(var(--tg-radius) - 4px);
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(242, 245, 251, 0.94));
	box-shadow: var(--tg-shadow-soft);
}

.top_panel .block {
	padding: 16px 18px;
	border-radius: 18px;
	background: rgba(0, 71, 187, 0.05);
}

.top_panel_text {
	color: var(--tg-blue);
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.98rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.top_panel_text_1 {
	color: var(--tg-ink);
	font-size: 1.02rem;
	font-weight: 700;
}

.moduleBox {
	max-width: 100%;
}

.moduleBox .row {
	display: grid;
	grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
	gap: 28px;
}

.moduleBox .instructor {
	padding: 0 0 18px;
	border-radius: calc(var(--tg-radius) - 6px);
	background: linear-gradient(180deg, rgba(0, 71, 187, 0.98), rgba(11, 39, 83, 0.98));
	box-shadow: var(--tg-shadow-soft);
	overflow: hidden;
}

.moduleBox .instructor h4 {
	margin: 0 0 18px;
	padding: 12px 16px;
	background: linear-gradient(135deg, var(--tg-gold), var(--tg-gold-soft));
	color: var(--tg-blue-deep);
	text-align: center;
	font-size: 1rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.moduleBox .instructor a,
.moduleBox .instructor p {
	display: block;
	padding: 0 20px;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1.7;
	text-align: center;
	text-decoration: none;
}

.moduleBox ul.left_sideMenu {
	padding: 0;
	margin: 18px 0 0;
	list-style: none;
}

.moduleBox ul.left_sideMenu li {
	position: relative;
	margin: 10px 0 0;
	padding: 18px 18px 15px;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid rgba(0, 71, 187, 0.08);
	box-shadow: 0 10px 24px rgba(3, 21, 49, 0.08);
	text-align: center;
}

.moduleBox ul.left_sideMenu li.active {
	background: linear-gradient(135deg, var(--tg-blue), var(--tg-blue-dark));
	color: #fff;
}

.moduleBox ul.left_sideMenu li h5 {
	margin: 0 0 6px;
	color: inherit;
	font-size: 1rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.moduleBox .discussion_Board,
.moduleBox a.read-lecture {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	margin-top: 14px;
	padding: 13px 18px;
	border-radius: 16px;
	background: rgba(255, 173, 6, 0.12);
	color: var(--tg-blue-deep);
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 0.95rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-decoration: none;
	text-transform: uppercase;
	border: 1px solid rgba(255, 173, 6, 0.35);
}

.moduleBox .discussion_Board:hover,
.moduleBox a.read-lecture:hover {
	background: rgba(255, 173, 6, 0.2);
	transform: translateY(-1px);
}

.moduleBox .right-column {
	padding-bottom: 18px;
	border: 1px solid rgba(3, 21, 49, 0.08);
	border-radius: calc(var(--tg-radius) - 2px);
	background: rgba(255, 255, 255, 0.96);
	box-shadow: var(--tg-shadow);
	overflow: hidden;
}

.moduleBox .right-column img {
	display: block;
	width: 100%;
	height: auto;
}

.moduleBox .right-column .grayBox {
	margin: 18px;
	padding: 18px;
	border-radius: 18px;
	background: var(--tg-surface-alt);
}

.moduleBox .right-column .grayBox strong {
	display: block;
	margin-bottom: 8px;
	color: var(--tg-ink);
	font-family: "Oswald", "Segoe UI", sans-serif;
	font-size: 1.05rem;
}

.moduleBox .right-column .grayBox .text-right {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: flex-end;
	margin-top: 16px;
}

.moduleBox iframe,
.moduleBox video,
.moduleBox embed,
.moduleBox object {
	width: 100%;
	border: 0;
}

.info_area {
	margin-top: 28px;
	padding: 32px 0;
	background: linear-gradient(135deg, rgba(11, 39, 83, 0.98), rgba(0, 71, 187, 0.92));
	color: #fff;
}

.info_wrap {
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.8fr) minmax(0, 0.95fr);
	gap: 26px;
	width: var(--tg-container);
	margin: 0 auto;
}

.info_box,
.info_box_2,
.info_box_3 {
	padding: 22px;
	border-radius: 20px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(8px);
}

.info_area h2,
.info_area .text,
.info_area a,
.info_area p,
.info_area li,
.info_area label {
	color: #fff;
}

.info_area h2 {
	margin-top: 0;
	margin-bottom: 18px;
	font-size: 1.15rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.info_box_2 .left,
.info_box_2 .right {
	display: inline-flex;
	align-items: center;
}

.info_box_2 .left {
	min-width: 100px;
	font-weight: 700;
}

.info_box_2 .right a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.12);
}

.info_box_2 .right img {
	width: 20px;
	height: 20px;
	filter: brightness(0) invert(1);
}

.footer {
	padding: 22px 0 30px;
	background: var(--tg-blue-deep);
}

.footer_resize {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	width: var(--tg-container);
	margin: 0 auto;
}

.footer p,
.footer a {
	margin: 0;
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.95rem;
	text-decoration: none;
}

.footer a:hover {
	color: var(--tg-gold-soft);
}

.tg-reveal {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.tg-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.contact-row {
	display: flex;
	margin-bottom: 12px;
}

.label {
	width: 120px;
	font-weight: bold;
}

.value {
	flex: 1;
}

.social-row a {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
}

.social-row img {
	width: 20px;
	height: 20px;
}

#sf_widget_constantcontact_2_form .field1 {
  margin-bottom: 12px;
  display: block; /* important if you want vertical spacing */
  width: 100%;     /* optional, for full width layout */
}

.tg-course-card__media {
  display: block;
  height: 180px;        /* 🔥 control card height from here */
  overflow: hidden;
}

.tg-course-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;    /* keeps image cropped nicely */
  display: block;
}

 body #lessons_list>div h4>a{
	padding: 8px 2.5em 8px 2rem;
 }
.learndash .completed:before{
		content: "";
		display: inline-block;
		width: 20px;
		height: 20px;
		background: url('assets/images/completed.png') no-repeat center;
		background-size: contain;
		margin-right: 8px;
}

.learndash .notcompleted:before{
	content: "";
    display: inline-block;
    width: 20px;
    height: 20px;
    background: url('assets/images/notcompleted.png') no-repeat center;
    background-size: contain;
    margin-right: 8px;
}


@media (max-width: 1024px) {
	.header {
		grid-template-columns: 1fr;
		justify-items: center;
		text-align: center;
	}

	.searchk {
		width: 100%;
		justify-content: center;
	}

	.tg-search-form {
		max-width: 420px;
	}

	.top_2,
	.tg-home-intro,
	.info_wrap,
	.moduleBox .row,
	.tg-category-card {
		grid-template-columns: 1fr;
	}

	.top_panel {
		grid-template-columns: 1fr;
	}

	.tg-category-card__media img {
		max-width: 160px;
	}
}

@media (max-width: 782px) {

	.tg-topbar-shell,
	.footer_resize {
		flex-direction: column;
		align-items: flex-start;
	}

	.bluetabs li a,
	.tg-topnav-shortcode,
	.tg-topnav-widget {
		min-height: 32px;
		padding: 6px 12px;
		font-size: 0.8rem;
	}

	.tg-main-navigation .menu,
	.tg-user-navigation .menu {
		justify-content: flex-start;
	}

	.tg-panel,
	.tg-section-card,
	.tg-category-card,
	.info_box,
	.info_box_2,
	.info_box_3 {
		padding: 20px;
	}

	.site-content .ast-container {
		padding-top: 18px;

	}

	.ast-container {
		max-width: 100% !important;
	}

	.tg-course-directory__stats {
		width: 100%;
	}

	.tg-search-form {
		max-width: 100%;
	}

	.tg-search-form button {
		min-width: 48px;
		padding: 0 12px;
	}

	.tg-search-label {
		display: none;
	}

	.tg-login-modal__dialog {
		padding: 22px;
		margin-top: 24px;
	}
}

@media (max-width: 544px) {
	:root {
		--tg-container: min(100vw - 20px, 1140px);
	}

	.tg-section-header {
		align-items: flex-start;
	}

	.tg-course-grid {
		grid-template-columns: 1fr;
	}

	.moduleBox .right-column .grayBox .text-right {
		justify-content: flex-start;
	}
}
