/* =============================================================
   krscms-inline.css
   All extracted <style> blocks and converted inline styles
   from KRSCMS PHP pages.
   ============================================================= */

/* ─────────────────────────────────────────────
   CONVERTED INLINE STYLES → CLASSES
   ───────────────────────────────────────────── */

/* eligibility.php — doc check images */
.doc-check-img { width: 50px; height: 50px; }

/* certificate-of-accreditation.php */
#pdfViewerContainer { display: none; }
.pdf-sticky-card { top: 20px; }
.pdf-viewer-body { height: 600px; overflow: hidden; }
#pdfFrame { width: 100%; height: 100%; border: none; }

/* NAAC Cycle 1 / Certificate of Accreditation — documents table */
.kr-naac-docs-table-wrap {
	background: #fff;
	border: 1px solid #dee2e6;
	border-radius: 4px;
	overflow: hidden;
}
.kr-naac-docs-table-scroll {
	width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}
.kr-naac-docs-table {
	width: 100%;
	margin: 0;
	border-collapse: collapse;
	border-spacing: 0;
	font-family: "Poppins", sans-serif;
}
.kr-naac-docs-table thead th {
	background: #f8f9fa;
	color: #000;
	font-weight: 700;
	font-size: 0.92rem;
	padding: 16px 18px;
	border: 1px solid #dee2e6;
	text-align: left;
	vertical-align: middle;
}
.kr-naac-docs-table thead th:first-child {
	width: 56px;
}
.kr-naac-docs-table thead th:last-child {
	width: 120px;
}
.kr-naac-docs-table tbody td {
	padding: 16px 18px;
	border: 1px solid #dee2e6;
	color: #212529;
	font-size: 0.94rem;
	line-height: 1.5;
	vertical-align: middle;
	text-align: left;
	background: #fff;
}
.kr-naac-docs-table tbody td:first-child {
	width: 56px;
	color: #212529;
}
.kr-naac-docs-table tbody td:last-child {
	width: 120px;
	color: #6c757d;
}
.kr-naac-docs-title {
	display: block;
	color: #212529;
	font-weight: 400;
}
.kr-naac-docs-desc {
	font-size: 0.84rem;
	color: #6c757d;
	margin-top: 0.35rem;
	line-height: 1.45;
}
.kr-naac-docs-dash {
	color: #6c757d;
	font-size: 1rem;
}
.kr-naac-docs-pdf-link {
	color: #dc3545;
	font-size: 1.1rem;
	text-decoration: none;
}
.kr-naac-docs-pdf-link:hover {
	color: #b02a37;
}
.kr-naac-docs-doc-actions {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.kr-naac-docs-doc-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	border: 1px solid #dee2e6;
	border-radius: 6px;
	background: #fff;
	color: #495057;
	font-size: 0.85rem;
	cursor: pointer;
	transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
}
.kr-naac-docs-doc-btn:hover {
	border-color: #adb5bd;
	color: #212529;
	background: #f8f9fa;
}
@media (max-width: 767.98px) {
	.kr-naac-docs-table thead th,
	.kr-naac-docs-table tbody td {
		padding: 12px 14px;
		font-size: 0.88rem;
	}
	.kr-naac-docs-table {
		min-width: 520px;
	}
}

/* naac-cycle2.php */
.toggle-content { display: none; }
.th-num  { width: 40px; }
.th-doc  { width: 100px; }

/* bca.php / about-bca.php / mba.php — programme pages */
.prog-featured-img { max-height: 360px; object-fit: cover; }
.prog-info-label   { font-size: .72rem; text-transform: uppercase; letter-spacing: .5px; }
.prog-info-value   { font-size: .9rem; }

/* Programme pages (MBA/BCA) — modern + professional (scoped) */
body.kr-programme-page {
	--kr-prog-ink: #0f172a;
	--kr-prog-text: #334155;
	--kr-prog-muted: #64748b;
	--kr-prog-border: rgba(15, 23, 42, 0.10);
	--kr-prog-shadow: 0 16px 44px rgba(15, 23, 42, 0.08);
	--kr-prog-accent: #e56500; /* orange accent (match admission) */
	--kr-prog-accent-soft: rgba(229, 101, 0, 0.10);
}

body.kr-programme-page .cms-content {
	color: var(--kr-prog-text);
	line-height: 1.85;
	font-size: 1.02rem;
	font-family: "Poppins", sans-serif;
}
body.kr-programme-page .cms-content h2 {
	font-size: clamp(1.28rem, 2.35vw, 1.62rem);
	font-weight: 900;
	letter-spacing: -0.025em;
	color: var(--kr-prog-ink);
	margin: 1.85rem 0 0.9rem;
	position: relative;
}
body.kr-programme-page .cms-content h2::after {
	content: "";
	display: block;
	width: 64px;
	height: 3px;
	border-radius: 3px;
	margin-top: 0.55rem;
	background: linear-gradient(90deg, var(--kr-prog-accent), rgba(229, 101, 0, 0.65));
	opacity: 0.9;
}
body.kr-programme-page .cms-content h3 {
	font-size: 1.08rem;
	font-weight: 850;
	color: var(--kr-prog-accent);
	margin: 1.35rem 0 0.65rem;
	letter-spacing: -0.01em;
}
body.kr-programme-page .cms-content p {
	margin-bottom: 1.05rem;
}
body.kr-programme-page .cms-content ul {
	padding-left: 1.25rem;
	margin: 0.75rem 0 1.1rem;
}
body.kr-programme-page .cms-content li {
	margin-bottom: 0.45rem;
}
body.kr-programme-page .cms-content a {
	color: var(--kr-prog-accent);
	font-weight: 800;
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
}
body.kr-programme-page .cms-content a:hover {
	color: #cc4f00;
}

/* Sidebar cards: cleaner + premium */
body.kr-programme-page .card.box-shadow-1.custom-border-radius-1 {
	border-radius: 18px;
	border: 1px solid var(--kr-prog-border);
	box-shadow: var(--kr-prog-shadow);
}
body.kr-programme-page .card.box-shadow-1.custom-border-radius-1 .card-body {
	padding-top: 1.15rem !important;
	padding-bottom: 1.15rem !important;
}
body.kr-programme-page .card.bg-primary.custom-border-radius-1 {
	border-radius: 18px;
	box-shadow: 0 18px 54px rgba(15, 23, 42, 0.14);
	position: relative;
	overflow: hidden;
}
body.kr-programme-page .card.bg-primary.custom-border-radius-1::before {
	content: "";
	position: absolute;
	inset: -40% -40% auto auto;
	width: 260px;
	height: 260px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(255,255,255,0.18), transparent 65%);
	pointer-events: none;
}

/* Micro polish: list link hover + rhythm */
body.kr-programme-page .custom-nav-list-effect-1 a {
	font-weight: 700;
}
body.kr-programme-page .custom-nav-list-effect-1 a:hover {
	color: var(--kr-prog-accent) !important;
}

/* Programme info tiles (Duration, Eligibility, etc.) */
body.kr-programme-page .kr-prog-info-card {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(248, 250, 252, 0.92));
	border: 1px solid rgba(15, 23, 42, 0.08);
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
	border-radius: 14px;
}
body.kr-programme-page .kr-prog-info-icon {
	color: var(--kr-prog-accent);
}
body.kr-programme-page .kr-prog-info-label {
	font-size: 0.7rem;
	font-weight: 900;
	color: var(--kr-prog-muted);
	letter-spacing: 0.14em;
	text-transform: uppercase;
}
body.kr-programme-page .kr-prog-info-value {
	display: block;
	color: var(--kr-prog-ink);
	font-weight: 900;
	letter-spacing: -0.01em;
	font-size: 0.98rem;
}

/* Section titles above cms-content */
body.kr-programme-page .kr-prog-section-title {
	font-weight: 900;
	letter-spacing: -0.02em;
	color: var(--kr-prog-ink);
	margin-bottom: 0.6rem;
	font-size: clamp(1.25rem, 1.6vw, 1.55rem);
}

/* Programme pages — mobile layout tightening (no floating/sticky elements) */
@media (max-width: 767.98px) {
	body.kr-programme-page .section.section-height-1.bg-primary.border-0.m-15 {
		margin: 0 !important;
	}

	body.kr-programme-page .container.my-5.pt-4.pb-5 {
		margin-top: 1.1rem !important;
		padding-top: 0.75rem !important;
		padding-bottom: 2.25rem !important;
	}

	body.kr-programme-page .kr-prog-info-grid {
		margin-bottom: 1.1rem !important;
	}

	/* Content should read like an article on mobile (not centered) */
	body.kr-programme-page .cms-content {
		font-size: 0.98rem;
		line-height: 1.78;
		text-align: left;
	}
	body.kr-programme-page .cms-content h2,
	body.kr-programme-page .cms-content h3 {
		text-align: left;
	}

	/* Lists: keep bullets close to text */
	body.kr-programme-page .cms-content ul,
	body.kr-programme-page .cms-content ol {
		padding-left: 1.15rem;
		margin-left: 0;
	}
	body.kr-programme-page .cms-content li {
		margin-bottom: 0.55rem;
	}
}

/* Admission pages — same clean blocks (scoped) */
body.kr-admission-page {
	--kr-adm-ink: #0f172a;
	--kr-adm-text: #334155;
	--kr-adm-muted: #64748b;
	--kr-adm-border: rgba(15, 23, 42, 0.10);
	--kr-adm-shadow: 0 16px 44px rgba(15, 23, 42, 0.08);
	--kr-adm-accent: #e56500; /* orange accent (match programme underline) */
}
body.kr-admission-page .cms-content {
	color: var(--kr-adm-text);
	line-height: 1.85;
	font-size: 1.02rem;
	font-family: "Poppins", sans-serif;
}
body.kr-admission-page .cms-content h2,
body.kr-admission-page .cms-content h3,
body.kr-admission-page .cms-content h4 {
	color: var(--kr-adm-ink);
	font-weight: 900;
	letter-spacing: -0.02em;
	margin: 1.55rem 0 0.75rem;
}
body.kr-admission-page .cms-content h2 {
	font-size: clamp(1.28rem, 2.35vw, 1.62rem);
	position: relative;
	color: var(--kr-adm-accent);
}
body.kr-admission-page .cms-content h2::after {
	content: "";
	display: block;
	width: 64px;
	height: 3px;
	border-radius: 3px;
	margin-top: 0.55rem;
	background: linear-gradient(90deg, var(--kr-adm-accent), rgba(229, 101, 0, 0.65));
	opacity: 0.9;
}
/* Make common admission section titles match programme h3 look */
body.kr-admission-page .cms-content h3,
body.kr-admission-page .cms-content h4.text-primary {
	color: var(--kr-adm-accent) !important;
	font-size: 1.08rem;
	font-weight: 850;
	letter-spacing: -0.01em;
	margin: 1.35rem 0 0.65rem;
}
body.kr-admission-page .cms-content h4 {
	color: var(--kr-adm-accent);
	font-weight: 850;
	letter-spacing: -0.01em;
}
body.kr-admission-page .cms-content strong {
	color: var(--kr-adm-accent);
	font-weight: 900;
}
body.kr-admission-page .cms-content ul {
	padding-left: 1.25rem;
	margin: 0.75rem 0 1.1rem;
}
body.kr-admission-page .cms-content li {
	margin-bottom: 0.45rem;
}
body.kr-admission-page .cms-content a {
	color: var(--kr-adm-accent);
	font-weight: 800;
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
}
body.kr-admission-page .cms-content a:hover {
	color: #a90016;
}
body.kr-admission-page .table-responsive {
	border-radius: 14px;
	border: 1px solid var(--kr-adm-border);
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
	background: #fff;
}
body.kr-admission-page .table {
	margin-bottom: 0;
}
body.kr-admission-page .table thead th {
	border-bottom: 1px solid rgba(15, 23, 42, 0.12);
	color: var(--kr-adm-ink);
	font-weight: 900;
}
body.kr-admission-page .table td,
body.kr-admission-page .table th {
	vertical-align: middle;
}
body.kr-admission-page .accordion .card {
	border-radius: 14px !important;
	border: 1px solid var(--kr-adm-border) !important;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
	overflow: hidden;
}
body.kr-admission-page .accordion .card + .card {
	margin-top: 0.9rem;
}

/* Why KRSCMS page — article + highlights (scoped; desktop + mobile) */
body.kr-why-krscms-page {
	--kr-why-ink: #0f172a;
	--kr-why-text: #334155;
	--kr-why-accent: #e56500;
}
body.kr-why-krscms-page .kr-why-content {
	color: var(--kr-why-text);
	line-height: 1.85;
	font-size: 1.02rem;
	font-family: "Poppins", sans-serif;
}
body.kr-why-krscms-page .kr-why-content p {
	margin-bottom: 1rem;
}
body.kr-why-krscms-page .kr-why-content h2 {
	color: var(--kr-why-ink);
	font-weight: 900;
	font-size: 1.35rem;
	letter-spacing: -0.02em;
	margin: 1.65rem 0 0.75rem;
	padding-bottom: 0.35rem;
	border-bottom: 2px solid rgba(229, 101, 0, 0.35);
}
body.kr-why-krscms-page .kr-why-content h2:first-of-type {
	margin-top: 0.25rem;
}
body.kr-why-krscms-page .kr-why-content ul {
	padding-left: 1.25rem;
	margin: 0.5rem 0 1.1rem;
}
body.kr-why-krscms-page .kr-why-content li {
	margin-bottom: 0.5rem;
}
body.kr-why-krscms-page .kr-why-content strong {
	color: var(--kr-why-ink);
	font-weight: 800;
}
body.kr-why-krscms-page .kr-why-highlights-card {
	border-radius: 12px;
	border: 1px solid rgba(15, 23, 42, 0.08) !important;
}
body.kr-why-krscms-page .kr-why-highlights-card ul li {
	font-size: 0.95rem;
	line-height: 1.5;
}
@media (max-width: 767.98px) {
	body.kr-why-krscms-page .section.section-height-1.bg-primary.border-0.m-0 {
		margin: 0 !important;
	}
	body.kr-why-krscms-page .container.my-5.pt-2.pb-5 {
		margin-top: 1.1rem !important;
		padding-top: 0.75rem !important;
		padding-bottom: 2.25rem !important;
	}
	body.kr-why-krscms-page .kr-why-content {
		font-size: 0.98rem;
		line-height: 1.78;
		text-align: left;
	}
	body.kr-why-krscms-page .kr-why-content h2 {
		font-size: 1.12rem;
		margin-top: 1.35rem;
	}
	body.kr-why-krscms-page .kr-why-content ul {
		padding-left: 1.15rem;
	}
	body.kr-why-krscms-page .kr-why-highlights-card {
		padding: 1rem 1.1rem !important;
	}
}

/* Porto theme animation-delay helpers (data-appear-animation driven) */
.anim-delay-100 { animation-delay: 100ms; }
.anim-delay-300 { animation-delay: 300ms; }
.anim-delay-500 { animation-delay: 500ms; }
.anim-delay-800 { animation-delay: 800ms; }

/* _marquee_admission_popup.php */
.marquee-item-clickable { cursor: pointer; margin: 0 15px; }

/* about.php — stats bar */
.stat-icon  { font-size: 1.8rem; }
.stat-value { font-size: 1.6rem; font-weight: 800; }
.stat-label { font-size: .85rem; }

/* about.php — layout helpers */
.pt-0-force   { padding-top: 0 !important; }
.about-img-col { margin-top: -1px; padding-top: 100px; }
.about-img-wrap { position: relative; padding-bottom: 0; padding-right: 12px; }
.about-img-overlay {
    position: absolute; bottom: 0; right: 0;
    width: 100%; height: 100%;
    background: #e56500; border-radius: 16px;
    opacity: .12; z-index: 0;
}
.about-main-img {
    display: block; width: 100%; height: 420px;
    object-fit: cover; border-radius: 16px;
    box-shadow: 0 10px 30px rgba(0,0,0,.12);
    position: relative; z-index: 1;
    transform: none !important;
}
.vm-icon      { font-size: 1.5rem; }
.divider-short { width: 60px; }
.highlight-bg   { background: #f8f9fa; }
.highlight-icon { font-size: 1.2rem; flex-shrink: 0; }
.highlight-text { font-size: .95rem; }
.director-img   { max-width: 180px; aspect-ratio: 1; object-fit: cover; }

/* director-message — signature styling (no card/background) */
.kr-director-signature {
	margin: 0;
	padding: 0;
}
.kr-director-signature__name {
	color: #7b0010; /* sober maroon */
	font-weight: 900;
}
.kr-director-signature__qual {
	color: #4b5563;
	font-weight: 600;
}
.kr-director-signature__role {
	color: #7b0010; /* sober maroon */
	font-weight: 800;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	font-size: 0.9rem;
}
/* contact.php — KPI info cards (site UI: dark border + maroon accent) */
.contact-info-card {
	background: #fff;
	border-radius: 6px;
	padding: 24px 20px 20px;
	height: 100%;
	border: 1.6px solid rgba(15, 23, 42, 0.55);
	box-shadow: 0 4px 16px rgba(15, 23, 42, 0.07);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	gap: 0;
	min-height: 200px;
	overflow: visible;
}

/* contact.php — message form */
.contact-form-card {
	background: #fff;
	border-radius: 14px;
	border: 1px solid rgba(15, 23, 42, 0.10);
	box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
	padding: 42px 40px;
}
.contact-form-title {
	font-weight: 900;
	color: #0f172a;
	margin-bottom: 24px;
	letter-spacing: -0.01em;
}
.contact-field {
	border-radius: 12px;
	padding: 14px 16px;
	border: 1.6px solid rgba(15, 23, 42, 0.16);
	background: #fff;
	font-size: .95rem;
	line-height: 1.3;
	transition: box-shadow .2s ease, border-color .2s ease;
}
.contact-field:focus {
	border-color: rgba(123, 0, 16, 0.55);
	box-shadow: 0 0 0 4px rgba(123, 0, 16, 0.10);
	outline: none;
}
.contact-field--textarea {
	resize: vertical;
	min-height: 150px;
}
.contact-submit-btn {
	border-radius: 999px;
	border: none;
	background: linear-gradient(135deg, #7b0010, #a90016);
	box-shadow: 0 10px 22px rgba(123, 0, 16, 0.24);
	font-size: 0.98rem;
	letter-spacing: 0.06em;
	padding-left: 28px;
	padding-right: 28px;
}
.contact-submit-btn:hover {
	filter: brightness(1.03);
}

@media (max-width: 575.98px) {
	.contact-form-card { padding: 30px 20px; border-radius: 12px; }
	.contact-form-title { margin-bottom: 18px; }
}
.contact-info-card:hover {
	transform: translateY(-2px);
	border-color: rgba(123, 0, 16, 0.55);
	box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}
.contact-icon-box {
	width: auto;
	height: auto;
	border-radius: 0;
	background: transparent;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 14px;
	box-shadow: none;
	flex-shrink: 0;
}
.contact-icon-box i {
	color: #7b0010;
	font-size: 1.48rem;
	opacity: 0.94;
}
.contact-info-title {
	font-weight: 900;
	color: #0f172a;
	margin-bottom: 10px;
	font-size: 1.02rem;
	letter-spacing: -0.01em;
	text-transform: none;
}
.contact-info-text {
	color: #475569;
	line-height: 1.6;
	margin-bottom: 10px;
	font-size: 0.93rem;
	max-width: 18rem;
	width: 100%;
	word-break: break-word;
	overflow-wrap: anywhere;
}
.contact-info-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	color: #7b0010;
	font-weight: 700;
	font-size: 0.78rem;
	text-decoration: none;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-top: auto;
	padding-top: 10px;
}
.contact-info-link i { font-size: 0.72rem; transition: transform 0.15s ease; }
.contact-info-link:hover {
	color: #a90016;
	text-decoration: none;
}
.contact-info-link:hover i { transform: translateX(2px); }

@media (max-width: 575.98px) {
	.contact-info-card {
		padding: 22px 16px 20px;
		min-height: 0;
		border-radius: 6px;
		border: 1.6px solid rgba(15, 23, 42, 0.55);
		box-shadow: 0 3px 12px rgba(15, 23, 42, 0.06);
	}
	.contact-icon-box { margin-bottom: 12px; }
	.contact-icon-box i { font-size: 1.35rem; }
	.contact-info-title { font-size: 0.98rem; margin-bottom: 8px; }
	.contact-info-text { font-size: 0.9rem; max-width: 100%; margin-bottom: 8px; }
	.contact-info-link { font-size: 0.75rem; padding-top: 8px; }
}

/* Contact page — KPI cards */
body.kr-contact-page .kr-contact-cards {
	--bs-gutter-y: 1.25rem;
	--bs-gutter-x: 1.15rem;
}
body.kr-contact-page .contact-info-card {
	min-height: 198px;
}
body.kr-contact-page .kr-contact-cards > [class*="col-"] {
	display: flex;
}
body.kr-contact-page .kr-contact-cards .contact-info-card {
	width: 100%;
}
/* contact.php — social icon hover */
.contact-social-icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; text-decoration: none;
    font-size: .9rem;
    box-shadow: 0 4px 12px rgba(0,0,0,.15);
    transition: transform .2s, box-shadow .2s;
}
.contact-social-icon:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(0,0,0,.2);
    color: #fff;
}

/* photo.php — video gallery */
.video-placeholder-icon  { font-size: 3rem; color: rgba(255,255,255,0.3); }
.uploaded-video-player   { width: 100%; border-radius: 8px; max-height: 70vh; }
.gallery-date            { font-size: .75rem; }

/* achievements.php */
.ach-stat-value { font-size: 1.3rem; }
.ach-icon-placeholder-hidden { display: none; }

/* index.php — section backgrounds */
.section-bg-light       { background: linear-gradient(160deg, #f8f9ff 0%, #eef1f8 100%); }
.section-bg-dark        { background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%) !important; overflow: hidden; position: relative; }
.section-faq            { background: linear-gradient(135deg, #f8f9ff 0%, #eef1f8 100%); padding: 80px 0; }


/* =============================================================
   EXTRACTED <style> BLOCKS FROM PHP FILES
   ============================================================= */

/* ── achievements.php ── */
.ach-card {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(15,20,60,.08);
    overflow: hidden;
    transition: transform .3s, box-shadow .3s;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.ach-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 48px rgba(15,20,60,.15);
}
.ach-img-wrap {
    position: relative;
    width: 100%;
    padding-top: 56%;
    overflow: hidden;
    background: linear-gradient(135deg, #1a1a2e, #0f3460);
    flex-shrink: 0;
}
.ach-img-wrap img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
}
.ach-card:hover .ach-img-wrap img { transform: scale(1.05); }
.ach-icon-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    color: rgba(255,255,255,.25);
}
.ach-year-badge {
    position: absolute;
    top: 12px;
    right: 12px;
    background: rgba(229,101,0,.9);
    color: #fff;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .8px;
    padding: 4px 10px;
    border-radius: 50px;
}
.ach-body {
    padding: 20px 22px 22px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.ach-title {
    font-size: 1rem;
    font-weight: 700;
    color: #0d1b3e;
    margin-bottom: 8px;
    line-height: 1.35;
}
.ach-desc {
    font-size: .88rem;
    color: #6b7280;
    line-height: 1.7;
    flex: 1;
}
.ach-icon-strip {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid #f3f4f6;
}
.ach-icon-strip i {
    color: #e56500;
    font-size: .9rem;
}
.ach-icon-strip span {
    font-size: .75rem;
    font-weight: 600;
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.ach-stats-bar {
    background: linear-gradient(135deg, #0f3460, #1a1a2e);
    border-radius: 16px;
    padding: 32px 40px;
    margin-bottom: 48px;
}
.ach-stat-item { text-align: center; }
.ach-stat-item strong {
    display: block;
    font-size: 2rem;
    font-weight: 800;
    color: #fff;
    line-height: 1;
}
.ach-stat-item span {
    font-size: .75rem;
    color: rgba(255,255,255,.55);
    letter-spacing: 1px;
    text-transform: uppercase;
}
.ach-empty {
    text-align: center;
    padding: 80px 20px;
    color: #9ca3af;
}
.ach-empty i { font-size: 3.5rem; margin-bottom: 16px; display: block; opacity: .3; }

/* ── annual-reports.php / audit-reports.php (shared) ── */
.report-table-wrap { border-radius: 12px; overflow: hidden; box-shadow: 0 3px 20px rgba(15,20,60,.07); }
.report-table { width: 100%; border-collapse: collapse; background: #fff; }
.report-table thead tr { background: linear-gradient(135deg, #0f3460, #1a1a2e); }
.report-table thead th { color: #fff; font-size: .82rem; font-weight: 600; padding: 14px 18px; text-align: left; white-space: nowrap; }
.report-table tbody tr { border-bottom: 1px solid #f0f2f8; transition: background .2s; }
.report-table tbody tr:last-child { border-bottom: none; }
.report-table tbody tr:hover { background: #f8f9ff; }
.report-table tbody td { padding: 14px 18px; font-size: .88rem; color: #374151; vertical-align: middle; }
.rpt-sr { font-weight: 700; color: #9ca3af; font-size: .8rem; width: 40px; }
.rpt-title { font-weight: 600; color: #0d1b3e; }
.rpt-desc { color: #6b7280; font-size: .82rem; margin-top: 3px; }
.rpt-year-badge { display: inline-block; background: #f0f4ff; color: #1846a6; font-size: .75rem; font-weight: 600; padding: 3px 10px; border-radius: 50px; white-space: nowrap; }
.rpt-pdf-btn { display: inline-flex; align-items: center; gap: 6px; background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; border-radius: 6px; padding: 6px 14px; font-size: .8rem; font-weight: 600; text-decoration: none; transition: background .2s, color .2s; white-space: nowrap; }
.rpt-pdf-btn:hover { background: #dc2626; color: #fff; border-color: #dc2626; }
.rpt-empty { text-align: center; padding: 60px 20px; color: #9ca3af; }
.rpt-empty i { font-size: 3rem; margin-bottom: 12px; display: block; opacity: .3; }

/* ── blog.php — public listing + detail (CSS only; maroon + orange) */
body.kr-blog-page {
	--kr-blog-ink: #0f172a;
	--kr-blog-text: #334155;
	--kr-blog-muted: #64748b;
	--kr-blog-border: rgba(15, 23, 42, 0.10);
	--kr-blog-shadow: 0 10px 28px rgba(15, 23, 42, 0.07);
	--kr-blog-maroon: #7b0010;
	--kr-blog-maroon-hover: #a90016;
	--kr-blog-accent: #e56500;
	font-family: "Poppins", sans-serif;
}

/* Compact page header (reduced height) */
body.kr-blog-page .page-header.page-header-modern.page-header-md {
	padding: 24px 0 20px !important;
	min-height: 0;
	background: linear-gradient(180deg, #ffffff 0%, #faf7f7 100%);
	border-bottom: 1px solid rgba(123, 0, 16, 0.1);
}
body.kr-blog-page .page-header.page-header-modern .p-static {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}
body.kr-blog-page .page-header.page-header-modern h1 {
	letter-spacing: -0.02em;
	font-size: 1.65rem !important;
	line-height: 1.25;
	margin: 0;
}
body.kr-blog-page .page-header.page-header-modern h1::after {
	content: "";
	display: block;
	width: 52px;
	height: 3px;
	border-radius: 3px;
	margin: 0.45rem auto 0;
	background: linear-gradient(90deg, var(--kr-blog-maroon), var(--kr-blog-accent));
	opacity: 0.95;
}
body.kr-blog-page .page-header .breadcrumb {
	margin: 0.35rem 0 0;
	padding: 0;
	font-size: 0.82rem;
}
body.kr-blog-page .breadcrumb a {
	color: var(--kr-blog-ink);
	font-weight: 600;
}
body.kr-blog-page .breadcrumb a:hover {
	color: var(--kr-blog-maroon);
}
body.kr-blog-page .breadcrumb .active {
	color: var(--kr-blog-muted);
}

/* Main content spacing */
body.kr-blog-page .main > .container.py-5 {
	padding-top: 1.65rem !important;
	padding-bottom: 2.25rem !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

body.kr-blog-page .filter-bar {
	background: #fff;
	border-radius: 12px;
	padding: 16px 18px;
	border: 1px solid var(--kr-blog-border);
	box-shadow: var(--kr-blog-shadow);
	margin-bottom: 1.5rem;
}
body.kr-blog-page .filter-bar .form-control:focus,
body.kr-blog-page .filter-bar .form-select:focus {
	border-color: rgba(123, 0, 16, 0.45);
	box-shadow: 0 0 0 3px rgba(123, 0, 16, 0.1);
}
body.kr-blog-page .filter-bar .btn-primary {
	background: linear-gradient(135deg, var(--kr-blog-maroon), var(--kr-blog-maroon-hover));
	border-color: var(--kr-blog-maroon);
	font-weight: 700;
	letter-spacing: 0.03em;
}
body.kr-blog-page .filter-bar .btn-primary:hover {
	filter: brightness(1.05);
	border-color: var(--kr-blog-maroon-hover);
}
body.kr-blog-page .filter-bar .btn-outline-secondary {
	border-color: rgba(15, 23, 42, 0.18);
	color: var(--kr-blog-text);
}

body.kr-blog-page .blog-card {
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-top: 3px solid var(--kr-blog-maroon);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: var(--kr-blog-shadow);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
	background: #fff;
}
body.kr-blog-page .blog-card:hover {
	transform: translateY(-3px);
	border-top-color: var(--kr-blog-accent);
	border-color: rgba(123, 0, 16, 0.22);
	box-shadow: 0 16px 36px rgba(15, 23, 42, 0.11);
}
body.kr-blog-page .blog-card-img {
	width: 100%;
	height: 190px;
	object-fit: cover;
}
body.kr-blog-page .blog-card-img-placeholder {
	width: 100%;
	height: 190px;
	background:
		radial-gradient(circle at 18% 22%, rgba(123, 0, 16, 0.08), transparent 52%),
		radial-gradient(circle at 82% 78%, rgba(229, 101, 0, 0.1), transparent 48%),
		linear-gradient(160deg, #f8f9fb, #fff);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(123, 0, 16, 0.25);
}
body.kr-blog-page .blog-card-body {
	padding: 18px 18px 16px;
	flex: 1;
	display: flex;
	flex-direction: column;
}
body.kr-blog-page .blog-card-category {
	font-size: 0.7rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.09em;
	color: var(--kr-blog-maroon);
	margin-bottom: 6px;
}
body.kr-blog-page .blog-card-title {
	font-size: 1.02rem;
	font-weight: 800;
	color: var(--kr-blog-ink);
	line-height: 1.35;
	margin-bottom: 8px;
	letter-spacing: -0.01em;
}
body.kr-blog-page .blog-card-title a { color: inherit; text-decoration: none; }
body.kr-blog-page .blog-card-title a:hover { color: var(--kr-blog-maroon); }
body.kr-blog-page .blog-card-excerpt {
	font-size: 0.88rem;
	color: var(--kr-blog-text);
	line-height: 1.6;
	margin-bottom: 12px;
	flex: 1;
}
body.kr-blog-page .blog-card-meta {
	font-size: 0.76rem;
	color: var(--kr-blog-muted);
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	align-items: center;
}
body.kr-blog-page .blog-card-meta i {
	color: var(--kr-blog-maroon);
	opacity: 0.75;
}
body.kr-blog-page .blog-read-more {
	font-size: 0.8rem;
	font-weight: 800;
	color: var(--kr-blog-maroon);
	text-decoration: none;
	margin-top: auto;
	padding-top: 8px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
body.kr-blog-page .blog-read-more:hover {
	color: var(--kr-blog-accent);
}

body.kr-blog-page .pagination .page-link {
	color: var(--kr-blog-maroon);
	border-radius: 8px;
	margin: 0 2px;
	border-color: rgba(15, 23, 42, 0.12);
}
body.kr-blog-page .pagination .page-link:hover {
	background: rgba(123, 0, 16, 0.06);
	color: var(--kr-blog-maroon-hover);
}
body.kr-blog-page .pagination .page-item.active .page-link {
	background: linear-gradient(135deg, var(--kr-blog-maroon), var(--kr-blog-maroon-hover));
	border-color: var(--kr-blog-maroon);
	color: #fff;
}
body.kr-blog-page .no-blogs {
	text-align: center;
	padding: 48px 20px;
	color: var(--kr-blog-muted);
	border: 1px dashed rgba(123, 0, 16, 0.2);
	border-radius: 12px;
	background: linear-gradient(180deg, #fff, #faf8f8);
}
body.kr-blog-page .no-blogs i {
	font-size: 2.5rem;
	margin-bottom: 12px;
	display: block;
	color: var(--kr-blog-maroon);
	opacity: 0.45;
}
body.kr-blog-page .no-blogs .btn-primary {
	background: linear-gradient(135deg, var(--kr-blog-maroon), var(--kr-blog-maroon-hover));
	border-color: var(--kr-blog-maroon);
}

/* Blog detail (same body class) */
body.kr-blog-page .blog-detail-wrap .text-muted.small:hover {
	color: var(--kr-blog-maroon) !important;
}
body.kr-blog-page .blog-title {
	color: var(--kr-blog-ink);
}
body.kr-blog-page .blog-title::after {
	content: "";
	display: block;
	width: 64px;
	height: 3px;
	margin-top: 0.5rem;
	border-radius: 3px;
	background: linear-gradient(90deg, var(--kr-blog-maroon), var(--kr-blog-accent));
}
body.kr-blog-page .blog-content blockquote {
	border-left-color: var(--kr-blog-maroon);
}
body.kr-blog-page .related-card-title a:hover {
	color: var(--kr-blog-maroon);
}

@media (max-width: 767.98px) {
	body.kr-blog-page .page-header.page-header-modern.page-header-md {
		padding: 18px 0 16px !important;
	}
	body.kr-blog-page .page-header.page-header-modern h1 {
		font-size: 1.4rem !important;
	}
	body.kr-blog-page .main > .container.py-5 {
		padding-top: 1.25rem !important;
		padding-bottom: 1.75rem !important;
	}
	body.kr-blog-page .blog-card-img,
	body.kr-blog-page .blog-card-img-placeholder {
		height: 170px;
	}
}

/* ── blog-detail.php ── */
.blog-detail-wrap { max-width: 820px; margin: 0 auto; }
.blog-hero-wrap {
    width: 100%;
    aspect-ratio: 1290/840;
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 32px;
    background: #f3f4f6;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}
.blog-hero-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}
.blog-hero-img:hover { transform: scale(1.02); }
.blog-hero-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #e0e7ff, #f0fdf4);
    color: #9ca3af;
    font-size: 3rem;
}
.blog-title     { font-size: 2.2rem; font-weight: 700; line-height: 1.25; color: #1a1a2e; margin-bottom: 12px; }
.blog-meta      { font-size: .85rem; color: #6b7280; margin-bottom: 28px; display: flex; flex-wrap: wrap; gap: 16px; }
.blog-meta span { display: flex; align-items: center; gap: 5px; }
.blog-content   { font-size: 1.05rem; line-height: 1.85; color: #374151; }
.blog-content p { margin-bottom: 1.2rem; }
.blog-content h2, .blog-content h3 { font-weight: 700; color: #1a1a2e; margin: 2rem 0 .8rem; }
.blog-content img { max-width: 100%; border-radius: 8px; }
.blog-content blockquote { border-left: 4px solid #667eea; padding-left: 1.2rem; color: #6b7280; font-style: italic; margin: 1.5rem 0; }
.blog-tags .tag { display: inline-block; background: #ede9fe; color: #5b21b6; font-size: .78rem; font-weight: 600; padding: 4px 12px; border-radius: 20px; margin: 3px; text-decoration: none; }
.blog-tags .tag:hover { background: #667eea; color: #fff; }
.related-card { border: 0; border-radius: 10px; overflow: hidden; box-shadow: 0 2px 12px rgba(0,0,0,.07); transition: transform .2s; }
.related-card:hover { transform: translateY(-3px); }
.related-card img { width: 100%; height: 150px; object-fit: cover; }
.related-card-body { padding: 14px; }
.related-card-title { font-size: .9rem; font-weight: 700; color: #1a1a2e; line-height: 1.3; }
.related-card-title a { color: inherit; text-decoration: none; }
.related-card-title a:hover { color: #667eea; }
@media(max-width:768px) {
    .blog-hero-wrap { aspect-ratio: 1/1; border-radius: 8px; margin-bottom: 24px; }
    .blog-title { font-size: 1.5rem; }
}
@media(max-width:480px) {
    .blog-hero-wrap { aspect-ratio: 4/3; margin-bottom: 20px; }
}

/* ── evets_mba.php ── */
.events-table-wrap { border-radius: 12px; overflow: hidden; box-shadow: 0 3px 20px rgba(15,20,60,.07); }
.events-table { width: 100%; border-collapse: collapse; background: #fff; }
.events-table thead tr { background: linear-gradient(135deg, #0f3460, #1a1a2e); }
.events-table thead th { color: #fff; font-size: .82rem; font-weight: 600; padding: 14px 18px; text-align: left; white-space: nowrap; }
.events-table tbody tr { border-bottom: 1px solid #f0f2f8; transition: background .2s; }
.events-table tbody tr:last-child { border-bottom: none; }
.events-table tbody tr:hover { background: #f8f9ff; }
.events-table tbody td { padding: 14px 18px; font-size: .88rem; color: #374151; vertical-align: middle; }
.evt-sr { font-weight: 700; color: #9ca3af; font-size: .8rem; width: 40px; }
.evt-title { font-weight: 600; color: #0d1b3e; }
.evt-venue { color: #6b7280; font-size: .82rem; }
.evt-date-badge { display: inline-block; background: #f0f4ff; color: #1846a6; font-size: .75rem; font-weight: 600; padding: 3px 10px; border-radius: 50px; white-space: nowrap; }
.evt-pdf-btn { display: inline-flex; align-items: center; gap: 5px; background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; border-radius: 6px; padding: 5px 12px; font-size: .78rem; font-weight: 600; text-decoration: none; transition: background .2s, color .2s; white-space: nowrap; }
.evt-pdf-btn:hover { background: #dc2626; color: #fff; border-color: #dc2626; }
.evt-link-btn { display: inline-flex; align-items: center; gap: 5px; background: #f0f9ff; color: #0284c7; border: 1px solid #bae6fd; border-radius: 6px; padding: 5px 12px; font-size: .78rem; font-weight: 600; text-decoration: none; transition: background .2s, color .2s; }
.evt-link-btn:hover { background: #0284c7; color: #fff; border-color: #0284c7; }
.evt-empty { text-align: center; padding: 60px 20px; color: #9ca3af; }
.evt-empty i { font-size: 3rem; margin-bottom: 12px; display: block; opacity: .3; }
@media(max-width:767px) { .events-table thead th:nth-child(3), .events-table tbody td:nth-child(3) { display: none; } }
@media(max-width:575px) { .events-table thead th:nth-child(4), .events-table tbody td:nth-child(4) { display: none; } .events-table tbody td { padding: 10px 12px; } }

/* ── health_care.php ── */
.hc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; margin-bottom: 36px; }
.hc-card {
    background: #fff;
    border-radius: 6px;
    box-shadow: none;
    border: 1.6px solid rgba(15, 23, 42, 0.55);
    padding: 24px 20px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.hc-card:hover {
	transform: translateY(-2px);
	border-color: rgba(123, 0, 16, 0.55);
	box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}
.hc-icon {
    width: 46px;
    height: 46px;
    border-radius: 0;
    background: transparent;
    display: grid;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
    flex-shrink: 0;
}
.hc-icon i { color: #7b0010; font-size: 1.42rem; opacity: 0.95; }
.hc-card h4 {
	font-size: 1.02rem;
	font-weight: 900;
	color: #0f172a;
	margin-bottom: 6px;
	letter-spacing: -0.01em;
}
.hc-card p  {
	font-size: .93rem;
	color: #475569;
	line-height: 1.55;
	margin: 0;
	max-width: 18rem;
}

/* ── ict-facilities.php ── */
.ict-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px; margin-bottom: 40px; }
.ict-card {
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 3px 18px rgba(15,20,60,.08);
    padding: 28px 24px 24px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    transition: transform .3s, box-shadow .3s;
}
.ict-card:hover { transform: translateY(-4px); box-shadow: 0 12px 36px rgba(15,20,60,.13); }
.ict-icon {
    width: 52px; height: 52px;
    border-radius: 12px;
    background: linear-gradient(135deg, #e56500, #c0392b);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 16px;
    flex-shrink: 0;
}
.ict-icon i { color: #fff; font-size: 1.3rem; }
.ict-card h4 { font-size: .97rem; font-weight: 700; color: #0d1b3e; margin-bottom: 6px; }
.ict-card p  { font-size: .84rem; color: #6b7280; line-height: 1.65; margin: 0; }

/* shared pdf-section / pdf-btn (health_care + ict-facilities) */
.pdf-section {
    background: #f8f9ff;
    border: 1.5px solid #e0e4f0;
    border-radius: 14px;
    padding: 26px;
    margin-bottom: 32px;
}
.pdf-section h5 { font-weight: 700; color: #0d1b3e; margin-bottom: 6px; }
.pdf-section p  { font-size: .88rem; color: #6b7280; margin-bottom: 16px; }
.pdf-btn {
    display: inline-flex; align-items: center; gap: 8px;
    background: linear-gradient(135deg, #dc2626, #b91c1c);
    color: #fff; border: none; border-radius: 8px;
    padding: 10px 22px; font-size: .88rem; font-weight: 600;
    text-decoration: none; transition: opacity .2s;
}
.pdf-btn:hover { opacity: .88; color: #fff; }
.pdf-embed-wrap {
    margin-top: 20px;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid #e0e4f0;
    box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.pdf-embed-wrap iframe { display: block; width: 100%; height: 680px; border: none; }
@media(max-width:575px) { .pdf-embed-wrap iframe { height: 420px; } }

/* ── press.php ── */
.press-card {
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 3px 20px rgba(15,20,60,.07);
    overflow: hidden;
    transition: transform .3s, box-shadow .3s;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.press-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 40px rgba(15,20,60,.13);
}
.press-img-wrap {
    position: relative;
    width: 100%;
    padding-top: 58%;
    overflow: hidden;
    background: linear-gradient(135deg, #1a1a2e, #0f3460);
    flex-shrink: 0;
}
.press-img-wrap img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
}
.press-card:hover .press-img-wrap img { transform: scale(1.05); }
.press-img-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.8rem;
    color: rgba(255,255,255,.2);
}
.press-date-badge {
    position: absolute;
    bottom: 12px;
    left: 12px;
    background: rgba(229,101,0,.92);
    color: #fff;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .6px;
    padding: 4px 10px;
    border-radius: 50px;
}
.press-body {
    padding: 18px 20px 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.press-source {
    font-size: .72rem;
    font-weight: 700;
    color: #e56500;
    text-transform: uppercase;
    letter-spacing: .8px;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    gap: 5px;
}
.press-title {
    font-size: .97rem;
    font-weight: 700;
    color: #0d1b3e;
    line-height: 1.4;
    margin-bottom: 8px;
}
.press-desc {
    font-size: .85rem;
    color: #6b7280;
    line-height: 1.7;
    flex: 1;
    margin-bottom: 14px;
}
.press-read-more {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: .8rem;
    font-weight: 600;
    color: #1846a6;
    text-decoration: none;
    transition: color .2s, gap .2s;
}
.press-read-more:hover { color: #e56500; gap: 10px; }
.press-empty {
    text-align: center;
    padding: 80px 20px;
    color: #9ca3af;
}
.press-empty i { font-size: 3.5rem; margin-bottom: 16px; display: block; opacity: .3; }

/* ── photo.php / sport_gallery.php — video gallery ── */
.video-gallery {
    margin-top: 3.5rem;
    margin-bottom: 3rem;
    padding: 1rem 0;
}
.video-item {
    margin-bottom: 2.5rem;
    padding: 0.5rem;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: 12px;
    background: #fff;
}
.video-item:hover { transform: translateY(-8px); }
.video-link {
    text-decoration: none;
    display: block;
    color: inherit;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.video-link:hover {
    text-decoration: none;
    color: inherit;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}
.video-overlay {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(135deg, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.4) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}
.video-item:hover .video-overlay { opacity: 1; }
.play-button {
    font-size: 3.5rem;
    color: #fff;
    background: rgba(255,255,255,0.2);
    border: 2px solid rgba(255,255,255,0.8);
    border-radius: 50%;
    width: 70px; height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
}
.play-button:hover {
    background: rgba(255,255,255,0.3);
    border-color: #fff;
    transform: scale(1.1);
}
.video-info {
    background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
    padding: 1.25rem 1rem;
    border: none;
    text-align: center;
}
.video-info h6 {
    color: #2c3e50;
    font-weight: 700;
    font-size: 0.95rem;
    margin-bottom: 0.5rem;
    line-height: 1.3;
}
.video-info small {
    font-size: 0.85rem;
    color: #6c757d;
    font-weight: 500;
}
.thumb-info-wrapper {
    position: relative;
    overflow: hidden;
    border-radius: 12px 12px 0 0;
}
.thumb-info-wrapper img {
    transition: transform 0.4s ease;
    width: 100%;
    height: auto;
}
.video-item:hover .thumb-info-wrapper img { transform: scale(1.08); }
@media (max-width: 768px) {
    .video-gallery { margin-top: 2.5rem; margin-bottom: 2rem; padding: 0.5rem 0; }
    .video-item { margin-bottom: 2rem; padding: 0.25rem; }
    .play-button { font-size: 2.5rem; width: 50px; height: 50px; }
    .video-info h6 { font-size: 0.85rem; }
    .video-info small { font-size: 0.75rem; }
}
@media (max-width: 576px) {
    .video-gallery { margin-top: 2rem; margin-bottom: 1.5rem; padding: 0.25rem 0; }
    .video-item { margin-bottom: 1.5rem; padding: 0.25rem; }
    .video-info { padding: 1rem 0.75rem; }
    .video-info h6 { font-size: 0.8rem; }
    .video-info small { font-size: 0.7rem; }
}

/* ── photo.php — album grid ── */
.album-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 18px; margin-top: 10px; }
.album-card-new { border-radius: 14px; overflow: hidden; box-shadow: 0 4px 18px rgba(0,0,0,.10); transition: transform .28s, box-shadow .28s; background: #fff; cursor: pointer; text-decoration: none; display: block; color: inherit; }
.album-card-new:hover { transform: translateY(-6px); box-shadow: 0 12px 32px rgba(0,0,0,.18); color: inherit; text-decoration: none; }
.album-collage-new { position: relative; height: 200px; overflow: hidden; }
.collage-grid { display: grid; height: 100%; gap: 2px; }
.collage-grid.g1 { grid-template-columns: 1fr; }
.collage-grid.g2 { grid-template-columns: 1fr 1fr; }
.collage-grid.g3 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.collage-grid.g3 .c-main { grid-row: 1/3; }
.collage-grid.g4 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.collage-grid img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.album-card-new:hover .collage-grid img { transform: scale(1.06); }
.more-overlay { position: absolute; bottom: 0; right: 0; width: 50%; height: 50%; background: rgba(0,0,0,.55); display: flex; align-items: center; justify-content: center; flex-direction: column; color: #fff; }
.more-overlay span { font-size: 1.4rem; font-weight: 800; line-height: 1; }
.more-overlay small { font-size: .7rem; opacity: .85; }
.album-hover-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.6) 0%, transparent 55%); opacity: 0; transition: opacity .28s; display: flex; align-items: center; justify-content: center; }
.album-card-new:hover .album-hover-overlay { opacity: 1; }
.album-hover-overlay i { font-size: 2rem; color: #fff; background: rgba(255,255,255,.15); border: 2px solid rgba(255,255,255,.7); border-radius: 50%; width: 56px; height: 56px; display: flex; align-items: center; justify-content: center; backdrop-filter: blur(4px); }
.album-placeholder { height: 200px; background: linear-gradient(135deg, #e0e7ff, #f0fdf4); display: flex; align-items: center; justify-content: center; }
.album-info-new { padding: 12px 14px 14px; }
.album-info-new h5 { font-size: .95rem; font-weight: 700; color: #1a1a2e; margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.album-info-new .meta { display: flex; align-items: center; justify-content: space-between; }
.album-info-new .img-count { font-size: .75rem; color: #888; }
.album-info-new .view-link { font-size: .75rem; font-weight: 600; color: #667eea; }
@media(max-width:576px) { .album-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; } .album-collage-new { height: 140px; } }

/* ── Porto / Owl visibility fallbacks (.body .main = all frontend pages) ─────
   theme-elements.css: .appear-animation { opacity:0 } until JS adds .appear-animation-visible.
   owl.carousel.css: .owl-carousel { display:none } until .owl-loaded; .owl-loading { opacity:0 }.
   If JS is slow, blocked, or errors, content stays blank — match live site by showing it. */
.body .main [data-appear-animation],
.body .main .appear-animation {
	opacity: 1 !important;
	visibility: visible !important;
}
.body .main [data-appear-animation].invisible,
.body .main .appear-animation.invisible {
	visibility: visible !important;
	opacity: 1 !important;
}

/* Hero: Owl hides the whole slider until init; keep first slide visible as fallback */
.body .main .krscms-hero-slider.owl-carousel:not(.owl-loaded),
.body .main .krscms-hero-slider.owl-carousel.owl-loading {
	display: block !important;
	opacity: 1 !important;
}
.body .main .krscms-hero-slider.owl-carousel {
	opacity: 1 !important;
}
.body .main .krscms-hero-slider.owl-carousel:not(.owl-loaded) > .slide-item ~ .slide-item {
	display: none !important;
}
.body .main .krscms-hero-slider.owl-carousel:not(.owl-loaded) > .slide-item {
	display: flex !important;
}

/* Home testimonials (.ts-owl): same display:none until owl-loaded */
.body .main .ts-owl.owl-carousel:not(.owl-loaded),
.body .main .ts-owl.owl-carousel.owl-loading {
	display: block !important;
	opacity: 1 !important;
}

/* ── index.php — hero slider ── */
.krscms-hero-slider { position: relative; }
.krscms-hero-slider .slide-item {
    position: relative;
    min-height: 560px;
    display: flex;
    align-items: center;
    overflow: hidden;
}
.krscms-hero-slider .slide-bg {
    position: absolute;
    inset: 0;
    /* Shows under hero photo and if image 404s / missing locally (DB often points at uploads/...) */
    background-color: #5c3014;
    background-size: cover;
    background-position: center;
    transform: scale(1.05);
    transition: transform 8s ease;
}
.krscms-hero-slider .owl-item.active .slide-bg { transform: scale(1); }
.krscms-hero-slider .slide-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(0,0,0,0.28) 0%, rgba(0,0,0,0.08) 60%, transparent 100%);
}
.krscms-hero-slider .slide-content {
    position: relative;
    z-index: 2;
    padding: 60px 0 80px;
}
.krscms-hero-slider .slide-logo-inline {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}
.krscms-hero-slider .slide-logo-inline img {
    width: 130px;
    height: auto;
    filter: drop-shadow(0 2px 6px rgba(0,0,0,0.4));
}
.krscms-hero-slider .slide-logo-inline span {
    font-size: .75rem;
    font-weight: 700;
    color: rgba(255,255,255,.75);
    letter-spacing: 1px;
    text-transform: uppercase;
    line-height: 1.3;
}
.krscms-hero-slider .slide-small-heading {
    font-size: .95rem;
    font-weight: 600;
    color: rgba(255,255,255,0.8);
    letter-spacing: 1.2px;
    margin-bottom: 10px;
    text-transform: uppercase;
}
.krscms-hero-slider .slide-main-heading {
    font-size: clamp(1.8rem, 3.5vw, 2.8rem);
    font-weight: 800;
    color: #fff;
    line-height: 1.2;
    margin-bottom: 28px;
    text-shadow: 0 2px 16px rgba(0,0,0,0.6), 0 1px 4px rgba(0,0,0,0.5);
}
.krscms-hero-slider .slide-btn {
    display: inline-block;
    padding: 12px 36px;
    background: linear-gradient(135deg, #e56500, #c0392b);
    color: #fff;
    font-weight: 700;
    font-size: .95rem;
    border-radius: 50px;
    text-decoration: none;
    box-shadow: 0 6px 20px rgba(229,101,0,.4);
    transition: transform .2s, box-shadow .2s;
    letter-spacing: .3px;
}
.krscms-hero-slider .slide-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(229,101,0,.5);
    color: #fff;
}
.krscms-hero-slider .owl-nav button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px; height: 44px;
    background: rgba(255,255,255,0.12) !important;
    border: 1.5px solid rgba(255,255,255,0.35) !important;
    border-radius: 50% !important;
    color: #fff !important;
    font-size: 1rem !important;
    transition: background 0.2s;
    z-index: 10;
}
.krscms-hero-slider .owl-nav button:hover { background: rgba(255,255,255,0.25) !important; }
.krscms-hero-slider .owl-nav .owl-prev { left: 16px; }
.krscms-hero-slider .owl-nav .owl-next { right: 16px; }
.krscms-hero-slider .owl-dots {
    position: absolute;
    bottom: 18px;
    width: 100%;
    text-align: center;
    z-index: 10;
}
.krscms-hero-slider .owl-dots .owl-dot span {
    width: 8px; height: 8px;
    background: rgba(255,255,255,0.4);
    border-radius: 50%;
    margin: 0 4px;
    display: inline-block;
    transition: background 0.2s, transform 0.2s;
}
.krscms-hero-slider .owl-dots .owl-dot.active span {
    background: #fff;
    transform: scale(1.4);
}
@media(max-width:768px) {
    .krscms-hero-slider .slide-item { min-height: 380px; }
    .krscms-hero-slider .slide-content { padding: 50px 0 70px; }
    .krscms-hero-slider .slide-main-heading { font-size: 1.6rem; }
}

/* ── Home — placement board (.kr-placement-*) — homepage + placement partial ── */
.kr-placement-board {
	--kr-red: #a90016;
	--kr-red2: #df1728;
	--kr-navy: #18164f;
	--kr-gold: #ffd321;
	--kr-ink: #161616;
	position: relative;
	overflow: hidden;
	padding: 0 0 18px;
	margin-top: -0.55rem;
	font-family: Poppins, system-ui, sans-serif;
	background:
		radial-gradient(circle at 8% 28%, rgba(255, 226, 196, 0.8) 0 12%, transparent 24%),
		radial-gradient(circle at 85% 32%, rgba(244, 210, 80, 0.32) 0 16%, transparent 34%),
		linear-gradient(180deg, #fff 0%, #fff 52%, #fff4d9 100%);
}
.kr-placement-board::before {
	content: "";
	position: absolute;
	inset: auto -8% 18px -8%;
	height: 170px;
	pointer-events: none;
	background: linear-gradient(10deg, rgba(232, 73, 31, 0.18), rgba(255, 196, 61, 0.2));
	transform: rotate(5deg);
}
.kr-placement-board::after {
	content: none;
}
.kr-placement-inner {
	position: relative;
	z-index: 1;
	max-width: 100%;
	margin: 0 auto;
	padding: 0 18px 4px;
}
.kr-placement-titlebar {
	display: table;
	margin: 0 auto 16px;
	background: var(--kr-red);
	color: #fff;
	border-radius: 0 0 16px 16px;
	padding: 8px 18px 9px;
	text-transform: uppercase;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0.03em;
	font-size: clamp(1.15rem, 2.2vw, 1.75rem);
	box-shadow: 0 10px 24px rgba(169, 0, 22, 0.18);
}
.kr-placement-titlebar span {
	color: var(--kr-gold);
	margin-right: 10px;
}

/* Full-bleed auto-scroll row (duplicate list in Blade = seamless −50%) */
.kr-placement-marquee {
	position: relative;
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	overflow: hidden;
	padding: 14px 0 10px;
	box-sizing: border-box;
}
.kr-placement-marquee::before,
.kr-placement-marquee::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: min(100px, 9vw);
	z-index: 2;
	pointer-events: none;
}
.kr-placement-marquee::before {
	left: 0;
	background: linear-gradient(to right, rgba(255, 255, 255, 0.96), transparent 100%);
}
.kr-placement-marquee::after {
	right: 0;
	background: linear-gradient(to left, rgba(255, 255, 255, 0.96), transparent 100%);
}
/* Horizontal padding stays off the animated track — it breaks −50% / duplicate-half alignment */
.kr-placement-track {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	width: max-content;
	gap: 22px;
	padding: 10px 0;
	will-change: transform;
	backface-visibility: hidden;
	animation: krPlacementMarquee 175s linear infinite;
}
.kr-placement-marquee:hover .kr-placement-track {
	animation-play-state: paused;
}
@keyframes krPlacementMarquee {
	0% {
		transform: translate3d(0, 0, 0);
	}
	100% {
		transform: translate3d(-50%, 0, 0);
	}
}

.kr-placement-card {
	position: relative;
	flex: 0 0 auto;
	width: clamp(156px, 17.25vw, 202px);
	min-width: 0;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.kr-placement-package {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 4px;
	min-height: 34px;
	margin-bottom: 2px;
	color: var(--kr-navy);
	font-weight: 900;
	font-style: italic;
	line-height: 0.95;
	letter-spacing: 0.01em;
}
.kr-placement-package strong {
	font-size: clamp(1.15rem, 2.05vw, 1.72rem);
}
.kr-placement-package span {
	font-size: clamp(0.68rem, 1.05vw, 0.92rem);
	text-transform: uppercase;
}
.kr-placement-photo {
	position: relative;
	width: min(128px, 92%);
	aspect-ratio: 1 / 1.12;
	margin: 0 auto 10px;
	border: 1px solid rgba(223, 23, 40, 0.35);
	border-radius: 14px;
	background: var(--kr-red2);
	overflow: hidden;
}
.kr-placement-photo::before {
	content: "";
	position: absolute;
	inset: 18% 10% 0;
	border-radius: 46% 46% 0 0;
	background: #fff;
	opacity: 0.92;
}
.kr-placement-photo img {
	position: relative;
	z-index: 1;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
	display: block;
}
.kr-placement-avatar {
	position: relative;
	z-index: 1;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 2.5rem;
	font-weight: 900;
	background: linear-gradient(145deg, var(--kr-red2), #7e0010);
}
.kr-placement-name {
	color: #b01567;
	font-size: 0.78rem;
	font-weight: 900;
	font-style: italic;
	text-transform: uppercase;
	line-height: 1.15;
	margin-bottom: 1px;
	max-width: 170px;
	min-height: 2.35em;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.kr-placement-company {
	color: var(--kr-ink);
	font-size: 0.62rem;
	font-weight: 800;
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	max-width: 174px;
	min-height: 1.35em;
	overflow: hidden;
	text-overflow: ellipsis;
}
.kr-placement-dept {
	color: #5f5f5f;
	font-size: 0.6rem;
	font-weight: 700;
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	max-width: 174px;
	overflow: hidden;
	text-overflow: ellipsis;
}

@media (max-width: 575.98px) {
	.kr-placement-track {
		gap: 16px;
		animation-duration: 148s;
	}
	.kr-placement-card {
		width: clamp(140px, 44vw, 168px);
	}
	.kr-placement-photo {
		width: min(104px, 88%);
	}
}

@media (prefers-reduced-motion: reduce) {
	.kr-placement-track {
		animation: none !important;
		flex-wrap: wrap;
		justify-content: center;
		width: 100%;
		max-width: 1180px;
		margin: 0 auto;
		row-gap: 16px;
		padding: 8px 16px;
	}
}

/* Homepage — recruiter logo strip + gallery scroller (.kr-recruiter-*, .kr-gallery-*) */
.kr-recruiter-wrap {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding: 6px 0 18px;
}
.kr-recruiter-wrap::before,
.kr-recruiter-wrap::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 48px;
	z-index: 2;
	pointer-events: none;
}
.kr-recruiter-wrap::before {
	left: 0;
	background: linear-gradient(to right, rgba(246, 134, 51, 0.95), transparent);
}
.kr-recruiter-wrap::after {
	right: 0;
	background: linear-gradient(to left, rgba(255, 179, 71, 0.95), transparent);
}
.kr-recruiter-track {
	display: flex;
	width: max-content;
	gap: 14px;
	animation: krRecruiterMarquee 34s linear infinite;
}
.kr-recruiter-track:hover {
	animation-play-state: paused;
}
@keyframes krRecruiterMarquee {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-50%);
	}
}
.kr-recruiter-tagline {
	font-size: clamp(0.88rem, 1.6vw, 0.98rem);
	font-weight: 600;
	line-height: 1.45;
	color: rgba(92, 28, 8, 0.92);
	max-width: 36rem;
	margin-left: auto;
	margin-right: auto;
}
.kr-recruiter-card {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 132px;
	min-height: 88px;
	padding: 14px 12px;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 14px;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.07);
}
.kr-recruiter-logo {
	display: block;
	max-height: 56px;
	max-width: 112px;
	width: auto;
	height: auto;
	object-fit: contain;
}
.kr-recruiter-logo--broken {
	display: none !important;
}
.kr-recruiter-logo-fallback {
	width: 56px;
	height: 56px;
	border-radius: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	font-size: 1rem;
	color: #a90016;
	background: rgba(169, 0, 22, 0.09);
	border: 1px solid rgba(169, 0, 22, 0.2);
}

/* Homepage photo strip — continuous filmstrip (no per-image cards/shadows), full-bleed marquee */
.kr-gallery-strip {
	--kr-gallery-h: clamp(200px, 30vw, 320px);
	--kr-gallery-w: clamp(300px, 34vw, 460px);
	position: relative;
	overflow: hidden;
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding: 0;
	background: #0f0f0f;
	box-sizing: border-box;
}
.kr-gallery-strip::before,
.kr-gallery-strip::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: min(120px, 10vw);
	z-index: 2;
	pointer-events: none;
}
.kr-gallery-strip::before {
	left: 0;
	background: linear-gradient(to right, rgba(15, 15, 18, 0.97), rgba(15, 15, 18, 0) 100%);
}
.kr-gallery-strip::after {
	right: 0;
	background: linear-gradient(to left, rgba(15, 15, 18, 0.97), rgba(15, 15, 18, 0) 100%);
}

.kr-gallery-strip .kr-gallery-track {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: row;
	align-items: stretch;
	width: max-content;
	gap: 0;
	padding: 0;
	will-change: transform;
	backface-visibility: hidden;
	animation: krGalleryMarquee 72s linear infinite;
}
.kr-gallery-strip .kr-gallery-track:hover {
	animation-play-state: paused;
}
@keyframes krGalleryMarquee {
	0% {
		transform: translate3d(0, 0, 0);
	}
	100% {
		transform: translate3d(-50%, 0, 0);
	}
}

/* Single continuous row — photos flush, no frame / card chrome */
.kr-gallery-strip .kr-gallery-item {
	flex: 0 0 auto;
	display: block;
	width: var(--kr-gallery-w);
	height: var(--kr-gallery-h);
	margin: 0;
	padding: 0;
	overflow: hidden;
	border: none;
	border-radius: 0;
	box-shadow: none;
	outline: none;
	background: #141414;
	transition: filter 0.25s ease, opacity 0.25s ease;
}
.kr-gallery-strip .kr-gallery-item:hover {
	filter: brightness(1.06);
	opacity: 1;
}
.kr-gallery-strip .kr-gallery-item:focus-visible {
	outline: 2px solid #e56500;
	outline-offset: -2px;
	z-index: 3;
	position: relative;
}

.kr-gallery-strip .kr-gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	transform: none;
	transition: transform 14s linear;
}
/* CMS aspect ratio preset (premium sites: expose ratio in UI; keep object-fit cover) */
.kr-gallery-strip.kr-gallery-strip--cms-ratio .kr-gallery-item{
	height: auto;
	aspect-ratio: var(--kr-gallery-cms-aspect, 16 / 11);
	width: min(var(--kr-gallery-w, 460px), 92vw);
	max-width: 100%;
}
.kr-gallery-strip.kr-gallery-strip--cms-ratio .kr-gallery-item img{
	width: 100%;
	height: 100%;
	min-height: 0;
	object-fit: cover;
}

.kr-gallery-strip .kr-gallery-item:hover img {
	transform: scale(1.04);
}

@media (max-width: 575.98px) {
	.kr-gallery-strip {
		--kr-gallery-h: clamp(168px, 46vw, 220px);
		--kr-gallery-w: min(52vw, 280px);
	}
	.kr-gallery-strip .kr-gallery-track {
		animation-duration: 58s;
	}
}

@media (prefers-reduced-motion: reduce) {
	.kr-gallery-strip .kr-gallery-track {
		animation: none !important;
		flex-wrap: wrap;
		justify-content: center;
		width: 100%;
		max-width: none;
		margin: 0 auto;
		gap: 0;
		padding: 12px clamp(16px, 4vw, 32px);
	}
	.kr-gallery-strip .kr-gallery-item {
		flex: 1 1 min(260px, 100%);
		max-width: 400px;
	}
	.kr-gallery-strip .kr-gallery-item img {
		transition: none;
	}
}

/* ── index.php — placements section (alternate legacy cards) ── */
.pl-card {
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(15,20,60,.10);
    transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s;
    position: relative;
    background: #fff;
    display: flex;
    flex-direction: column;
}
.pl-card:hover {
    transform: translateY(-10px) scale(1.01);
    box-shadow: 0 24px 56px rgba(15,20,60,.18);
}
.pl-photo-area {
    position: relative;
    width: 100%;
    padding-top: 105%;
    flex-shrink: 0;
    background: linear-gradient(135deg, #1a1a2e, #0f3460);
    overflow: hidden;
}
.pl-photo-area img.pl-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform .5s ease;
}
.pl-card:hover .pl-photo-area img.pl-img { transform: scale(1.05); }
.pl-photo-area .pl-avatar-full {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4.5rem;
    color: rgba(255,255,255,.18);
}
.pl-photo-area::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 45%, rgba(10,14,35,.45) 70%, rgba(10,14,35,.88) 100%);
    pointer-events: none;
}
.pl-batch-pill {
    position: absolute;
    top: 12px; left: 12px;
    z-index: 2;
    background: rgba(255,255,255,.18);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.28);
    color: #fff;
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .6px;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: 50px;
}
.pl-name-on-photo {
    position: absolute;
    bottom: 12px; left: 14px; right: 14px;
    z-index: 2;
    font-size: .92rem;
    font-weight: 800;
    color: #fff;
    line-height: 1.25;
    text-shadow: 0 2px 8px rgba(0,0,0,.5);
}
.pl-info-strip {
    padding: 14px 16px 16px;
    background: #fff;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.pl-company-block {
    display: flex;
    align-items: center;
    gap: 9px;
    background: #f4f6ff;
    border-radius: 10px;
    padding: 10px 14px;
    border-left: 3px solid #0f3460;
}
.pl-company-block .pl-co-name { font-size: .85rem; font-weight: 700; color: #1a1a2e; line-height: 1.2; }
.pl-company-block .pl-co-label { font-size: .62rem; color: #888; text-transform: uppercase; letter-spacing: .5px; }
.pl-pkg-block {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(135deg, #e56500, #c0392b);
    border-radius: 10px;
    padding: 8px 14px;
    box-shadow: 0 4px 14px rgba(229,101,0,.3);
}
.pl-pkg-block .pl-pkg-label { font-size: .62rem; font-weight: 700; color: rgba(255,255,255,.75); text-transform: uppercase; letter-spacing: .6px; }
.pl-pkg-block .pl-pkg-value { font-size: .95rem; font-weight: 900; color: #fff; letter-spacing: .3px; }
.pl-faculty-row {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: .75rem;
    font-weight: 600;
    color: #444;
    background: #f9f9f9;
    border-radius: 8px;
    padding: 6px 10px;
    border: 1px solid #eee;
}
.pl-faculty-row i { color: #e56500; font-size: .72rem; }

/* ── index.php — recruiters section ── */
.rec-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: .18;
    pointer-events: none;
}
.rec-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(229,101,0,.15);
    border: 1px solid rgba(229,101,0,.4);
    color: #e56500;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 6px 18px;
    border-radius: 50px;
    margin-bottom: 16px;
}
.rec-stats { display: flex; gap: 32px; justify-content: center; flex-wrap: wrap; margin-top: 8px; }
.rec-stat  { text-align: center; }
.rec-stat strong { display: block; font-size: 1.6rem; font-weight: 800; color: #fff; line-height: 1; }
.rec-stat span   { font-size: .75rem; color: rgba(255,255,255,.55); letter-spacing: 1px; text-transform: uppercase; }
.rec-strip {
    background: rgba(255,255,255,.04);
    border-top: 1px solid rgba(255,255,255,.08);
    border-bottom: 1px solid rgba(255,255,255,.08);
    padding: 0;
    overflow: hidden;
    position: relative;
}
.rec-strip::before,
.rec-strip::after {
    content: '';
    position: absolute; top: 0; bottom: 0; width: 120px; z-index: 2; pointer-events: none;
}
.rec-strip::before { left: 0;  background: linear-gradient(to right, #16213e, transparent); }
.rec-strip::after  { right: 0; background: linear-gradient(to left,  #0f3460, transparent); }
.rec-track {
    display: flex;
    width: max-content;
    animation: recScroll 30s linear infinite;
}
.rec-track:hover { animation-play-state: paused; }
.rec-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin: 0 12px;
    padding: 18px 28px;
    height: 110px;
    flex-shrink: 0;
    background: #ffffff;
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 14px;
    transition: background .3s, border-color .3s, transform .3s;
    cursor: default;
    box-shadow: 0 2px 12px rgba(0,0,0,.08);
}
.rec-card:hover {
    background: #ffffff;
    border-color: rgba(229,101,0,.6);
    transform: translateY(-4px);
}
.rec-card img {
    max-height: 38px;
    max-width: 110px;
    width: auto;
    opacity: .9;
    transition: opacity .3s, transform .3s;
}
.rec-card:hover img { opacity: 1; transform: scale(1.08); }
.rec-card .rec-name {
    font-size: .68rem;
    font-weight: 600;
    color: rgba(0,0,0,.5);
    letter-spacing: .5px;
    text-transform: uppercase;
    transition: color .3s;
}
.rec-card:hover .rec-name { color: #e56500; }
@keyframes recScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* ── index.php — testimonials section (glassmorphism, consistent KPI-style cards) ── */
.section-testimonials {
	/* Maroon combo (aligned with recruiter/brand maroon) */
	background: linear-gradient(135deg, #5c0010 0%, #a90016 55%, #7a0012 100%) !important;
	padding: 0 0 54px; /* reduced overall testimonials height */
	position: relative;
	overflow: hidden;
}
/* Symmetric ambient glows (avoids heavier “shading” on one side) */
.section-testimonials::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -100px;
	transform: translateX(-50%);
	width: min(1200px, 140vw);
	height: 320px;
	background: radial-gradient(ellipse 70% 55% at 50% 100%, rgba(255, 211, 106, 0.14) 0%, rgba(255, 211, 106, 0) 68%);
	pointer-events: none;
}
.section-testimonials::after {
	content: "";
	position: absolute;
	left: 50%;
	top: -80px;
	transform: translateX(-50%);
	width: min(900px, 120vw);
	height: 260px;
	background: radial-gradient(ellipse 65% 50% at 50% 0%, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0) 70%);
	pointer-events: none;
}
.section-testimonials > .container {
	position: relative;
	z-index: 1;
	padding-top: 40px; /* bring title/cards slightly up */
}
.section-testimonials .ts-owl-outer { margin-top: 8px; }
.section-testimonials .ts-title { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 800; color: #fff; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 10px; }
.section-testimonials .ts-title-line { display: block; width: 52px; height: 3px; background: linear-gradient(90deg, #ffd36a, #ffb347); border-radius: 2px; margin: 0 auto 40px; }

.ts-owl-outer { position: relative; padding: 0 0 8px; max-width: 1120px; margin-left: auto; margin-right: auto; }

/* Standardized carousel motion & equal-height row */
.ts-owl.owl-carousel { touch-action: pan-y; }
.ts-owl .owl-stage {
	display: flex !important;
	align-items: stretch !important;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.ts-owl .owl-item {
	display: flex;
	align-items: stretch;
	padding: 0;
	height: auto;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
.ts-owl .owl-item > .ts-item-wrap { width: 100%; display: flex; min-height: 100%; }
.ts-owl .owl-stage-outer {
	overflow: hidden;
	padding: 10px 6px 32px;
	margin: -10px -6px 0;
}
.ts-owl.owl-grab .ts-card,
.ts-owl.owl-grab .ts-card:hover {
	transform: none;
	transition: none;
}

/* Nav — glass pills */
.ts-owl .owl-nav { display: block !important; margin-top: 24px; text-align: center; }
.ts-owl .owl-nav button.disabled { opacity: 0.35; pointer-events: none; }
.ts-owl .owl-nav button {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 48px !important;
	height: 48px !important;
	border-radius: 50% !important;
	margin: 0 8px !important;
	padding: 0 !important;
	background: rgba(255,255,255,0.5) !important;
	backdrop-filter: blur(12px) saturate(160%);
	-webkit-backdrop-filter: blur(12px) saturate(160%);
	border: 1px solid rgba(255,255,255,0.85) !important;
	box-shadow: 0 4px 20px rgba(15,23,42,0.08), inset 0 1px 0 rgba(255,255,255,0.9);
	transition: background .22s, transform .22s, box-shadow .22s, border-color .22s !important;
}
.ts-owl .owl-nav button:hover {
	background: rgba(229,101,0,0.92) !important;
	transform: translateY(-2px) scale(1.05);
	border-color: rgba(229,101,0,0.35) !important;
	box-shadow: 0 10px 28px rgba(229,101,0,0.28);
}
.ts-nav-btn {
	font-size: 1.85rem;
	line-height: 1;
	color: #c45100;
	font-weight: 350;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color .2s;
	user-select: none;
}
.ts-owl .owl-nav button span:not(.ts-nav-btn) { display: none; }
.ts-owl .owl-nav button:hover .ts-nav-btn { color: #fff; }
.ts-owl .owl-dots { display: none !important; }

/* Glass card — same structure every slide */
.ts-item-wrap { height: 100%; display: flex; width: 100%; flex: 1; }
.ts-card {
	isolation: isolate;
	border-radius: 20px;
	padding: 26px 24px 22px;
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	width: 100%;
	flex: 1;
	min-height: 260px;
	/* Sober glass (keep cards clearly readable on maroon) */
	background: linear-gradient(
		155deg,
		rgba(255,255,255,0.96) 0%,
		rgba(255,255,255,0.90) 55%,
		rgba(255,255,255,0.94) 100%
	);
	backdrop-filter: blur(10px) saturate(130%);
	-webkit-backdrop-filter: blur(10px) saturate(130%);
	border: 1px solid rgba(255,255,255,0.82);
	/* Single symmetric drop shadow (no horizontal offset → even band left→right) */
	box-shadow:
		0 18px 44px rgba(0,0,0,0.18),
		inset 0 1px 0 rgba(255,255,255,0.9),
		inset 0 0 0 1px rgba(92,0,16,0.08);
	transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease, background .28s ease;
}
/* Soft inner sheen + rim */
.ts-card::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: linear-gradient(180deg, rgba(255,255,255,0.52) 0%, transparent 38%);
	pointer-events: none;
	z-index: 0;
}
.ts-card::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	box-shadow: inset 0 0 0 1px rgba(92,0,16,0.10);
	pointer-events: none;
	z-index: 0;
}
.ts-card > * { position: relative; z-index: 1; }
.ts-card:hover {
	transform: translateY(-6px);
	border-color: rgba(255,255,255,0.92);
	box-shadow:
		0 24px 56px rgba(0,0,0,0.22),
		inset 0 1px 0 rgba(255,255,255,0.95),
		inset 0 0 0 1px rgba(92,0,16,0.14);
}

.ts-quote-icon {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 2.85rem;
	line-height: 0.85;
	color: rgba(169,0,22,0.92);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	margin-bottom: 14px;
	border-radius: 14px;
	background: rgba(255,255,255,0.78);
	border: 1px solid rgba(255,255,255,0.7);
	box-shadow: 0 6px 18px rgba(0,0,0,0.12), inset 0 1px 0 rgba(255,255,255,0.85);
	flex-shrink: 0;
}
.ts-text {
	font-size: .935rem;
	line-height: 1.78;
	color: rgba(17,24,39,0.88);
	flex: 1 1 auto;
	min-height: 4.5rem;
	margin: 0;
	letter-spacing: .01em;
}
.ts-author-block {
	margin-top: auto;
	padding-top: 16px;
	border-top: 1px solid rgba(15,23,42,0.09);
	flex-shrink: 0;
	min-height: 4.75rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}
.ts-author-name {
	font-size: 1rem;
	font-weight: 800;
	color: #0f172a;
	line-height: 1.25;
	letter-spacing: .015em;
}
.ts-author-role {
	font-size: .74rem;
	color: rgba(15,23,42,0.48);
	margin-top: 5px;
	text-transform: uppercase;
	letter-spacing: .095em;
	font-weight: 700;
	line-height: 1.35;
}

@media (min-width: 992px) {
	.ts-card { min-height: 280px; padding: 26px 24px 22px; }
}

@media(max-width:576px) {
	.section-testimonials { padding: 0 0 44px; }
	.section-testimonials > .container { padding-top: 34px; }
	.ts-owl .owl-stage-outer { padding: 6px 10px 28px; margin: -6px -10px 0; }
	.ts-card {
		min-height: 0;
		padding: 22px 18px 20px;
		border-radius: 18px;
		backdrop-filter: blur(10px) saturate(130%);
		-webkit-backdrop-filter: blur(10px) saturate(130%);
	}
	.ts-quote-icon { width: 46px; height: 46px; font-size: 2.5rem; margin-bottom: 12px; }
	.ts-text { min-height: 0; font-size: .9rem; }
	.ts-author-block { min-height: 0; padding-top: 14px; }
}

@media (max-width: 991.98px){
	.section-testimonials { padding-top: 0; }
	.section-testimonials > .container { padding-top: 50px; }
}

@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
	.ts-card {
		background: linear-gradient(180deg, #ffffff 0%, #fffaf5 100%);
	}
	.ts-owl .owl-nav button { background: #fff !important; }
}

/* ── index.php — FAQ section (premium, consistent with testimonials) ── */
.section-faq{
	/* Cool lavender/blue (FAQ) */
	background: linear-gradient(180deg, #ffffff 0%, #f5f7ff 44%, #ffffff 100%);
	position: relative;
	overflow: hidden;
	padding: 78px 0;
}
.section-faq::before{
	content:"";
	position:absolute;
	left:50%;
	bottom:-120px;
	transform:translateX(-50%);
	width:min(1100px, 140vw);
	height:340px;
	background: radial-gradient(ellipse 70% 55% at 50% 100%, rgba(79,70,229,0.12) 0%, rgba(79,70,229,0) 70%);
	pointer-events:none;
}
.section-faq::after{
	content:"";
	position:absolute;
	left:50%;
	top:-120px;
	transform:translateX(-50%);
	width:min(900px, 130vw);
	height:260px;
	background: radial-gradient(ellipse 65% 50% at 50% 0%, rgba(2,132,199,0.08) 0%, rgba(2,132,199,0) 72%);
	pointer-events:none;
}
.section-faq > .container{ position: relative; z-index: 1; }

.faq-wrap { max-width: 920px; margin: 0 auto; }
.faq-badge{
	display:inline-flex;
	align-items:center;
	gap:8px;
	background: rgba(255,255,255,0.65);
	backdrop-filter: blur(12px) saturate(160%);
	-webkit-backdrop-filter: blur(12px) saturate(160%);
	border: 1px solid rgba(255,255,255,0.9);
	color:#9a3f00;
	font-size:.72rem;
	font-weight:900;
	letter-spacing:.14em;
	text-transform:uppercase;
	padding:6px 18px;
	border-radius:999px;
	box-shadow: 0 10px 26px rgba(15,23,42,0.08), inset 0 1px 0 rgba(255,255,255,0.9);
	margin-bottom: 14px;
}
.faq-badge::before{
	content:"";
	width:8px; height:8px;
	border-radius:999px;
	background: linear-gradient(135deg, #e56500, #a90016);
	box-shadow: 0 6px 14px rgba(229,101,0,0.22);
}
.faq-main-heading{
	font-weight: 900;
	color: #0f172a;
	letter-spacing: .01em;
}
.faq-main-sub{
	color: rgba(15,23,42,0.62);
	max-width: 560px;
	margin-left: auto;
	margin-right: auto;
}

.faq-item{
	position: relative;
	border-radius: 18px;
	margin-bottom: 14px;
	overflow: hidden;
	background: linear-gradient(155deg, rgba(255,255,255,0.68) 0%, rgba(255,255,255,0.42) 55%, rgba(255,247,237,0.44) 100%);
	backdrop-filter: blur(16px) saturate(155%);
	-webkit-backdrop-filter: blur(16px) saturate(155%);
	border: 1px solid rgba(255,255,255,0.78);
	box-shadow: 0 14px 36px rgba(15,23,42,0.10), inset 0 1px 0 rgba(255,255,255,0.92);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.faq-item::before{
	content:"";
	position:absolute;
	left:0; top:0; bottom:0;
	width: 4px;
	background: linear-gradient(180deg, rgba(229,101,0,0.18), rgba(169,0,22,0.10));
	opacity: 0;
	transition: opacity .25s ease;
	pointer-events:none;
}
.faq-item:hover{
	transform: translateY(-3px);
	box-shadow: 0 20px 48px rgba(15,23,42,0.12), inset 0 1px 0 rgba(255,255,255,0.95);
	border-color: rgba(255,255,255,0.92);
}
.faq-item:hover::before{ opacity: 1; }

.faq-question{
	width: 100%;
	background: none;
	border: none;
	text-align: left;
	padding: 18px 22px 18px 24px;
	font-size: 1.02rem;
	font-weight: 800;
	color: rgba(15,23,42,0.92);
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 14px;
	line-height: 1.35;
}
.faq-question:focus-visible{
	outline: none;
	box-shadow: 0 0 0 4px rgba(229,101,0,0.16);
}
.faq-question .faq-icon{
	flex-shrink: 0;
	width: 34px; height: 34px;
	border-radius: 12px;
	background: rgba(255,255,255,0.6);
	border: 1px solid rgba(255,255,255,0.82);
	display:flex;
	align-items:center;
	justify-content:center;
	box-shadow: 0 8px 18px rgba(15,23,42,0.08), inset 0 1px 0 rgba(255,255,255,0.9);
	transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.faq-question .faq-icon svg{
	width: 14px; height: 14px;
	stroke: #c45100;
	stroke-width: 2.6;
	fill: none;
	transition: transform .25s ease, stroke .2s ease;
}

.faq-item.open .faq-question{ color: #9a3f00; }
.faq-item.open::before{ opacity: 1; }
.faq-item.open .faq-question .faq-icon{
	background: rgba(229,101,0,0.92);
	border-color: rgba(229,101,0,0.30);
}
.faq-item.open .faq-question .faq-icon svg{
	stroke: #fff;
	transform: rotate(45deg);
}
.faq-answer{
	display:none;
	padding: 0 22px 18px 24px;
	color: rgba(15,23,42,0.72);
	font-size: .95rem;
	line-height: 1.85;
	border-top: 1px solid rgba(15,23,42,0.08);
}
.faq-answer p{ margin: 14px 0 0; }

@media (max-width: 576px){
	.section-faq{ padding: 62px 0; }
	.faq-wrap{ max-width: 100%; }
	.faq-item{ border-radius: 16px; }
	.faq-question{ padding: 16px 16px 16px 18px; font-size: .98rem; }
	.faq-answer{ padding: 0 16px 16px 18px; }
}

/* ── index.php — Vision & Mission (premium cards) ── */
.kr-vm-section {
	position: relative;
	overflow: hidden;
	/* Warm cream/gold (Vision & Mission) — matches orange brand, not green */
	background: linear-gradient(180deg, #ffffff 0%, #fff7ed 38%, #fffdf8 62%, #ffffff 100%);
}
/* Full-width wash (left → right), not corner-only — matches testimonial section balance */
.kr-vm-section::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -80px;
	width: 100%;
	height: min(420px, 52vh);
	background: radial-gradient(ellipse 120% 85% at 50% 100%, rgba(229,101,0,0.13) 0%, rgba(255,211,106,0.12) 42%, transparent 74%);
	pointer-events: none;
}
.kr-vm-section::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: -40px;
	width: 100%;
	height: min(240px, 36vh);
	background: radial-gradient(ellipse 110% 90% at 50% 0%, rgba(169,0,22,0.05) 0%, rgba(169,0,22,0) 72%);
	pointer-events: none;
}
.kr-vm-section > .container {
	position: relative;
	z-index: 1;
}

.kr-vm-card {
	position: relative;
	height: 100%;
	border-radius: 18px;
	padding: 26px 24px 22px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.92) 100%);
	border: 1px solid rgba(15,23,42,0.08);
	box-shadow: 0 14px 40px rgba(15,23,42,0.10);
	transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.kr-vm-card::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	padding: 1px;
	background: linear-gradient(135deg, rgba(229,101,0,0.22), rgba(15,23,42,0.10), rgba(255,211,106,0.16));
	-webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
	opacity: 0.85;
}
.kr-vm-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 22px 60px rgba(15,23,42,0.16);
	border-color: rgba(15,23,42,0.12);
}
.kr-vm-card-head {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 12px;
}
.kr-vm-icon {
	width: 44px;
	height: 44px;
	border-radius: 14px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	background: linear-gradient(135deg, #0d9488, #14b8a6);
	box-shadow: 0 10px 26px rgba(13,148,136,0.20);
	flex-shrink: 0;
}
.kr-vm-icon i { font-size: 1.05rem; }
.kr-vm-title {
	margin: 0;
	font-weight: 900;
	color: #111827;
	font-size: 1.15rem;
	letter-spacing: .01em;
}
.kr-vm-text {
	margin: 0 0 14px;
	color: #374151;
	font-size: .95rem;
	line-height: 1.8;
}
.kr-vm-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 800;
	font-size: .85rem;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: #0d9488;
	text-decoration: none;
}
.kr-vm-link i { transition: transform .2s ease; }
.kr-vm-link:hover { color: #0f766e; }
.kr-vm-link:hover i { transform: translateX(3px); }

/* Vision vs Mission — distinct accents but consistent UI */
.kr-vm-card--vision .kr-vm-icon {
	background: linear-gradient(135deg, #0d9488, #14b8a6);
	box-shadow: 0 10px 26px rgba(13,148,136,0.20);
}
.kr-vm-card--vision::before {
	background: linear-gradient(135deg, rgba(13,148,136,0.28), rgba(15,23,42,0.08), rgba(45,212,191,0.18));
}
.kr-vm-card--vision .kr-vm-link { color: #0d9488; }
.kr-vm-card--vision .kr-vm-link:hover { color: #0f766e; }

.kr-vm-card--mission .kr-vm-icon {
	background: linear-gradient(135deg, #1d4ed8, #6366f1);
	box-shadow: 0 10px 26px rgba(29,78,216,0.18);
}
.kr-vm-card--mission::before {
	background: linear-gradient(135deg, rgba(29,78,216,0.26), rgba(15,23,42,0.08), rgba(99,102,241,0.18));
}
.kr-vm-card--mission .kr-vm-link { color: #1d4ed8; }
.kr-vm-card--mission .kr-vm-link:hover { color: #1e40af; }
@media (max-width: 576px) {
	.kr-vm-card { padding: 22px 18px 18px; border-radius: 16px; }
	.kr-vm-icon { width: 40px; height: 40px; border-radius: 12px; }
	.kr-vm-text { font-size: .92rem; }
}

/* ── include/_adm_popup.php ── */
#admPopup {
	--kr-adm-popup-accent: #e56500;
}
#admPopup .modal-dialog {
    max-width: 460px;
    margin: 1rem auto;
}
#admPopup .adm-wrap {
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(229, 101, 0, 0.18);
    box-shadow: 0 16px 48px rgba(0,0,0,.15), 0 4px 12px rgba(0,0,0,.07);
    background: #fff;
	position: relative;
}
#admPopup .adm-wrap::before{
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 6px;
	background: linear-gradient(90deg, var(--kr-adm-popup-accent), rgba(229,101,0,0.25));
}
.adm-close-btn {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #f3f4f6;
    border: none;
    color: #6b7280;
    font-size: .8rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .2s, transform .2s;
    z-index: 20;
}
.adm-close-btn:hover {
    background: #e5e7eb;
    transform: rotate(90deg);
}
.adm-body {
    padding: 28px 28px 22px;
}
.adm-top-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: #fff7ed;
    border: 1px solid #fed7aa;
    color: #c2410c;
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 50px;
    margin-bottom: 10px;
}
.adm-top-badge::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #f97316;
    animation: adm-pulse 1.6s ease-in-out infinite;
}
@keyframes adm-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: .4; transform: scale(1.5); }
}
.adm-form-title {
    font-family: 'Poppins', sans-serif;
    font-size: 1.15rem;
    font-weight: 900;
    color: #0f172a;
    margin-bottom: 5px;
    line-height: 1.3;
}
.adm-form-sub {
    font-size: .86rem;
    color: #64748b;
    margin-bottom: 16px;
}
.adm-divider {
    height: 1px;
    background: #f3f4f6;
    margin-bottom: 14px;
}
.adm-row-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.adm-field { margin-bottom: 8px; }
.adm-input {
    width: 100%;
    height: 44px;
    border-radius: 10px !important;
    border: 1.5px solid #e5e7eb !important;
    padding: 0 13px !important;
    font-size: .88rem !important;
    color: #1f2937 !important;
    background: #fafafa !important;
    transition: border-color .2s, box-shadow .2s !important;
    outline: none !important;
    font-family: 'Poppins', sans-serif !important;
    appearance: none;
}
.adm-input::placeholder { color: #b0b7c3 !important; }
.adm-input:focus {
    border-color: var(--kr-adm-popup-accent) !important;
    box-shadow: 0 0 0 3px rgba(229,101,0,.14) !important;
    background: #fff !important;
}
textarea.adm-input {
    height: auto !important;
    padding-top: 9px !important;
    padding-bottom: 9px !important;
	min-height: 76px;
    resize: none;
}
select.adm-input { cursor: pointer; }
.adm-submit-btn {
    width: 100%;
    height: 46px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--kr-adm-popup-accent) 0%, #cc4f00 100%);
    border: none;
    color: #fff;
    font-family: 'Poppins', sans-serif;
    font-size: .92rem;
    font-weight: 900;
    letter-spacing: .3px;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(255,122,0,.28);
    transition: transform .2s, box-shadow .2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    margin-top: 4px;
}
.adm-submit-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 26px rgba(255,122,0,.42);
}
.adm-submit-btn:disabled { opacity: .7; cursor: not-allowed; transform: none; }
.adm-footer-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 10px;
    gap: 8px;
}
.adm-consent {
    font-size: .72rem;
    color: #94a3b8;
    margin: 0;
    flex: 1;
}
.adm-phone-link {
    font-size: .74rem;
    font-weight: 600;
    color: #0f172a;
    text-decoration: none;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 4px;
}
.adm-phone-link:hover { color: var(--kr-adm-popup-accent); }
.adm-alert {
    border-radius: 10px;
    font-size: .83rem;
    padding: 10px 14px;
    margin-bottom: 14px;
    display: none;
}
.adm-alert.adm-success {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
}
.adm-alert.adm-error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #991b1b;
}
.adm-alert.show { display: block; }
@media (max-width: 575px) {
    #admPopup .modal-dialog { margin: .5rem; }
    .adm-body { padding: 24px 18px 18px; }
    .adm-row-2 { grid-template-columns: 1fr; }
    .adm-footer-row { flex-direction: column; align-items: flex-start; }
}
@keyframes adm-spin { to { transform: rotate(360deg); } }

/* ── Additional helper classes ── */

/* index.php — recruiters section */
.rec-heading    { font-weight: 800; color: #fff; font-size: clamp(1.6rem, 3vw, 2.4rem); margin-bottom: 8px; }
.rec-subheading { color: rgba(255,255,255,.6); font-size: .95rem; max-width: 520px; margin: 0 auto 24px; }
.rec-icon-placeholder { font-size: 1.6rem; color: rgba(0,0,0,.35); }
.rec-empty-msg  { color: rgba(255,255,255,.4); font-size: .9rem; }
.rec-award-icon { color: #e56500; opacity: .4; }

/* index.php — spacer */
.section-spacer-40 { padding: 40px 0; }

/* Header — top enquiry bar (dismissible) */
.kr-top-enquiry-bar{
	background: #e56500;
	color: #fff;
	position: relative;
	z-index: 1002;
}
.kr-top-enquiry-inner{
	position: relative;
	padding: 8px 0;
}
.kr-top-enquiry-text{
	text-align: center;
	font-weight: 700;
	font-size: .95rem;
	line-height: 1.2;
	cursor: pointer;
	padding-right: 44px;
}
.kr-top-enquiry-link{
	color: #fff !important;
	text-decoration: underline;
	text-underline-offset: 3px;
}
.kr-top-enquiry-close{
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	border: 1px solid rgba(255,255,255,0.55);
	background: rgba(255,255,255,0.10);
	color: #fff;
	width: 32px;
	height: 32px;
	border-radius: 10px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	font-size: 20px;
	font-weight: 600;
	-webkit-tap-highlight-color: transparent;
	transition: background .18s ease, border-color .18s ease, transform .18s ease;
}
.kr-top-enquiry-close:hover{
	background: rgba(255,255,255,0.22);
	border-color: rgba(255,255,255,0.75);
	transform: translateY(-50%) scale(1.04);
}
.kr-top-enquiry-close:active{ transform: translateY(-50%) scale(0.98); }
.kr-top-enquiry-close:focus-visible{
	outline: none;
	box-shadow: 0 0 0 3px rgba(255,255,255,0.32);
}
@media (max-width: 575.98px){ .kr-top-enquiry-text{ font-size: .85rem; } }

/* Header — single announcement strip (below navigation) */
.kr-ann-bar{
	background: #fff9ee;
	border-top: 3px solid #a90016;
	border-bottom: 1px solid rgba(2,6,23,0.10);
	margin: 0;
}
/* Inside header column: no sibling gap; bar width matches nav block */
#header .kr-ann-bar{
	width: 100%;
	flex: 0 0 auto;
	margin-top: 0;
	margin-bottom: 0 !important;
}
.kr-ann-call-pill {
	display: none;
}
.kr-ann-strip{
	position: relative;
	overflow: hidden;
	width: 100%;
	padding: 6px 0;
}
.kr-ann-track{
	display: flex;
	align-items: center;
	white-space: nowrap;
	gap: 22px;
	width: max-content;
	will-change: transform;
	transform: translate3d(0,0,0);
	/* Duplicate list in Blade = 50% equals one cycle (seamless loop) */
	animation: krAnnScroll 55s linear infinite;
}
.kr-ann-item{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-weight: 800;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: #1f2937;
	font-size: .82rem;
}
.kr-ann-dot{
	width: 5px;
	height: 5px;
	border-radius: 999px;
	background: #e56500;
}
.kr-ann-link{ color: #1f2937 !important; text-decoration: none !important; }
.kr-ann-link:hover{ color: #a90016 !important; text-decoration: underline !important; text-underline-offset: 3px; }
@keyframes krAnnScroll{
	0%{ transform: translate3d(0,0,0); }
	100%{ transform: translate3d(-50%,0,0); }
}
@media (max-width: 575.98px) {
	.kr-ann-bar {
		display: flex;
		align-items: center;
		min-height: 0;
	}
	.kr-ann-call-pill {
		display: inline-flex;
		align-items: center;
		flex: 0 0 auto;
		align-self: center;
		gap: 4px;
		margin: 2px 0 2px 6px;
		padding: 3px 8px 3px 6px;
		max-height: 24px;
		background: #fff;
		border-radius: 999px;
		border: 1px solid rgba(15, 23, 42, 0.06);
		box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
		text-decoration: none !important;
		color: #1e293b !important;
		font-size: 0.62rem;
		font-weight: 700;
		letter-spacing: 0.01em;
		line-height: 1;
		text-transform: none;
		white-space: nowrap;
		z-index: 3;
		-webkit-tap-highlight-color: transparent;
	}
	.kr-ann-call-text {
		display: none !important;
	}
	.kr-ann-call-num {
		flex-shrink: 0;
		font-size: 0.62rem;
		font-weight: 700;
		letter-spacing: 0.015em;
	}
	.kr-ann-call-pill .icons {
		font-size: 0.7rem;
		flex-shrink: 0;
		line-height: 1;
		color: #334155;
	}
	.kr-ann-call-pill:hover,
	.kr-ann-call-pill:focus-visible {
		color: #1e293b !important;
		box-shadow: 0 1px 4px rgba(15, 23, 42, 0.12);
	}
	.kr-ann-call-pill:focus-visible {
		outline: none;
		box-shadow: 0 0 0 2px rgba(229, 101, 0, 0.28), 0 1px 3px rgba(15, 23, 42, 0.08);
	}
	.kr-ann-strip {
		flex: 1;
		min-width: 0;
		padding: 3px 0;
	}
	.kr-ann-strip::before {
		content: "";
		position: absolute;
		left: 0;
		top: 0;
		bottom: 0;
		width: 14px;
		background: linear-gradient(to right, #fff9ee 40%, transparent);
		z-index: 2;
		pointer-events: none;
	}
	.kr-ann-item {
		font-size: 0.7rem;
		gap: 7px;
	}
	.kr-ann-track {
		gap: 14px;
	}
}
@media (max-width: 380px) {
	.kr-ann-call-pill {
		margin-left: 4px;
		padding: 2px 6px 2px 5px;
		gap: 3px;
	}
	.kr-ann-call-num,
	.kr-ann-call-pill {
		font-size: 0.58rem;
	}
	.kr-ann-call-pill .icons {
		font-size: 0.65rem;
	}
}
@media (prefers-reduced-motion: reduce){
	.kr-ann-track{
		animation: none !important;
		justify-content: center;
		flex-wrap: wrap;
		row-gap: 8px;
		width: 100%;
		max-width: 100%;
		white-space: normal;
	}
}

/* Remove any spacing between header and announcement bar */
#header,
#header .header-body,
.sticky-wrapper{
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}

/* Kill header bottom border/shadow seam above announcement */
#header .header-body.header-body-bottom-border-fixed{
	border-bottom: 0 !important;
}

/* Homepage spacing under stacked header — keeps hero/recruit/testimonial rhythm correct */
.krscms-home #header ~ .main > *:first-child {
	margin-top: 0 !important;
}
.krscms-home #header ~ .main > .slider-container:first-child {
	padding-top: 0 !important;
}
.krscms-home .main,
.krscms-home .main.has-sticky-header-transform {
	margin-top: 0 !important;
	padding-top: 0 !important;
	transform: none !important;
	transition: none !important;
}
.krscms-home .slider-container,
.krscms-home .krscms-hero-slider {
	margin-top: 0 !important;
}

/* index.php — CTA: subtle vertical rhythm only; Porto keeps text-3-5 / text-8 / text-4 sizing */
section.section.kr-home-cta.section-height-1,
.kr-home-cta {
	padding-top: 52px !important;
	padding-bottom: 52px !important;
	margin: 0;
}
@media (max-width: 991.98px) {
	section.section.kr-home-cta.section-height-1,
	.kr-home-cta {
		padding-top: 42px !important;
		padding-bottom: 42px !important;
	}
}
@media (max-width: 575.98px) {
	section.section.kr-home-cta.section-height-1,
	.kr-home-cta {
		padding-top: 34px !important;
		padding-bottom: 34px !important;
	}
}

/* index.php — standardized vertical gap blocks (same above/below CTA) */
.kr-home-gap { height: 84px; }
@media (max-width: 991.98px){ .kr-home-gap { height: 68px; } }
@media (max-width: 575.98px){ .kr-home-gap { height: 52px; } }

/* =============================================================
   HOMEPAGE: standardized vertical rhythm (senior QA pass)
   ============================================================= */
.krscms-home{
	--kr-home-section-pad: 88px;
	--kr-home-section-pad-sm: 68px;
	--kr-home-section-pad-xs: 52px;
}
@media (max-width: 991.98px){
	.krscms-home{ --kr-home-section-pad: var(--kr-home-section-pad-sm); }
}
@media (max-width: 575.98px){
	.krscms-home{ --kr-home-section-pad: var(--kr-home-section-pad-xs); }
}
.kr-home-section{
	padding-top: var(--kr-home-section-pad);
	padding-bottom: var(--kr-home-section-pad);
}
.kr-home-section--top-only{ padding-bottom: 0; }
.kr-home-section--bottom-only{ padding-top: 0; }

/* Welcome block — tight gap below hero image (reference ~15–20px) */
.krscms-home{
	--kr-home-hero-welcome-gap: 1.125rem; /* 18px */
}
@media (max-width: 575.98px){
	.krscms-home{ --kr-home-hero-welcome-gap: 0.875rem; } /* 14px */
}
.krscms-home .slider-container + .container.kr-home-section--hero-welcome,
.krscms-home .section.position-relative.border-0.overflow-hidden + .container.kr-home-section--hero-welcome{
	padding-top: var(--kr-home-hero-welcome-gap) !important;
}

/* ── Homepage — Academic & Infrastructure (legacy Porto thumb-info + maroon accent) ── */
.kr-home-academic{
	position: relative;
	--kr-academic-maroon: #7a0012;
	--kr-academic-maroon-mid: #a90016;
	--kr-academic-maroon-deep: #5c0010;
}
.kr-home-academic--hero-spacing{
	padding-top: 2.5rem;
	padding-bottom: 1rem;
	margin-top: 1.75rem;
	margin-bottom: 0.35rem;
}
@media (max-width: 991.98px){
	.kr-home-academic--hero-spacing{
		padding-top: 2rem;
		padding-bottom: 0.85rem;
		margin-bottom: 0.25rem;
	}
}
.kr-home-academic-grid{
	margin-top: 0;
	margin-bottom: 0 !important;
}
.kr-home-academic-link{
	text-decoration: none !important;
	transition: transform 0.28s ease;
}
.kr-home-academic-card{
	position: relative;
	border-radius: 14px;
	overflow: hidden;
	background: #fff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	box-shadow: 0 8px 26px rgba(15, 23, 42, 0.08);
	transition: box-shadow 0.28s ease, transform 0.28s ease;
}
.kr-home-academic-thumb-wrap{
	overflow: hidden;
	border-radius: 14px 14px 0 0 !important;
	background: #eceff3;
}
.kr-home-academic .thumb-info-wrapper.kr-home-academic-thumb-wrap img.kr-home-academic-img{
	width: 100%;
	display: block;
	border-radius: 0;
	object-fit: cover;
	object-position: center;
	transition: transform 0.45s ease;
	min-height: 160px;
}
/* CMS-driven crop box (recommended uploads: 1600×1000+, 16:10 or CMS ratio) */
.kr-home-academic .thumb-info-wrapper.kr-home-academic-thumb-wrap.kr-home-academic-thumb-wrap--ratio img.kr-home-academic-img{
	min-height: 0;
	height: 100%;
}

.section-testimonials .ts-photo-wrap{
	max-width: 72px;
}
.section-testimonials .ts-photo{
	display: block;
	margin: 0 auto;
	aspect-ratio: 1 / 1;
	box-shadow: 0 4px 14px rgba(15,23,42,0.12);
}
.kr-home-academic-img--fallback{
	object-fit: contain !important;
	padding: 14px;
	background: #eceff3;
	min-height: 160px !important;
}
.kr-home-academic .thumb-info.kr-home-academic-card h3.kr-home-academic-heading,
.kr-home-academic-heading{
	margin: 0 !important;
	padding: 13px 12px 15px !important;
	font-weight: 800 !important;
	text-align: center;
	letter-spacing: 0.03em;
	color: #fff !important;
	line-height: 1.25;
	background: linear-gradient(135deg, var(--kr-academic-maroon-deep) 0%, var(--kr-academic-maroon-mid) 50%, var(--kr-academic-maroon) 100%) !important;
	border-top: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 0 0 13px 13px;
	box-shadow: none !important;
}
.kr-home-academic-link:hover{
	transform: translateY(-6px);
}
.kr-home-academic-link:hover .kr-home-academic-card{
	box-shadow:
		0 16px 40px rgba(15, 23, 42, 0.12),
		0 8px 24px rgba(122, 0, 18, 0.16);
}
.kr-home-academic-link:hover .kr-home-academic-thumb-wrap img.kr-home-academic-img:not(.kr-home-academic-img--fallback){
	transform: scale(1.04);
}
.kr-home-academic-link:focus-visible{
	outline: none;
	box-shadow: 0 0 0 3px rgba(169, 0, 22, 0.42);
	border-radius: 14px;
}

/* Maroon accent under section title */
.kr-home-academic .divider-primary.custom-divider hr,
.kr-home-academic .custom-divider.divider-primary hr{
	max-width: 64px;
	margin-left: auto !important;
	margin-right: auto !important;
	background: linear-gradient(90deg, var(--kr-academic-maroon-deep), var(--kr-academic-maroon-mid) 55%, var(--kr-academic-maroon)) !important;
	border: 0 !important;
	height: 4px !important;
	border-radius: 2px;
	opacity: 1 !important;
}
@media (max-width: 575.98px){
	.kr-home-academic .thumb-info-wrapper.kr-home-academic-thumb-wrap img.kr-home-academic-img{
		min-height: 140px;
	}
}

/* index.php — testimonials container (legacy, kept for compat) */

/* index.php — FAQ headings */
.faq-main-heading { font-weight: 800; color: #1a1a2e; font-size: clamp(1.7rem, 3vw, 2.4rem); line-height: 1.2; margin-bottom: 10px; }
.faq-main-sub     { color: #777; font-size: .95rem; max-width: 480px; margin: 0 auto; }
.faq-answer-open  { display: block; }

/* evets_mba.php — small icon */
.evt-small-icon { font-size: .75rem; }

/* eligibility.php — doc check images */
.doc-check-img { width: 50px; height: 50px; }

/* _marquee_admission_popup.php */
.marquee-item-clickable { cursor: pointer; margin: 0 15px; }

/* ─────────────────────────────────────────────
   INDEX.PHP HERO — extracted inline styles
   ───────────────────────────────────────────── */

/* Admission CTA button (hero area) */
.hero-admission-btn {
    display: inline-flex; align-items: center; gap: 10px;
    background: linear-gradient(135deg, #a90016, #df1728);
    color: #fff; font-size: .85rem; font-weight: 800;
    padding: 13px 36px; border-radius: 50px; text-decoration: none;
    letter-spacing: .6px; text-transform: uppercase;
    box-shadow: 0 6px 24px rgba(169,0,22,.35);
    transition: transform .2s, box-shadow .2s;
}
.hero-admission-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 32px rgba(169,0,22,.45);
}

/* Testimonials section gradient background */
.testimonials-bg {
    background: linear-gradient(135deg, #f68633 0%, #ffb347 52%, #ffd36a 100%);
    padding: 60px 0;
}

/* Testimonial badge label */
.testimonial-badge {
    display: inline-block; background: #a90016; color: #fff;
    font-size: .75rem; font-weight: 700; letter-spacing: .1em;
    text-transform: uppercase; padding: 5px 16px;
    border-radius: 20px; margin-bottom: 14px;
}

/* Testimonial heading and subtext */
.testimonial-heading  { font-size: 2rem; color: #3b1800; }
.testimonial-subtext  { font-size: .95rem; color: rgba(59,24,0,.82); }

/* Bounce admission popup widget (bottom-left) */
.adm-popup-widget {
    position: fixed; bottom: 10px; left: 0;
    cursor: pointer; width: 160px; height: 160px;
    z-index: 9999999;
}

/* Theme loading overlay (if present) */
.loading-overlay,
.loading-overlay-showing .loading-overlay {
	display: none !important;
	opacity: 0 !important;
	visibility: hidden !important;
}

/* Mobile-only: floating NAAC badge — perfect circle (bottom-right) */
@media (max-width: 575.98px) {
	.body::after {
		content: "";
		position: fixed;
		right: 12px;
		bottom: max(12px, env(safe-area-inset-bottom, 0px));
		z-index: 9999;
		width: 52px;
		height: 52px;
		min-width: 52px;
		min-height: 52px;
		padding: 0;
		border-radius: 50%;
		box-sizing: border-box;
		overflow: hidden;
		display: block;
		background-color: rgba(255, 255, 255, 0.96);
		background-image: url("../img/naac-a-grade.png");
		background-repeat: no-repeat;
		background-position: center center;
		background-size: 36px 36px;
		border: 2px solid rgba(229, 101, 0, 0.42);
		box-shadow: 0 8px 22px rgba(15, 23, 42, 0.2);
		pointer-events: none;
	}
}

/* MBA Fees — mobile: same table size, horizontal scroll only */
@media (max-width: 767.98px) {
	body.kr-mba-fees-page .kr-fees-table-scroll {
		display: block;
		width: 100%;
		max-width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		overscroll-behavior-x: contain;
	}
	body.kr-mba-fees-page .kr-fees-table-scroll > table {
		width: auto;
		min-width: 100%;
	}
}

/* Governing Body — mobile: same table size, horizontal scroll only */
@media (max-width: 767.98px) {
	body.kr-governing-body-page .kr-gov-table-scroll {
		display: block;
		width: 100%;
		max-width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		overscroll-behavior-x: contain;
	}
	body.kr-governing-body-page .kr-gov-table-scroll .table-responsive {
		overflow: visible !important;
		border: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
		box-shadow: none !important;
	}
	body.kr-governing-body-page .kr-gov-table-scroll table {
		width: auto;
		min-width: 100%;
	}
}

/* Contact page — map + mobile info cards */
body.kr-contact-page .kr-contact-map-title {
	font-weight: 700;
	color: #1a1a2e;
	margin-bottom: 0.35rem;
}
body.kr-contact-page .kr-contact-map-sub {
	color: #666;
	font-size: 0.95rem;
	line-height: 1.55;
}
body.kr-contact-page .kr-contact-map-frame {
	line-height: 0;
	border-top: 4px solid #e56500;
	position: relative;
}
body.kr-contact-page .kr-contact-map-iframe {
	width: 100%;
	max-width: 100%;
	border: 0;
	display: block;
}
@media (max-width: 767.98px) {
	body.kr-contact-page .section.section-height-1.bg-primary.border-0.m-0 {
		margin: 0 !important;
	}
	body.kr-contact-page .kr-contact-main {
		padding-top: 1.35rem !important;
		padding-bottom: 2rem !important;
		margin-top: 0.35rem !important;
		margin-bottom: 0 !important;
		max-width: 100%;
		overflow-x: clip;
	}
	body.kr-contact-page .kr-contact-cards {
		--bs-gutter-x: 1rem;
		margin-bottom: 1.5rem !important;
	}
	body.kr-contact-page .kr-contact-cards > [class*="col-"] {
		display: flex;
	}
	body.kr-contact-page .contact-info-card {
		flex: 1 1 auto;
		width: 100%;
		min-height: 0;
		height: auto;
		overflow: visible;
	}
	body.kr-contact-page .contact-info-text {
		max-width: 100%;
		width: 100%;
	}
	body.kr-contact-page .kr-contact-form-row h2 {
		font-size: clamp(1.35rem, 5vw, 1.75rem) !important;
		margin-bottom: 0.75rem !important;
	}
	body.kr-contact-page .kr-contact-form-row > .col-12 > p {
		margin-bottom: 1.25rem !important;
		font-size: 0.95rem;
		line-height: 1.65;
	}
	body.kr-contact-page .contact-form-card {
		padding: 1.35rem 1rem 1.25rem;
		border-radius: 12px;
		box-shadow: 0 10px 28px rgba(15, 23, 42, 0.07);
	}
	body.kr-contact-page .contact-form-title {
		font-size: 1.15rem;
		margin-bottom: 1rem;
	}
	body.kr-contact-page .contact-field {
		font-size: 16px; /* prevents iOS zoom on focus */
	}
	body.kr-contact-page .contact-submit-btn {
		width: 100%;
		display: block;
	}
	body.kr-contact-page .kr-contact-map {
		margin-top: 1.75rem !important;
	}
	body.kr-contact-page .kr-contact-map-iframe {
		height: 260px !important;
		min-height: 220px;
	}
}

/* =============================================================
   ABOUT US — page-only (header untouched; matches site orange/maroon)
   ============================================================= */
body.kr-about-page-body .main {
	background: #fff;
}
.kr-about-page {
	color: #1f2937;
	padding-bottom: 2rem;
}
.kr-about-mast {
	background: linear-gradient(180deg, #fff 0%, #fafbfc 100%);
	border-bottom: 0;
}
.kr-about-mast__eyebrow {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: #6b7280;
	margin: 0;
}
.kr-about-mast__title {
	font-size: clamp(1.65rem, 2.8vw, 2.25rem);
	font-weight: 800;
	line-height: 1.2;
	color: #111827;
	letter-spacing: -0.02em;
}

.kr-about-naac-strip {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	max-width: 100%;
	padding: 0.4rem 1rem 0.4rem 0.45rem;
	background: #fff;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: 999px;
	box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
}
.kr-about-naac-strip__badge {
	flex-shrink: 0;
	line-height: 0;
}
.kr-about-naac-strip__badge img {
	width: 52px;
	height: auto;
	display: block;
}
.kr-about-naac-strip__copy {
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
	min-width: 0;
	text-align: left;
}
.kr-about-naac-strip__title {
	font-size: 0.95rem;
	font-weight: 800;
	color: #111827;
	letter-spacing: 0.01em;
	line-height: 1.2;
}
.kr-about-naac-strip__hint {
	font-size: 0.68rem;
	font-weight: 600;
	color: #9a3412;
	line-height: 1.25;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
@media (max-width: 400px) {
	.kr-about-naac-strip__hint {
		font-size: 0.62rem;
	}
}

.kr-about-stats {
	background: #fff !important;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}
.kr-about-stat__icon {
	font-size: 1.65rem !important;
	color: #c45100 !important;
	opacity: 0.92;
}
.kr-about-stat__value {
	font-size: 1.5rem;
	font-weight: 800;
	color: #111827;
	line-height: 1.1;
}
.kr-about-stat__label {
	font-size: 0.82rem;
	color: #6b7280;
	margin-top: 0.2rem;
	max-width: 12rem;
	line-height: 1.35;
}

.kr-about-container {
	/* Slightly more top padding so spacing stays balanced after removing mast border */
	padding-top: 2.35rem;
}
@media (min-width: 992px) {
	.kr-about-container {
		padding-top: 3rem;
	}
}

/* About intro: visual + why block lines up with body copy (after left rule), not above it */
@media (min-width: 992px) {
	.kr-about-intro-row {
		align-items: flex-start;
	}
	.kr-about-intro-media {
		/* Match .kr-about-divider height (4px) + its mb-4 (1.5rem) */
		padding-top: calc(4px + 1.5rem);
	}
}

.kr-about-divider {
	width: 52px;
	height: 4px;
	border-radius: 2px;
	background: linear-gradient(90deg, #a90016 0%, #e56500 100%);
}
.kr-about-prose {
	font-size: 1rem;
	line-height: 1.75;
	text-align: justify;
	color: #374151 !important;
}
.kr-about-prose h2 {
	font-size: clamp(1.2rem, 2vw, 1.35rem);
	font-weight: 800;
	color: #111827;
	margin: 2rem 0 0.85rem;
	letter-spacing: -0.01em;
	line-height: 1.35;
}
.kr-about-prose h2:first-child {
	margin-top: 0;
}
.kr-about-prose p {
	margin-bottom: 1rem;
}
.kr-about-prose ul {
	padding-left: 1.25rem;
	margin-bottom: 1rem;
}
.kr-about-prose li {
	margin-bottom: 0.35rem;
}

.kr-about-btn {
	border-radius: 8px;
	border: 2px solid #c45100;
	color: #c45100 !important;
	background: #fff;
	font-size: 0.95rem;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.kr-about-btn:hover {
	background: #c45100;
	color: #fff !important;
	border-color: #c45100;
	box-shadow: 0 8px 24px rgba(196, 81, 0, 0.22);
}

.kr-about-figure__frame {
	position: relative;
	border-radius: 14px;
	overflow: hidden;
	border: 1px solid rgba(15, 23, 42, 0.08);
	box-shadow: 0 18px 40px rgba(15, 23, 42, 0.1);
	background: #e5e7eb;
}
.kr-about-figure__frame::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 14px;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
	pointer-events: none;
}
.kr-about-figure__img {
	display: block;
	width: 100%;
	height: auto;
	min-height: 280px;
	max-height: 440px;
	object-fit: cover;
	vertical-align: middle;
}

/* Why Choose Us — minimal stack under About page image column */
.kr-about-why--minimal {
	padding-top: 0.35rem;
	border-top: 1px solid rgba(15, 23, 42, 0.07);
}
.kr-about-why__h-min {
	font-size: 1rem;
	font-weight: 800;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #374151;
	margin: 0 0 0.65rem;
}
.kr-about-why__rule-min {
	width: 36px;
	height: 3px;
	border-radius: 2px;
	margin-bottom: 1rem;
	background: linear-gradient(90deg, #a90016, #ea580c);
}
.kr-about-why__stack {
	display: flex;
	flex-direction: column;
	gap: 0;
}
.kr-about-why__row {
	display: flex;
	gap: 0.85rem;
	align-items: flex-start;
	padding: 0.85rem 0;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}
.kr-about-why__row:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}
.kr-about-why__glyph {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.35rem;
	height: 2.35rem;
	border-radius: 10px;
	background: rgba(169, 0, 22, 0.06);
	color: #a90016;
	font-size: 0.92rem;
}
.kr-about-why__copy {
	min-width: 0;
	flex: 1;
}
.kr-about-why__row-title {
	font-size: 0.88rem;
	font-weight: 800;
	line-height: 1.35;
	color: #111827;
	letter-spacing: -0.01em;
	margin-bottom: 0.35rem !important;
}
.kr-about-why__row-sub {
	font-size: 0.78rem;
	line-height: 1.55;
	color: #64748b;
	font-weight: 500;
	margin-top: 0.15rem !important;
}
@media (min-width: 992px) {
	.kr-about-why--minimal {
		padding-left: 0.125rem;
		max-width: 100%;
	}
}

.kr-about-vm-row {
	margin-top: 0.5rem;
}
.kr-about-panel {
	background: #fff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: 14px;
	padding: 1.5rem 1.5rem 1.35rem;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
	border-left: 4px solid #a90016;
}
.kr-about-panel__head {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	margin-bottom: 1rem;
}
.kr-about-panel__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 10px;
	background: rgba(196, 81, 0, 0.08);
	color: #b45309;
	font-size: 1.1rem;
	flex-shrink: 0;
}
.kr-about-panel__title {
	font-size: 1.15rem;
	font-weight: 800;
	color: #111827;
	line-height: 1.25;
}
.kr-about-panel__body {
	font-size: 0.95rem;
	line-height: 1.7;
	color: #4b5563 !important;
}
.kr-about-panel__body p:last-child {
	margin-bottom: 0;
}

.kr-about-director {
	padding: 2.25rem 0 1rem;
	margin-top: 0.5rem;
	border-top: 1px solid rgba(15, 23, 42, 0.08);
}
.kr-about-director__photo {
	max-width: 200px;
	border-radius: 50%;
	border: 4px solid #fff;
	box-shadow: 0 12px 32px rgba(15, 23, 42, 0.12);
	object-fit: cover;
	aspect-ratio: 1;
}
.kr-about-director__name {
	font-size: 1.35rem;
	font-weight: 800;
	color: #111827;
}
.kr-about-director__role {
	font-size: 0.88rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #c45100;
	margin: 0;
}
.kr-about-director__message {
	font-size: 0.98rem;
	line-height: 1.75;
	color: #4b5563 !important;
}

/* Admission FAQ page */
body.kr-admission-faq-page .admission-faq-content {
	color: #334155;
	font-size: 1rem;
	line-height: 1.75;
}

body.kr-admission-faq-page .admission-faq-content > h4.text-primary {
	color: #e56500 !important;
	font-size: 1.45rem;
	font-weight: 900;
	letter-spacing: 0;
	line-height: 1.25;
	margin: 0 0 1.25rem;
}

body.kr-admission-faq-page .admission-faq-accordion {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}

body.kr-admission-faq-page .admission-faq-card {
	background: #fff;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: 8px;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
	margin: 0;
	overflow: hidden;
}

body.kr-admission-faq-page .admission-faq-card__head {
	background: transparent;
	border: 0;
	margin: 0;
	padding: 0;
}

body.kr-admission-faq-page .admission-faq-card__toggle {
	align-items: center;
	background: #fff;
	border: 0;
	color: #0f172a;
	cursor: pointer;
	display: flex;
	font-family: "Poppins", sans-serif;
	font-size: 0.98rem;
	font-weight: 800;
	gap: 1rem;
	justify-content: space-between;
	letter-spacing: 0;
	line-height: 1.45;
	padding: 1rem 1.15rem;
	text-align: left;
	width: 100%;
}

body.kr-admission-faq-page .admission-faq-card__toggle::after {
	align-items: center;
	background: rgba(229, 101, 0, 0.09);
	border-radius: 50%;
	color: #e56500;
	content: "-";
	display: inline-flex;
	flex: 0 0 2rem;
	font-size: 1.25rem;
	font-weight: 800;
	height: 2rem;
	justify-content: center;
	line-height: 1;
	width: 2rem;
}

body.kr-admission-faq-page .admission-faq-card__toggle.collapsed::after {
	content: "+";
}

body.kr-admission-faq-page .admission-faq-card__toggle:hover,
body.kr-admission-faq-page .admission-faq-card__toggle:focus {
	color: #e56500;
	outline: none;
}

body.kr-admission-faq-page .admission-faq-card__body {
	background: #fff;
	border-top: 1px solid rgba(15, 23, 42, 0.08);
	color: #475569;
	padding: 1rem 1.15rem 1.1rem;
}

body.kr-admission-faq-page .admission-faq-card__body p,
body.kr-admission-faq-page .admission-faq-card__body ul,
body.kr-admission-faq-page .admission-faq-card__body ol {
	margin-bottom: 0.85rem;
}

body.kr-admission-faq-page .admission-faq-card__body > :last-child,
body.kr-admission-faq-page .admission-faq-card__body p:last-child {
	margin-bottom: 0;
}

@media (max-width: 767.98px) {
	body.kr-admission-faq-page .admission-faq-card__toggle {
		align-items: flex-start;
		font-size: 0.94rem;
		padding: 0.95rem 1rem;
	}

	body.kr-admission-faq-page .admission-faq-card__body {
		padding: 0.95rem 1rem;
	}
}
