/* KJC Site Suite CSS v1.2.4 */
@media (max-width:1024px){.desktop-only{display:none!important}}
@media (max-width:767px),(min-width:1025px){.tablet-only{display:none!important}}
@media (min-width:768px){.mobile-only{display:none!important}}
@media (max-width:767px){.desktop-tablet-only{display:none!important}}
@media (min-width:768px) and (max-width:1024px){.desktop-mobile-only{display:none!important}}
@media (min-width:1025px){.tablet-mobile-only{display:none!important}}

.fullscreen-image{position:fixed;top:0!important;left:0!important;width:100vw!important;height:100vh!important;overflow:hidden;margin:0!important;padding:0!important;z-index:-1}
.fullscreen-image img{position:absolute;top:0!important;left:0!important;width:100vw!important;height:100vh!important;max-width:none!important;max-height:none!important;object-fit:cover;object-position:top center!important;display:block;margin:0!important;padding:0!important}

.kjcss-hero{position:relative!important;width:100vw!important;max-width:100vw!important;height:75vh!important;min-height:75vh!important;left:50%!important;right:50%!important;margin-left:-50vw!important;margin-right:-50vw!important;margin-top:-120px!important;padding:0!important;overflow:hidden!important;display:flex!important;align-items:flex-start!important;justify-content:center!important;box-sizing:border-box!important}
.kjcss-hero__image,.kjcss-hero__overlay{position:absolute!important;inset:0!important;width:100%!important;height:100%!important}
.kjcss-hero__image{z-index:1!important}.kjcss-hero__overlay{z-index:2!important;pointer-events:none!important}
.kjcss-hero__image img{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;max-width:none!important;max-height:none!important;object-fit:cover!important;display:block!important;margin:0!important;padding:0!important}
.kjcss-hero__content{position:relative!important;z-index:3!important;width:min(92vw,1100px)!important;max-width:1100px!important;margin:0 auto!important;padding-top:var(--kjcss-content-vh,60vh)!important;padding-left:2rem!important;padding-right:2rem!important;padding-bottom:2rem!important;color:#fff!important;box-sizing:border-box!important}
.kjcss-hero__content h1,.kjcss-hero__content h2,.kjcss-hero__content h3,.kjcss-hero__content h4,.kjcss-hero__content h5,.kjcss-hero__content h6,.kjcss-hero__content p,.kjcss-hero__content li{color:#fff!important;text-shadow:0 3px 18px rgba(0,0,0,.45)!important}
.kjcss-hero__content h1{font-size:clamp(2.5rem,6vw,5rem)!important;line-height:1.05!important}.kjcss-hero__content p{font-size:clamp(1rem,2vw,1.35rem)!important;line-height:1.5!important;max-width:900px!important}
@media(max-width:768px){.kjcss-hero{margin-top:-90px!important}.kjcss-hero__content{width:94vw!important;padding-left:1.25rem!important;padding-right:1.25rem!important;padding-bottom:1.25rem!important}}

.kjcss-hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}
.kjcss-testimonial-form{display:grid;gap:1rem;max-width:760px}.kjcss-testimonial-form label{display:grid;gap:.4rem;font-weight:700}
.kjcss-testimonial-form input,.kjcss-testimonial-form select,.kjcss-testimonial-form textarea{width:100%;min-height:48px;border:1px solid #8f9ca3;border-radius:12px;padding:.8rem 1rem;font:inherit;box-sizing:border-box;background:#fff}
.kjcss-testimonial-form textarea{min-height:160px}.kjcss-testimonial-form button{border:0;border-radius:999px;padding:.9rem 1.4rem;background:#023a51;color:#fff;font-weight:700;cursor:pointer}.kjcss-form-message{border-left:4px solid #023a51;background:#f3f7f9;padding:1rem}
.kjcss-testimonial-grid,.kjcss-testimonial-home{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}
.kjcss-testimonial-card,.kjcss-testimonial-sidebar-card{border:1px solid rgba(2,58,81,.16);border-radius:22px;padding:1.25rem;background:#fff;box-shadow:0 12px 30px rgba(0,0,0,.08)}
.kjcss-testimonial-photo{width:84px;height:84px;border-radius:50%;object-fit:cover;margin-bottom:0}.kjcss-stars{color:#d6a100;letter-spacing:.08em;font-size:1.5rem;line-height:1}.kjcss-testimonial-text{font-size:1rem;line-height:1.55}.kjcss-testimonial-person{margin:0;color:#023a51;line-height:.9}

.kjcss-global-block{width:100%}
.kjcss-badge-carousel{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.kjcss-badge-card{border:1px solid rgba(2,58,81,.18);border-radius:20px;padding:1rem;background:#fff;box-shadow:0 12px 28px rgba(0,0,0,.08)}
.kjcss-badge-card img{width:100%;max-width:180px;height:auto;display:block;margin:0 auto 1rem}.kjcss-badge-card h3{font-size:1rem;line-height:1.2}

.category .category-hero-section{position:relative;width:100vw;height:75vh;margin-top:-120px;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);padding-top:120px;overflow:hidden;z-index:1;display:flex;align-items:center;justify-content:center}
.category .category-hero-section figure{position:absolute;inset:0;width:100%;height:100%;margin:0;z-index:1}.category .category-hero-section img{width:100%!important;height:100%!important;max-width:none!important;max-height:none!important;object-fit:cover;object-position:center top;display:block;margin:0!important;padding:0!important}
.category .category-hero-section:after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.5);z-index:2}.category #header{position:absolute;top:0;left:0;width:100%;z-index:9999;background:transparent!important;box-shadow:none!important}.category .category-hero-section .hero-section{position:relative;z-index:3;width:min(90vw,900px);margin:0 auto;padding:0!important}.category .category-hero-section .entry-header{text-align:center}.category .category-hero-section .page-title{font-size:3rem!important;color:#fff!important;line-height:1.1;text-align:center;margin:0 0 1rem 0;text-shadow:0 2px 12px rgba(0,0,0,.35)}.category .category-hero-section .page-description,.category .category-hero-section .page-description p{font-size:1.4rem!important;color:#fff!important;line-height:1.4;text-align:center;margin:0 auto;text-shadow:0 2px 12px rgba(0,0,0,.35)}.category .ct-container[data-vertical-spacing*="top"]{padding-top:40px!important}


/* =========================================================
   BADGE CAROUSEL FIX
   Image-only output
========================================================= */

.kjcss-badge-carousel {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: 1rem;
	align-items: center;
}

.kjcss-badge-card {
	border: 0 !important;
	border-radius: 0 !important;
	padding: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.kjcss-badge-card img {
	width: 100% !important;
	max-width: 160px !important;
	height: auto !important;
	display: block !important;
	margin: 0 auto !important;
}


/* =========================================================
   BADGE CAROUSEL 1.2.2
   Greyed, image-only, 8 visible, scroll navigation
========================================================= */

.kjcss-badge-carousel-wrap,
.kjcss-all-badges-grid,
.kjcss-badge-carousel-wrap *,
.kjcss-all-badges-grid *,
.kjcss-badge-modal,
.kjcss-badge-modal * {
	box-sizing: border-box;
}

.kjcss-badge-carousel-wrap {
	width: 100%;
	display: flex;
	align-items: center;
	gap: 14px;
	margin: 24px 0;
}

.kjcss-badge-carousel-track {
	display: flex;
	gap: 18px;
	overflow-x: auto;
	scroll-behavior: smooth;
	padding: 10px 4px;
	width: 100%;
	scrollbar-width: thin;
}

.kjcss-badge-card-carousel {
	flex: 0 0 calc((100% - 126px) / 8) !important;
	width: calc((100% - 126px) / 8) !important;
	min-width: 0 !important;
	height: 110px !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}

.kjcss-badge-card-grid {
	width: 100%;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}

.kjcss-all-badges-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
	gap: 14px;
	width: 100%;
	margin: 24px 0;
}

.kjcss-badge-open {
	width: 100%;
	height: 100%;
	min-height: 100px;
	border: 0 !important;
	background: transparent !important;
	padding: 0 !important;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
}

.kjcss-badge-open img {
	display: block;
	width: 100% !important;
	height: 100% !important;
	max-width: 120px !important;
	max-height: 120px !important;
	object-fit: contain !important;
	filter: grayscale(100%) brightness(1.45) contrast(0.72);
	opacity: 0.9;
	transition: filter 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.kjcss-badge-open:hover img,
.kjcss-badge-open:focus img {
	filter: grayscale(0%) brightness(1) contrast(1);
	opacity: 1;
	transform: scale(1.035);
}

.kjcss-badge-nav {
	width: 44px;
	min-width: 44px;
	height: 44px;
	border-radius: 999px;
	border: 1px solid #d7d7d7;
	background: #ffffff;
	color: #000000;
	cursor: pointer;
	font-size: 32px;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

.kjcss-badge-template {
	display: none !important;
}

/* Badge modal */
.kjcss-badge-modal {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 0;
}

.kjcss-badge-modal.is-open {
	display: flex;
}

.kjcss-badge-modal-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.30);
}

.kjcss-badge-modal-dialog {
	position: relative;
	z-index: 2;
	width: 65vw !important;
	max-width: 65vw !important;
	min-width: 65vw !important;
	max-height: 92vh;
	overflow-y: auto;
	background: #ffffff;
	color: #000000 !important;
	border-radius: 20px;
	border: 1px solid #023a51;
	padding: 54px;
	box-shadow: 0 20px 70px rgba(0, 0, 0, 0.18);
}

.kjcss-badge-modal-content,
.kjcss-badge-modal-content * {
	color: #000000 !important;
	font-size: 1rem !important;
	line-height: 1.6;
}

.kjcss-badge-modal-layout {
	display: grid;
	grid-template-columns: minmax(320px, 0.95fr) minmax(320px, 1.05fr);
	gap: 46px;
	align-items: start;
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
}

.kjcss-badge-modal-column-main {
	text-align: center;
}

.kjcss-badge-modal-column-standards {
	text-align: left;
	border-left: 1px solid #dddddd;
	padding-left: 38px;
}

.kjcss-badge-modal-image-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
}

.kjcss-badge-modal-image {
	display: block;
	width: 250px;
	max-width: 250px;
	height: auto;
	object-fit: contain;
	margin: 0 auto 24px auto;
}

.kjcss-badge-modal-title {
	margin: 0 0 4px 0;
	text-align: center;
	font-weight: 700;
	font-size: 0.9rem !important;
	line-height: 1.1 !important;
}

.kjcss-badge-modal-issued {
	text-align: center;
	margin: 0 0 16px 0;
	font-size: 0.9rem !important;
	line-height: 1.1 !important;
}

.kjcss-badge-modal-section {
	text-align: left;
	margin-top: 24px;
}

.kjcss-badge-modal-close {
	position: sticky;
	top: 0;
	float: right;
	z-index: 5;
	width: 46px;
	height: 46px;
	border: 1px solid #000000;
	background: #ffffff;
	color: #000000;
	cursor: pointer;
	font-size: 2rem !important;
	line-height: 1;
	margin: -30px -30px 10px 10px;
}

body.kjcss-badge-modal-open {
	overflow: hidden;
}

@media (max-width: 1100px) {
	.kjcss-badge-card-carousel {
		flex-basis: calc((100% - 90px) / 6) !important;
		width: calc((100% - 90px) / 6) !important;
	}
}

@media (max-width: 900px) {
	.kjcss-badge-card-carousel {
		flex-basis: calc((100% - 54px) / 4) !important;
		width: calc((100% - 54px) / 4) !important;
	}

	.kjcss-badge-modal-dialog {
		width: 100vw !important;
		max-width: 100vw !important;
		min-width: 100vw !important;
		height: 100vh !important;
		max-height: 100vh !important;
		padding: 22px;
		overflow-y: auto;
	}

	.kjcss-badge-modal-layout {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.kjcss-badge-modal-column-standards {
		border-left: 0;
		border-top: 1px solid #dddddd;
		padding-left: 0;
		padding-top: 24px;
	}

	.kjcss-badge-modal-close {
		position: sticky;
		top: 8px;
		margin: 0 0 12px auto;
		display: block;
		float: none;
	}
}

@media (max-width: 767px) {
	.kjcss-badge-carousel-wrap {
		gap: 8px;
	}

	.kjcss-badge-card-carousel {
		flex-basis: 85px !important;
		width: 85px !important;
		height: 85px !important;
	}

	.kjcss-badge-nav {
		width: 38px;
		min-width: 38px;
		height: 38px;
		font-size: 27px;
	}

	.kjcss-all-badges-grid {
		grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
		gap: 10px;
	}
}


/* =========================================================
   BADGE ADMIN + MODAL FIELD RESTORE 1.2.3
========================================================= */

.kjcss-badge-admin-fields hr {
	margin: 24px 0;
}

.kjcss-badge-modal-description,
.kjcss-badge-modal-criteria {
	text-align: left;
}

.kjcss-badge-modal-section h4,
.kjcss-badge-modal-column-standards h4 {
	margin: 0 0 10px 0;
	font-weight: 700;
}


/* Badge admin restore 1.2.4 */
.kjcss-badge-admin-fields hr {
	margin: 24px 0;
}

.kjcss-badge-modal-skills,
.kjcss-badge-modal-description,
.kjcss-badge-modal-criteria {
	text-align: left;
}


/* 1.2.5 badge modal field support */
.kjcss-badge-modal-skills,
.kjcss-badge-modal-description,
.kjcss-badge-modal-criteria,
.kjcss-badge-modal-column-standards {
	overflow-wrap: anywhere;
}


/* Badge modal/admin support 1.2.6 */
.kjcss-badge-modal-skills,
.kjcss-badge-modal-description,
.kjcss-badge-modal-criteria,
.kjcss-badge-modal-column-standards {
	overflow-wrap: anywhere;
}


/* =========================================================
   HERO PER-BLOCK VH CONTROLS 1.2.7
========================================================= */

.kjcss-hero__content--fallback {
	padding-top: var(--kjcss-content-vh, 60vh) !important;
}

.kjcss-hero__content--positioned {
	position: absolute !important;
	inset: 0 !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
	z-index: 3 !important;
	pointer-events: none;
}

.kjcss-hero__block {
	position: absolute !important;
	top: var(--kjcss-block-vh, 60vh) !important;
	left: 50% !important;
	transform: translateX(-50%) !important;
	width: min(92vw, 1100px) !important;
	max-width: 1100px !important;
	padding-left: 2rem !important;
	padding-right: 2rem !important;
	box-sizing: border-box !important;
	color: #ffffff !important;
	pointer-events: auto;
}

.kjcss-hero__block h1,
.kjcss-hero__block h2,
.kjcss-hero__block h3,
.kjcss-hero__block h4,
.kjcss-hero__block h5,
.kjcss-hero__block h6,
.kjcss-hero__block p,
.kjcss-hero__block li {
	color: #ffffff !important;
	text-shadow: 0 3px 18px rgba(0, 0, 0, 0.45) !important;
}

@media (max-width: 768px) {
	.kjcss-hero__block {
		width: 94vw !important;
		padding-left: 1.25rem !important;
		padding-right: 1.25rem !important;
	}
}


/* =========================================================
   TESTIMONIAL FORM REFINEMENT 1.2.9
========================================================= */

.kjcss-testimonial-form input[type="text"],
.kjcss-testimonial-form input[type="email"],
.kjcss-testimonial-form input[type="file"],
.kjcss-testimonial-form select,
.kjcss-testimonial-form textarea {
	border: 1pt solid #023a51 !important;
	border-radius: 0 !important;
	background: #ffffff !important;
	color: #023a51 !important;
	min-height: 52px !important;
	padding: 12px 14px !important;
	box-sizing: border-box !important;
	margin-bottom: 5% !important;
	width: 100% !important;
}

.kjcss-testimonial-form textarea {
	min-height: 160px !important;
}

.kjcss-testimonial-form input[type="file"] {
	padding-top: 14px !important;
}

.kjcss-testimonial-form ::placeholder {
	color: rgba(2, 58, 81, 0.5) !important;
	opacity: 1 !important;
}

.kjcss-testimonial-form select {
	color: rgba(2, 58, 81, 0.5) !important;
}

.kjcss-testimonial-form select:valid {
	color: #023a51 !important;
}

.kjcss-testimonial-role-other-wrap {
	display: none;
}



/* =========================================================
   TESTIMONIAL FORM FIX 1.3.0
   Correct conditional Other field and reduce spacing
========================================================= */

.kjcss-testimonial-form {
	display: grid !important;
	gap: 0.65rem !important;
	max-width: 760px;
}

.kjcss-testimonial-form .kjcss-testimonial-field {
	display: grid !important;
	gap: 0.3rem !important;
	margin: 0 0 0.65rem 0 !important;
	font-weight: 700;
}

.kjcss-testimonial-form input[type="text"],
.kjcss-testimonial-form input[type="email"],
.kjcss-testimonial-form input[type="file"],
.kjcss-testimonial-form select,
.kjcss-testimonial-form textarea {
	border: 1pt solid #023a51 !important;
	border-radius: 0 !important;
	background: #ffffff !important;
	color: #023a51 !important;
	min-height: 48px !important;
	padding: 10px 12px !important;
	box-sizing: border-box !important;
	margin-bottom: 0 !important;
	width: 100% !important;
}

.kjcss-testimonial-form textarea {
	min-height: 140px !important;
}

.kjcss-testimonial-form input[type="file"] {
	padding-top: 11px !important;
}

.kjcss-testimonial-form ::placeholder {
	color: rgba(2, 58, 81, 0.5) !important;
	opacity: 1 !important;
}

.kjcss-testimonial-form select {
	color: rgba(2, 58, 81, 0.5) !important;
}

.kjcss-testimonial-form select:valid {
	color: #023a51 !important;
}

.kjcss-testimonial-role-other-wrap {
	display: none;
}

.kjcss-testimonial-submit {
	margin-top: 0.35rem !important;
	margin-bottom: 5% !important;
	border-radius: 0 !important;
}


/* =========================================================
   TESTIMONIAL FIX 1.3.1
   Star rating select + random three home layout
========================================================= */

.kjcss-testimonial-form {
	display: grid !important;
	gap: 0.45rem !important;
	max-width: 760px;
}

.kjcss-testimonial-form .kjcss-testimonial-field {
	display: grid !important;
	gap: 0.25rem !important;
	margin: 0 0 0.45rem 0 !important;
	font-weight: 700;
}

.kjcss-testimonial-form input[type="text"],
.kjcss-testimonial-form input[type="email"],
.kjcss-testimonial-form input[type="file"],
.kjcss-testimonial-form select,
.kjcss-testimonial-form textarea {
	border: 1pt solid #023a51 !important;
	border-radius: 0 !important;
	background-color: #ffffff !important;
	color: #023a51 !important;
	min-height: 48px !important;
	padding: 10px 12px !important;
	box-sizing: border-box !important;
	margin-bottom: 0 !important;
	width: 100% !important;
	opacity: 1 !important;
	visibility: visible !important;
	pointer-events: auto !important;
	appearance: auto !important;
	-webkit-appearance: menulist !important;
}

.kjcss-testimonial-form .kjcss-testimonial-stars-select {
	display: block !important;
	position: relative !important;
	z-index: 2 !important;
	cursor: pointer !important;
}

.kjcss-testimonial-form ::placeholder {
	color: rgba(2, 58, 81, 0.5) !important;
	opacity: 1 !important;
}

.kjcss-testimonial-form select:invalid {
	color: rgba(2, 58, 81, 0.5) !important;
}

.kjcss-testimonial-form select:valid {
	color: #023a51 !important;
}

.kjcss-testimonial-home-random-three {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(260px, 320px)) !important;
	justify-content: center !important;
	justify-items: stretch !important;
	align-items: stretch !important;
	gap: 1.25rem !important;
	width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

@media (min-width: 960px) {
	.kjcss-testimonial-home-random-three {
		grid-template-columns: repeat(3, minmax(260px, 320px)) !important;
	}
}

@media (max-width: 959px) {
	.kjcss-testimonial-home-random-three {
		grid-template-columns: repeat(auto-fit, minmax(260px, 320px)) !important;
	}
}

@media (max-width: 420px) {
	.kjcss-testimonial-home-random-three {
		grid-template-columns: 1fr !important;
	}
}


/* =========================================================
   TESTIMONIAL AREA CHECKBOXES 1.3.2
========================================================= */

.kjcss-testimonial-area-group {
	border: 0 !important;
	padding: 0 !important;
	margin: 0 0 0.45rem 0 !important;
}

.kjcss-testimonial-area-group legend {
	font-weight: 700;
	color: #023a51;
	margin-bottom: 0.35rem;
	padding: 0;
}

.kjcss-testimonial-checkboxes {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 0.35rem 0.75rem;
	margin-bottom: 0 !important;
}

.kjcss-testimonial-checkbox {
	display: flex !important;
	align-items: center;
	gap: 0.5rem !important;
	margin: 0 !important;
	font-weight: 400 !important;
	color: #023a51;
}

.kjcss-testimonial-checkbox input[type="checkbox"] {
	width: 18px !important;
	height: 18px !important;
	min-height: 18px !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 1pt solid #023a51 !important;
	border-radius: 0 !important;
	accent-color: #023a51;
}

/* =========================================================
   TESTIMONIAL TYPOGRAPHY AND AUTHOR LAYOUT UPDATE
========================================================= */
.kjcss-testimonial-text {
	font-size: 1.2rem !important;
	line-height: 1.55 !important;
}

.kjcss-stars {
	font-size: 1.5rem !important;
	line-height: 1 !important;
}

.kjcss-testimonial-author-wrap {
	display: flex !important;
	align-items: center !important;
	gap: 0.75rem !important;
	margin-top: 0.75rem !important;
}

.kjcss-testimonial-photo {
	width: 84px !important;
	height: 84px !important;
	border-radius: 50% !important;
	object-fit: cover !important;
	margin: 0 !important;
	flex: 0 0 84px !important;
}

.kjcss-testimonial-person {
	margin: 0 !important;
	line-height: 0.9 !important;
}

.kjcss-testimonial-person strong {
	display: block !important;
	font-size: 1.35rem !important;
	font-weight: 700 !important;
	line-height: 0.9 !important;
	margin: 0 !important;
	padding: 0 !important;
}

.kjcss-testimonial-person span {
	display: block !important;
	font-size: 1rem !important;
	font-style: italic !important;
	line-height: 0.9 !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* =========================================================
   SOFTWARE LOGO CAROUSEL
   Eight visible, auto-scrolling, greyed until hover
========================================================= */
.kjcss-software-logo-carousel-wrap,
.kjcss-software-logo-carousel-wrap * {
	box-sizing: border-box;
}

.kjcss-software-logo-carousel-wrap {
	width: 100%;
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 24px 0;
}

.kjcss-software-logo-carousel-track {
	display: flex;
	gap: 12px;
	overflow-x: auto;
	scroll-behavior: smooth;
	padding: 12px 4px;
	width: 100%;
	scrollbar-width: none;
}

.kjcss-software-logo-carousel-track::-webkit-scrollbar {
	display: none;
}

.kjcss-software-logo-card {
	flex: 0 0 calc((100% - 84px) / 8) !important;
	width: calc((100% - 84px) / 8) !important;
	min-width: 0 !important;
	min-height: 108px !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	padding: 0 !important;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: 8px;
}

.kjcss-software-logo-card img {
	display: block;
	width: 100% !important;
	height: auto !important;
	max-width: 130px !important;
	max-height: 90px !important;
	object-fit: contain !important;
	filter: grayscale(100%) brightness(1.35) contrast(0.7);
	opacity: 0.82;
	transition: filter 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.kjcss-software-logo-card:hover img,
.kjcss-software-logo-card:focus-within img {
	filter: grayscale(0%) brightness(1) contrast(1);
	opacity: 1;
	transform: scale(1.28);
}

.kjcss-software-logo-title {
	display: none !important;
	width: 100% !important;
	margin-top: 0 !important;
	text-align: center !important;
	font-size: 0.8rem !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
	color: inherit !important;
	pointer-events: none !important;
}

.kjcss-software-logo-card:hover > .kjcss-software-logo-title {
	display: block !important;
}

.kjcss-software-logo-nav {
	width: 40px;
	min-width: 40px;
	height: 40px;
	border-radius: 999px;
	border: 1px solid #d7d7d7;
	background: #ffffff;
	color: #000000;
	cursor: pointer;
	font-size: 28px;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

@media (max-width: 1200px) {
	.kjcss-software-logo-card {
		flex-basis: calc((100% - 88px) / 8) !important;
		width: calc((100% - 88px) / 8) !important;
	}
}

@media (max-width: 900px) {
	.kjcss-software-logo-card {
		flex-basis: calc((100% - 44px) / 4) !important;
		width: calc((100% - 44px) / 4) !important;
		height: 76px !important;
	}
}

@media (max-width: 767px) {
	.kjcss-software-logo-carousel-wrap {
		gap: 8px;
	}

	.kjcss-software-logo-card {
		flex-basis: 78px !important;
		width: 78px !important;
		height: 70px !important;
	}

	.kjcss-software-logo-nav {
		width: 36px;
		min-width: 36px;
		height: 36px;
		font-size: 24px;
	}
}


.kjcss-software-logo-track{
    gap:40px !important;
}

.kjcss-software-logo-image{
    max-width:80px !important;
    width:80px !important;
    height:auto !important;
}

/* =========================================================
   FINAL TESTIMONIAL CARD UNIFORM HEIGHT AND AUTHOR POSITION
   Keeps testimonial cards equal height and anchors author info
   consistently at the bottom of each box.
========================================================= */
.kjcss-testimonial-grid,
.kjcss-testimonial-home,
.kjcss-testimonial-home-random-three {
	align-items: stretch !important;
}

.kjcss-testimonial-card,
.kjcss-testimonial-sidebar-card {
	height: 100% !important;
	display: flex !important;
	flex-direction: column !important;
	box-sizing: border-box !important;
}

.kjcss-testimonial-text {
	flex: 1 1 auto !important;
}

.kjcss-testimonial-author-wrap {
	margin-top: auto !important;
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	justify-content: flex-start !important;
	gap: 12px !important;
	width: 100% !important;
}

.kjcss-testimonial-photo {
	width: 84px !important;
	height: 84px !important;
	min-width: 84px !important;
	border-radius: 50% !important;
	object-fit: cover !important;
	margin: 0 !important;
	flex: 0 0 84px !important;
	align-self: center !important;
}

.kjcss-testimonial-person {
	margin: 0 !important;
	padding: 0 !important;
	line-height: 0.9 !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	align-items: flex-start !important;
	gap: 2px !important;
}

.kjcss-testimonial-person br {
	display: none !important;
}

.kjcss-testimonial-person strong {
	display: block !important;
	font-size: 1.35rem !important;
	font-weight: 700 !important;
	line-height: 0.9 !important;
	margin: 0 !important;
	padding: 0 !important;
}

.kjcss-testimonial-person span {
	display: block !important;
	font-size: 1rem !important;
	font-style: italic !important;
	line-height: 0.9 !important;
	margin: 0 !important;
	padding: 0 !important;
}


/* =========================================================
   PODCAST EPISODES
   Mirrors WordPress Latest Posts widget without dates
========================================================= */

.kjcss-podcast-episodes,
.kjcss-podcast-episodes.wp-block-latest-posts,
.kjcss-podcast-episodes.wp-block-latest-posts__list {
	list-style: none !important;
	margin-left: 0 !important;
	padding-left: 0 !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

.kjcss-podcast-episodes li {
	list-style: none !important;
	margin: 0 0 1em 0 !important;
	padding: 0 !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

.kjcss-podcast-episodes .wp-block-latest-posts__featured-image {
	margin: 0 0 .5em 0 !important;
	padding: 0 !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

.kjcss-podcast-episodes .wp-block-latest-posts__featured-image img {
	display: block !important;
	max-width: 100% !important;
	height: auto !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

.kjcss-podcast-episodes .wp-block-latest-posts__post-title {
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

.kjcss-podcast-episodes .wp-block-latest-posts__post-excerpt,
.kjcss-podcast-episodes .wp-block-latest-posts__post-full-content {
	margin-bottom: 1em !important;
	margin-top: .5em !important;
	padding: 0 !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
	font-size: inherit !important;
	font-weight: inherit !important;
	line-height: inherit !important;
}






/* =========================================================
   KJC PODCAST LATEST - RESTORED NON-ACCORDION
========================================================= */

.kjcss-podcast-latest-list {
	width: 100% !important;
	display: block !important;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	text-align: left !important;
}

.kjcss-podcast-latest-item {
	width: 100% !important;
	display: block !important;
	margin: 0 0 12px 0 !important;
	padding: 0 !important;
	text-align: left !important;
}

.kjcss-podcast-latest-title {
	display: block !important;
	text-align: left !important;
	font-weight: 700 !important;
}

.kjcss-podcast-latest-excerpt {
	display: block !important;
	text-align: left !important;
	margin-top: .5em !important;
	margin-bottom: 1em !important;
}







/* =========================================================
   KJC PODCAST FULL LIST ACCORDION - TRUE 100% WIDTH FINAL
   Applies only to [kjc_podcast_episodes]
========================================================= */

html body .kjcss-podcast-full-table-accordion {
	width: 100% !important;
	min-width: 100% !important;
	max-width: none !important;
	display: block !important;
	table-layout: auto !important;
	border-collapse: collapse !important;
	border-spacing: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	box-sizing: border-box !important;
	text-align: left !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-row {
	width: 100% !important;
	min-width: 100% !important;
	max-width: none !important;
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	box-sizing: border-box !important;
	text-align: left !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-trigger {
	width: 100% !important;
	min-width: 100% !important;
	max-width: none !important;
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 16px !important;
	box-sizing: border-box !important;
	margin: 0 !important;
	padding: 14px 18px !important;
	border: 0 !important;
	border-radius: 0 !important;
	background: #ffffff !important;
	box-shadow: none !important;
	outline: none !important;
	cursor: pointer !important;
	text-align: left !important;
	font-family: inherit !important;
	font-size: inherit !important;
	color: inherit !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-row:first-child .kjcss-podcast-full-trigger {
	border-top-left-radius: 20px !important;
	border-top-right-radius: 20px !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-row:nth-child(even) .kjcss-podcast-full-trigger {
	background: #e7e7e7 !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-title {
	flex: 1 1 auto !important;
	min-width: 0 !important;
	width: auto !important;
	max-width: none !important;
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	font-weight: 700 !important;
	line-height: 1.2 !important;
	text-align: justify !important;
	text-align-last: left !important;
	overflow-wrap: anywhere !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-arrow {
	flex: 0 0 28px !important;
	width: 28px !important;
	min-width: 28px !important;
	max-width: 28px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: flex-end !important;
	margin-left: auto !important;
	font-size: 1.1rem !important;
	line-height: 1 !important;
	transition: transform 0.2s ease !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-panel {
	width: 100% !important;
	min-width: 100% !important;
	max-width: none !important;
	display: none !important;
	box-sizing: border-box !important;
	margin: 0 !important;
	padding: 14px 18px 18px 18px !important;
	background: #ffffff !important;
	text-align: left !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-panel[hidden] {
	display: none !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-row.is-open .kjcss-podcast-full-panel {
	display: block !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-row.is-open .kjcss-podcast-full-arrow {
	transform: rotate(180deg) !important;
}

html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-description {
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
	text-align: left !important;
	box-sizing: border-box !important;
}

@media (max-width: 767px) {
	html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-trigger {
		width: 100% !important;
		padding: 12px 14px !important;
		gap: 10px !important;
	}

	html body .kjcss-podcast-full-table-accordion .kjcss-podcast-full-panel {
		width: 100% !important;
		padding: 12px 14px 16px 14px !important;
	}
}


/* =========================================================
   CONTACT POPUP SHORTCODE
========================================================= */
.kjcss-contact-popup-wrap,
.kjcss-contact-popup-wrap * {
	box-sizing: border-box;
}

.kjcss-contact-popup-open,
.kjcss-contact-popup-submit {
	border: 0 !important;
	border-radius: 999px !important;
	background: #023a51 !important;
	color: #ffffff !important;
	font: inherit !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
	padding: 0.9rem 1.4rem !important;
	cursor: pointer !important;
}

.kjcss-contact-popup-message {
	border-left: 4px solid #023a51 !important;
	background: #f3f7f9 !important;
	padding: 1rem !important;
	margin-bottom: 1rem !important;
}

.kjcss-contact-popup-modal {
	position: fixed !important;
	inset: 0 !important;
	z-index: 999999 !important;
	display: none !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 24px !important;
}

.kjcss-contact-popup-modal.is-open {
	display: flex !important;
}

.kjcss-contact-popup-overlay {
	position: absolute !important;
	inset: 0 !important;
	background: rgba(0, 0, 0, 0.5) !important;
}

.kjcss-contact-popup-dialog {
	position: relative !important;
	z-index: 2 !important;
	width: min(92vw, 720px) !important;
	max-height: 90vh !important;
	overflow-y: auto !important;
	background: #ffffff !important;
	border: 1pt solid #023a51 !important;
	border-radius: 20px !important;
	padding: 44px !important;
	box-shadow: 0 20px 70px rgba(0, 0, 0, 0.22) !important;
}

.kjcss-contact-popup-close {
	position: absolute !important;
	top: 12px !important;
	right: 14px !important;
	width: 38px !important;
	height: 38px !important;
	border: 1px solid #023a51 !important;
	border-radius: 999px !important;
	background: #ffffff !important;
	color: #023a51 !important;
	font-size: 1.6rem !important;
	line-height: 1 !important;
	cursor: pointer !important;
}

.kjcss-contact-popup-form {
	display: grid !important;
	gap: 0.85rem !important;
	width: 100% !important;
}

.kjcss-contact-popup-field {
	display: grid !important;
	gap: 0.35rem !important;
	font-weight: 700 !important;
	color: #023a51 !important;
}

.kjcss-contact-popup-field input,
.kjcss-contact-popup-field textarea {
	width: 100% !important;
	border: 1px solid #8f9ca3 !important;
	border-radius: 12px !important;
	background: #ffffff !important;
	color: #000000 !important;
	font: inherit !important;
	padding: 0.8rem 1rem !important;
}

.kjcss-contact-popup-field textarea {
	min-height: 150px !important;
	resize: vertical !important;
}

body.kjcss-contact-popup-open {
	overflow: hidden !important;
}

@media (max-width: 767px) {
	.kjcss-contact-popup-modal {
		padding: 12px !important;
	}

	.kjcss-contact-popup-dialog {
		width: 100% !important;
		max-height: 94vh !important;
		padding: 42px 18px 22px 18px !important;
	}
}

/* KJC Contact Popup: force readable Contact Form 7 label colours inside the modal */
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog label,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog p,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog span,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog div,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-form,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-form p,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-form label,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-form-control-wrap,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-list-item-label,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-not-valid-tip,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .kjcss-contact-popup-field,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .kjcss-contact-popup-field span {
	color: #023a51 !important;
}

.kjcss-contact-popup-modal .kjcss-contact-popup-dialog input,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog textarea,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog select {
	color: #000000 !important;
	background: #ffffff !important;
}

.kjcss-contact-popup-modal .kjcss-contact-popup-dialog input[type="submit"],
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog button[type="submit"],
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-submit {
	color: #ffffff !important;
}

.kjcss-contact-popup-modal .kjcss-contact-popup-close {
	color: #023a51 !important;
}

/* KJC Contact Popup: force visible submit button styling after input resets */
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog input[type="submit"],
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog button[type="submit"],
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-submit,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .kjcss-contact-popup-submit {
	appearance: none !important;
	-webkit-appearance: none !important;
	background: #023a51 !important;
	background-color: #023a51 !important;
	border: 1px solid #023a51 !important;
	border-radius: 999px !important;
	color: #ffffff !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
	padding: 0.9rem 1.4rem !important;
	cursor: pointer !important;
	box-shadow: none !important;
	text-decoration: none !important;
}

.kjcss-contact-popup-modal .kjcss-contact-popup-dialog input[type="submit"]:hover,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog input[type="submit"]:focus,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog button[type="submit"]:hover,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog button[type="submit"]:focus,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-submit:hover,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7-submit:focus,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .kjcss-contact-popup-submit:hover,
.kjcss-contact-popup-modal .kjcss-contact-popup-dialog .kjcss-contact-popup-submit:focus {
	background: #023a51 !important;
	background-color: #023a51 !important;
	border-color: #023a51 !important;
	color: #ffffff !important;
}


/* =========================================================
   CONTACT POPUP FINAL BUTTON LOCK
   Keeps CF7 submit buttons visible even when the theme styles inputs.
========================================================= */
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog form.wpcf7-form input.wpcf7-form-control.wpcf7-submit[type="submit"],
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog .wpcf7 input.wpcf7-submit[type="submit"],
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog input[type="submit"].wpcf7-submit,
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog input[type="submit"],
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog button[type="submit"],
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog .kjcss-contact-popup-submit {
	appearance: none !important;
	-webkit-appearance: none !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: auto !important;
	min-width: 140px !important;
	height: auto !important;
	min-height: 44px !important;
	padding: 0.85rem 1.35rem !important;
	margin-top: 0.5rem !important;
	background: #023a51 !important;
	background-color: #023a51 !important;
	background-image: none !important;
	border: 1px solid #023a51 !important;
	border-color: #023a51 !important;
	border-radius: 999px !important;
	box-shadow: none !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	font: inherit !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
	text-decoration: none !important;
	cursor: pointer !important;
	opacity: 1 !important;
}

html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog form.wpcf7-form input.wpcf7-form-control.wpcf7-submit[type="submit"]:hover,
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog form.wpcf7-form input.wpcf7-form-control.wpcf7-submit[type="submit"]:focus,
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog input[type="submit"]:hover,
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog input[type="submit"]:focus,
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog button[type="submit"]:hover,
html body .kjcss-contact-popup-wrap .kjcss-contact-popup-modal .kjcss-contact-popup-dialog button[type="submit"]:focus {
	background: #023a51 !important;
	background-color: #023a51 !important;
	background-image: none !important;
	border-color: #023a51 !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	opacity: 1 !important;
}

/* =========================================================
   AUDIO TESTIMONIAL SHORTCODE
========================================================= */

.kjcss-audio-testimonial {
	width: 100%;
	box-sizing: border-box;
}

.kjcss-audio-testimonial-title {
	margin: 0 0 8px 0;
	font-weight: 700;
	line-height: 1.2;
}

.kjcss-audio-testimonial-player {
	display: block;
	width: 100%;
	max-width: 100%;
}

.kjcss-audio-testimonial-link-wrap {
	margin: 8px 0 0 0;
}

.kjcss-audio-testimonial-link {
	display: inline-block;
	font-weight: 700;
	text-decoration: underline;
}

/* =========================================================
   POST GRAPHICS LIGHTTABLE, LMS MODAL PATTERN
========================================================= */

/* =========================================================
   POST GRAPHICS LIGHTBOX MODULE
   Uses the same dynamic lightbox pattern as KJC Student LMS.
========================================================= */

.kjcss-post-graphics,
.kjcss-post-graphics * {
	box-sizing: border-box;
}

.kjcss-post-graphics {
	width: 100%;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
	margin: 24px 0;
}

.kjcss-post-graphic-item {
	width: 100%;
}

.kjcss-post-graphic-image {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto !important;
	background: transparent !important;
	object-fit: contain !important;
	cursor: zoom-in !important;
	transition: transform .18s ease, opacity .18s ease;
}

.kjcss-post-graphic-image:hover,
.kjcss-post-graphic-image:focus-visible {
	transform: scale(1.015);
	outline: 2px solid #023a51;
	outline-offset: 3px;
}

body.kjc-lms-image-lightbox-open,
body.kjcss-post-graphic-lightbox-open {
	overflow: hidden;
}

.kjc-lms-image-lightbox {
	position: fixed;
	inset: 0;
	z-index: 2147483647;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 4vh 4vw;
	background: rgba(0, 0, 0, 0.5);
	box-sizing: border-box;
}

.kjc-lms-image-lightbox.is-open {
	display: flex !important;
}

.kjc-lms-image-lightbox__image {
	display: block;
	max-width: 90vw;
	max-height: 90vh;
	width: auto;
	height: auto;
	object-fit: contain;
	margin: auto;
	cursor: zoom-out;
	box-shadow: 0 18px 60px rgba(0, 0, 0, 0.35);
}

.kjc-lms-image-lightbox__close {
	position: absolute;
	top: 1rem;
	right: 1rem;
	width: 44px;
	height: 44px;
	border: 0;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.95);
	color: #333333;
	font-size: 2rem;
	line-height: 1;
	cursor: pointer;
	z-index: 2147483647;
}

.kjc-lms-image-lightbox__close:hover,
.kjc-lms-image-lightbox__close:focus {
	background: #ffffff;
	outline: 2px solid #ffffff;
	outline-offset: 2px;
}

@media (max-width: 767px) {
	.kjcss-post-graphics {
		grid-template-columns: 1fr;
	}

	.kjc-lms-image-lightbox {
		padding: 2vh 2vw;
	}

	.kjc-lms-image-lightbox__image {
		max-width: 96vw;
		max-height: 88vh;
	}
}

/* =========================================================
   TESTIMONIAL MAKER, CAROUSEL, EXCERPT, AND MODAL
   Added without changing the original testimonial background styling.
========================================================= */
.kjcss-testimonial-card,
.kjcss-testimonial-sidebar-card,
.kjcss-testimonial-carousel-wrap,
.kjcss-testimonial-carousel-wrap *,
.kjcss-testimonial-modal,
.kjcss-testimonial-modal * {
	box-sizing: border-box;
}

.kjcss-testimonial-open {
	display: block;
	width: 100%;
	min-height: 100%;
	padding: 0;
	margin: 0;
	border: 0;
	background: transparent;
	color: inherit;
	font: inherit;
	text-align: left;
	cursor: pointer;
}

.kjcss-testimonial-open:focus-visible {
	outline: 3px solid #023a51;
	outline-offset: 4px;
	border-radius: 18px;
}

.kjcss-testimonial-excerpt {
	font-size: 1rem;
	line-height: 1.55;
	margin: 0.75rem 0 1rem 0;
}

.kjcss-testimonial-text {
	font-size: 1rem;
	line-height: 1.55;
}

.kjcss-testimonial-read-more {
	display: inline-block;
	margin: 0 0 0.85rem 0;
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1.35;
	color: #023a51;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.kjcss-testimonial-open:hover .kjcss-testimonial-read-more,
.kjcss-testimonial-open:focus-visible .kjcss-testimonial-read-more {
	text-decoration-thickness: 2px;
}

.kjcss-testimonial-author-wrap {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	margin-top: 1rem;
}

.kjcss-testimonial-person span {
	display: block;
	margin-top: 0.35rem;
	line-height: 1.2;
}

.kjcss-testimonial-carousel-wrap {
	width: 100%;
	display: flex;
	align-items: stretch;
	gap: 14px;
	margin: 24px 0;
	background: transparent !important;
}

.kjcss-testimonial-carousel-track {
	display: flex;
	gap: 1.25rem;
	overflow-x: auto;
	scroll-behavior: smooth;
	scroll-snap-type: x mandatory;
	padding: 4px;
	width: 100%;
	background: transparent !important;
	scrollbar-width: thin;
}

.kjcss-testimonial-slide {
	flex: 0 0 calc((100% - 2.5rem) / 3);
	min-width: 260px;
	scroll-snap-align: start;
	display: flex;
	background: transparent !important;
}

.kjcss-testimonial-slide .kjcss-testimonial-card {
	width: 100%;
}

.kjcss-testimonial-nav {
	width: 44px;
	min-width: 44px;
	border-radius: 999px;
	border: 1px solid #d7d7d7;
	background: #ffffff;
	color: #023a51;
	cursor: pointer;
	font-size: 32px;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

.kjcss-testimonial-template {
	display: none !important;
}

.kjcss-testimonial-modal {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.kjcss-testimonial-modal.is-open {
	display: flex;
}

.kjcss-testimonial-modal-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.50);
}

.kjcss-testimonial-modal-dialog {
	position: relative;
	z-index: 2;
	width: min(760px, 92vw);
	max-height: 90vh;
	overflow-y: auto;
	background: #ffffff;
	color: #000000;
	border: 1px solid #023a51;
	border-radius: 20px;
	padding: 46px;
	box-shadow: 0 20px 70px rgba(0, 0, 0, 0.2);
}

.kjcss-testimonial-modal-close {
	position: sticky;
	top: 0;
	float: right;
	z-index: 5;
	width: 42px;
	height: 42px;
	border: 1px solid #023a51;
	background: #ffffff;
	color: #023a51;
	cursor: pointer;
	font-size: 2rem;
	line-height: 1;
	margin: -26px -26px 12px 12px;
}

.kjcss-testimonial-modal-layout {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: 28px;
	align-items: start;
}

.kjcss-testimonial-modal-photo {
	width: 140px;
	height: 140px;
	border-radius: 50%;
	object-fit: cover;
}

.kjcss-testimonial-modal-title {
	margin: 0.75rem 0 0.25rem 0;
	color: #023a51;
	line-height: 1.1;
}

.kjcss-testimonial-modal-role {
	margin: 0 0 1rem 0;
	color: #59667d;
	line-height: 1.2;
}

.kjcss-testimonial-modal-text,
.kjcss-testimonial-modal-text p {
	font-size: 1rem;
	line-height: 1.6;
	color: #000000;
}

body.kjcss-testimonial-modal-open {
	overflow: hidden;
}

@media (max-width: 900px) {
	.kjcss-testimonial-slide {
		flex-basis: calc((100% - 1.25rem) / 2);
	}
}

@media (max-width: 767px) {
	.kjcss-testimonial-carousel-wrap {
		gap: 8px;
	}

	.kjcss-testimonial-slide {
		flex-basis: 88%;
		min-width: 88%;
	}

	.kjcss-testimonial-nav {
		width: 38px;
		min-width: 38px;
		font-size: 27px;
	}

	.kjcss-testimonial-modal {
		padding: 0;
	}

	.kjcss-testimonial-modal-dialog {
		width: 100vw;
		max-width: 100vw;
		height: 100vh;
		max-height: 100vh;
		border-radius: 0;
		padding: 24px;
	}

	.kjcss-testimonial-modal-layout {
		grid-template-columns: 1fr;
		gap: 18px;
	}

	.kjcss-testimonial-modal-photo {
		width: 110px;
		height: 110px;
	}

	.kjcss-testimonial-modal-close {
		margin: 0 0 12px auto;
		display: block;
		float: none;
	}
}


/* =========================================================
   SKILL INVENTORY
========================================================= */

.kjcss-skill-inventory {
	width: 100%;
	margin: 1.25rem 0;
}

.kjcss-skill-inventory-title {
	color: #a63d40 !important;
	font-size: 1.15rem !important;
	font-weight: 800 !important;
	line-height: 1.2 !important;
	letter-spacing: 0.03em !important;
	margin: 0 0 0.85rem 0 !important;
	text-transform: uppercase !important;
}

.kjcss-skill-inventory-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	align-items: center;
}

.kjcss-skill-inventory-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #000000 !important;
	color: #ffffff !important;
	border-radius: 100px !important;
	padding: 0.55rem 1rem !important;
	font-size: 0.92rem !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
	white-space: nowrap;
}

.kjcss-skill-inventory-pill {
	border: 0 !important;
	cursor: pointer !important;
	font-family: inherit !important;
	appearance: none !important;
	-webkit-appearance: none !important;
}

.kjcss-skill-inventory-pill:hover,
.kjcss-skill-inventory-pill:focus {
	outline: 2px solid #a63d40 !important;
	outline-offset: 2px !important;
}

.kjcss-skill-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 999999;
	background: rgba(0, 0, 0, 0.5);
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.kjcss-skill-modal.is-open {
	display: flex;
}

.kjcss-skill-modal-dialog {
	width: min(640px, 100%);
	max-height: 85vh;
	overflow: auto;
	background: #ffffff;
	border: 1px solid #023a51;
	border-radius: 20px;
	padding: 28px;
	box-shadow: 0 18px 60px rgba(0, 0, 0, 0.28);
}

.kjcss-skill-modal-close {
	float: right;
	border: 0;
	background: #000000;
	color: #ffffff;
	width: 36px;
	height: 36px;
	border-radius: 100px;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
}

.kjcss-skill-modal-title {
	margin: 0 48px 0.85rem 0 !important;
	color: #a63d40 !important;
	font-size: 1.25rem !important;
	font-weight: 800 !important;
	line-height: 1.2 !important;
}

.kjcss-skill-modal-description {
	clear: both;
	color: #000000;
	font-size: 1rem;
	line-height: 1.6;
	white-space: pre-wrap;
}

body.kjcss-skill-modal-open {
	overflow: hidden;
}

@media (max-width: 767px) {
	.kjcss-skill-modal {
		padding: 12px;
	}

	.kjcss-skill-modal-dialog {
		padding: 22px;
	}
}

/* =========================================================
   SKILL INVENTORY HIERARCHY + ADMIN CLEANUP
========================================================= */

.kjcss-skill-inventory-groups {
	display: grid;
	gap: 1.1rem;
}

.kjcss-skill-inventory-group {
	width: 100%;
	background: #DDCBA4 !important;
	padding: 18px !important;
	border-radius: 20px !important;
}

.kjcss-skill-inventory-heading {
	margin: 0 0 0.55rem 0 !important;
	font-size: 1rem !important;
	font-weight: 800 !important;
	line-height: 1.25 !important;
	color: #000000 !important;
}

.kjcss-skills-admin .description {
	max-width: 980px;
}

.kjcss-skills-admin #col-container {
	margin-top: 18px;
}

.kjcss-skills-admin #col-left {
	width: 36%;
}

.kjcss-skills-admin #col-right {
	width: 62%;
}

.kjcss-skills-admin .col-wrap {
	background: #ffffff;
	border: 1px solid #c3c4c7;
	padding: 16px;
	box-sizing: border-box;
}

.kjcss-skills-admin .form-field input[type="text"],
.kjcss-skills-admin .form-field select,
.kjcss-skills-admin .form-field textarea {
	width: 100%;
	max-width: 100%;
}

.kjcss-skills-admin .form-field p {
	color: #646970;
}

.kjcss-skills-admin hr {
	margin: 22px 0;
}

.kjcss-skills-admin .kjcss-skills-table td,
.kjcss-skills-admin .kjcss-skills-table th {
	vertical-align: top;
}

@media screen and (max-width: 782px) {
	.kjcss-skills-admin #col-left,
	.kjcss-skills-admin #col-right {
		width: 100%;
		float: none;
	}

	.kjcss-skills-admin #col-right {
		margin-top: 18px;
	}
}

.kjcss-skills-admin .kjcss-skills-parent-checklist {
	max-height: 220px;
	overflow: auto;
	border: 1px solid #c3c4c7;
	background: #fff;
	padding: 8px 10px;
}

.kjcss-skills-admin .kjcss-skills-parent-checklist label {
	display: block;
	margin: 0 0 8px 0;
	line-height: 1.35;
}

.kjcss-skills-admin .kjcss-skills-bulk-form .tablenav {
	margin: 6px 0 8px 0;
}

.kjcss-skills-admin .column-cb {
	width: 2.2em;
}

/* =========================================================
   SKILL INVENTORY BULK ACTIONS
========================================================= */

.kjcss-skills-admin .kjcss-skills-bulk-toolbar {
	background: #ffffff;
	border: 1px solid #c3c4c7;
	padding: 10px;
	margin: 8px 0 12px 0;
}

.kjcss-skills-admin .kjcss-skills-bulk-toolbar .bulkactions select {
	max-width: 260px;
}

.kjcss-skills-admin .kjcss-bulk-parent-actions {
	margin-top: 10px;
	width: 100%;
}

.kjcss-skills-admin .kjcss-skills-parent-checklist-inline {
	max-height: 120px;
	margin-top: 6px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px 14px;
	align-items: center;
}

.kjcss-skills-admin .kjcss-skills-parent-checklist-inline label {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	margin: 0;
	white-space: nowrap;
}
