/* ============================================================
 *  SVMITF — Dark Blue Modern Theme
 *  Loaded last so it overrides plugins.min / style.min / skin-*
 *  Palette tokens follow claude_code_prompt.md spec.
 * ============================================================ */

/* Prevent horizontal scrollbars site-wide */
html, body { overflow-x: hidden !important; max-width: 100% !important; }
.page-wraper { overflow-x: hidden; }

/* Force Montserrat globally for the entire site */
html, body,
h1, h2, h3, h4, h5, h6,
p, a, span, div, li, ul, ol,
button, input, select, textarea,
.btn, .nav, .navbar-nav,
.sh-modern, .site-header, .site-footer,
.hero-block, .hero-title, .hero-subtitle,
.vr-card, .vr-title, .vr-subtitle, .vr-label, .vr-input, .vr-submit {
	font-family: 'Montserrat', sans-serif !important;
}

/* Default body font-size: 16px (nav/header items keep their own explicit sizes) */
body {
	font-size: 16px !important;
	line-height: 1.6;
}

:root {
	--brand-primary:        #0A1B3D;   /* deep navy — header/footer */
	--brand-primary-2:      #0B2148;
	--brand-secondary:      #13315C;   /* secondary navy */
	--brand-secondary-2:    #1B4079;
	--brand-tertiary:       #102a4d;
	--brand-accent:         #2E6BE6;   /* primary action blue */
	--brand-accent-2:       #3B82F6;   /* lighter accent / hover */
	--brand-accent-3:       #60A5FA;
	--brand-gold:           #f5b942;   /* HEMIS teacher highlight */
	--brand-text:           #FFFFFF;
	--brand-text-muted:     #D6E0F0;
	--brand-text-dark:      #0F172A;
	--brand-bg-light:       #F5F7FB;
	--brand-bg-section:     #FFFFFF;
	--brand-border:         rgba(255, 255, 255, 0.08);
	--brand-border-strong:  rgba(255, 255, 255, 0.18);
	--brand-shadow:         0 10px 30px rgba(10, 27, 61, 0.18);
	--brand-shadow-strong:  0 20px 50px rgba(10, 27, 61, 0.35);
	--brand-radius:         8px;
	--brand-radius-lg:      16px;
	--brand-container:      1240px;
	--brand-transition:     all .25s cubic-bezier(.4, 0, .2, 1);
}

/* ===== Global focus state (WCAG) ===== */
*:focus-visible {
	outline: 3px solid var(--brand-accent-3);
	outline-offset: 3px;
	border-radius: 2px;
}
a:focus-visible, button:focus-visible { outline-color: var(--brand-accent); }

/* ===== Modern 2-bar header (sh-modern) ===== */
.sh-modern { background: var(--brand-primary); font-family: 'Poppins', 'Inter', system-ui, sans-serif; }

/* Top utility bar */
.sh-top {
	background: linear-gradient(180deg, #07142e 0%, var(--brand-primary) 100%);
	border-bottom: 1px solid var(--brand-border);
	color: var(--brand-text); font-size: 13px;
}
.sh-top-inner {
	display: flex; align-items: center; justify-content: space-between;
	min-height: 44px; padding: 6px 0; gap: 16px;
}
.sh-top a { color: var(--brand-text); transition: var(--brand-transition); text-decoration: none; }
.sh-top a:hover { color: var(--brand-accent-3); }

/* Left cluster of top bar (socials + quick links) */
.sh-top-left { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }

/* Top-bar quick links (type=2 menu items) */
.sh-top-links { display: flex; gap: 4px; align-items: center; padding: 0; margin: 0; list-style: none; }
.sh-top-links a {
	display: inline-flex; align-items: center; gap: 6px;
	color: var(--brand-text); padding: 6px 10px; border-radius: 4px;
	font-size: 12.5px; font-weight: 500; letter-spacing: .3px;
	text-decoration: none; transition: var(--brand-transition);
}
.sh-top-links a:hover { background: rgba(255, 255, 255, 0.08); color: var(--brand-accent-3); }
.sh-top-links a i { font-size: 13px; opacity: .9; }

/* Colored social squares */
.sh-socials { display: flex; gap: 6px; align-items: center; padding: 0; margin: 0; list-style: none; }
.sh-soc-btn {
	display: inline-flex; align-items: center; justify-content: center;
	width: 32px; height: 32px; border-radius: 4px;
	color: #fff !important; font-size: 15px;
	transition: var(--brand-transition);
}
.sh-soc-btn:hover { transform: translateY(-2px); color: #fff !important; filter: brightness(1.1); }
.sh-soc-btn.soc-fb { background: #1877F2; }
.sh-soc-btn.soc-ig { background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%); }
.sh-soc-btn.soc-tg { background: #229ED9; }
.sh-soc-btn.soc-yt { background: #FF0000; }
.sh-soc-btn.soc-tw { background: #1DA1F2; }

/* Right cluster */
.sh-top-right { display: flex; align-items: center; gap: 14px; padding: 0; margin: 0; list-style: none; }
.sh-top-item { display: inline-flex; align-items: center; }
.sh-top-item a { display: inline-flex; align-items: center; gap: 6px; }

/* Square icon button */
.sh-icon-btn {
	display: inline-flex; align-items: center; justify-content: center;
	width: 32px; height: 32px; border-radius: 4px;
	background: rgba(255, 255, 255, 0.08); color: var(--brand-text);
	border: 1px solid var(--brand-border); cursor: pointer;
	transition: var(--brand-transition); padding: 0;
}
.sh-icon-btn:hover { background: rgba(255, 255, 255, 0.16); color: var(--brand-accent-3); }
.sh-icon-btn i { font-size: 14px; }

/* ===== Main bar ===== */
.sh-main {
	background: linear-gradient(180deg, var(--brand-primary) 0%, var(--brand-secondary) 100%);
	border-bottom: 1px solid var(--brand-border);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
	transition: var(--brand-transition);
}
.sh-main-inner {
	display: flex; align-items: center; gap: 5px;
	min-height: 78px; padding: 10px 0;
}

/* Brand: logo + 2-line name */
.sh-brand {
	display: flex; align-items: center; gap: 12px;
	color: var(--brand-text); text-decoration: none;
	flex: 0 0 auto; max-width: 300px;
}
.sh-brand:hover { color: var(--brand-text); text-decoration: none; }
.sh-brand-logo {
	width: 52px; height: 52px; object-fit: contain;
	background: #fff; border-radius: 50%; padding: 4px;
}
.sh-brand-name {
	font-size: 14px; font-weight: 600; line-height: 1.25;
	color: var(--brand-text);
	letter-spacing: .2px;
	white-space: normal;
}

/* Nav — force-visible on desktop (Bootstrap .collapse otherwise hides it) */
.sh-nav { flex: 1 1 auto; min-width: 0; }
@media (min-width: 1200px) {
	.sh-nav.navbar-collapse.collapse { display: flex !important; }
	.sh-nav.navbar-collapse { height: auto !important; }
}
.sh-modern .sh-nav ul.navbar-nav,
.sh-modern .sh-nav .nav.navbar-nav {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	gap: 0; align-items: center; justify-content: center;
	margin: 0; padding: 0; list-style: none;
	width: 100%;
}
/* Only TOP-LEVEL nav links stay on one line — dropdown items wrap */
.sh-modern .sh-nav .nav.navbar-nav > li > a { white-space: nowrap; }
.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li > a,
.sh-modern .sh-nav .nav.navbar-nav .sub-menu li > a {
	white-space: normal; word-break: break-word; line-height: 1.4;
}
.sh-modern .sh-nav .nav.navbar-nav > li { display: list-item; flex: 0 0 auto; }

/* Kill template's underline/border animation pseudo-elements on the nav */
.sh-modern .sh-nav .nav.navbar-nav > li > a::before,
.sh-modern .sh-nav .nav.navbar-nav > li > a::after,
.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li > a::before,
.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li > a::after,
.sh-modern .sh-nav .nav.navbar-nav .sub-menu li > a::before,
.sh-modern .sh-nav .nav.navbar-nav .sub-menu li > a::after { content: none !important; display: none !important; background: transparent !important; border: none !important; }

/* Re-apply ONLY our chevron caret for has-children sub-items, positioned cleanly on the right */
.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a {
	position: relative; padding-right: 32px !important;
}
.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a::after {
	content: "\f054" !important; display: inline-block !important;
	font-family: FontAwesome; font-size: 10px; opacity: .65;
	position: absolute !important; right: 14px; top: 50%; transform: translateY(-50%);
	background: transparent !important; border: none !important;
	width: auto !important; height: auto !important; margin: 0 !important;
}
.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.has-children:hover > a::after { opacity: 1; }
.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.flip-left > a::after { content: "\f053" !important; }

/* Hide the duplicate chevron-down icon inside <a> for nested has-children items (keep it only on top-level) */
.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a > .fa-chevron-down { display: none; }
.sh-nav .nav.navbar-nav > li { position: relative; }
.sh-nav .nav.navbar-nav > li > a,
.sh-nav .header-nav .nav > li > a,
.sh-nav li > a {
	display: inline-flex; align-items: center; gap: 4px;
	color: var(--brand-text) !important;
	font-weight: 500; letter-spacing: .3px; text-transform: uppercase; font-size: 14px;
	padding: 10px 8px !important;
	border-radius: 4px;
	transition: var(--brand-transition);
}
.sh-nav .nav.navbar-nav > li > a:hover,
.sh-nav .nav.navbar-nav > li.active > a {
	color: var(--brand-accent-3) !important;
	background: rgba(255, 255, 255, 0.08);
}
.sh-nav .nav.navbar-nav > li.dropdown > a .fa-chevron-down { font-size: 10px; margin-left: 2px; }

/* Dropdown submenus */
.sh-nav .nav.navbar-nav .sub-menu,
.sh-nav .nav.navbar-nav .dropdown-menu {
	position: absolute; top: 100%; left: 0;
	background: var(--brand-secondary); border: 1px solid var(--brand-border); border-radius: var(--brand-radius);
	padding: 6px 0; min-width: 260px; max-width: 320px; box-shadow: var(--brand-shadow);
	display: none; list-style: none; margin: 0; z-index: 1100;
}
/* Invisible hover bridge so cursor can cross from parent link to dropdown without losing :hover */
.sh-nav .nav.navbar-nav li.has-children > .dropdown-menu::before {
	content: ""; position: absolute; top: -10px; left: 0; right: 0; height: 10px; background: transparent;
}
.sh-nav .nav.navbar-nav li:hover > .sub-menu,
.sh-nav .nav.navbar-nav li:hover > .dropdown-menu,
.sh-nav .nav.navbar-nav li.show > .dropdown-menu { display: block; }
.sh-nav .nav.navbar-nav .sub-menu li > a,
.sh-nav .nav.navbar-nav .dropdown-menu li > a {
	display: flex; align-items: center; justify-content: space-between; gap: 8px;
	color: var(--brand-text) !important; padding: 9px 16px !important; font-size: 14px;
	border-bottom: 1px solid var(--brand-border);
	text-transform: none; letter-spacing: .2px;
}
.sh-nav .nav.navbar-nav .sub-menu li:last-child > a,
.sh-nav .nav.navbar-nav .dropdown-menu li:last-child > a { border-bottom: none; }
.sh-nav .nav.navbar-nav .sub-menu li > a:hover,
.sh-nav .nav.navbar-nav .dropdown-menu li > a:hover {
	background: var(--brand-tertiary); color: var(--brand-accent-3) !important;
}

/* Level-3 flyout — nested dropdown opens to the right of its parent item */
.sh-nav .nav.navbar-nav .dropdown-menu li.has-children { position: relative; }
.sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a::after {
	content: "\f054"; font-family: FontAwesome; font-size: 10px; margin-left: auto; opacity: .7;
}
.sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a .fa-chevron-down { display: none; }
.sh-nav .nav.navbar-nav .dropdown-menu .dropdown-menu {
	top: 0; left: 100%; margin: 0 0 0 1px;
	min-width: 260px;
}
/* Flip flyout to the left if it would overflow the viewport edge */
.sh-nav .nav.navbar-nav .dropdown-menu li.flip-left > .dropdown-menu {
	left: auto; right: 100%; margin: 0 1px 0 0;
}
.sh-nav .nav.navbar-nav .dropdown-menu li.flip-left > a::after { content: "\f053"; }

/* Right tools cluster */
.sh-tools { display: flex; align-items: center; gap: 8px; flex: 0 0 auto; margin-left: auto; }
.sh-lang { position: relative; }
.sh-lang .dropdown-toggle {
	display: inline-flex; align-items: center; gap: 6px;
	color: var(--brand-text); cursor: pointer;
	padding: 6px 10px; border-radius: 4px;
	transition: var(--brand-transition);
}
.sh-lang .dropdown-toggle:hover { background: rgba(255, 255, 255, 0.08); }
.sh-lang-abb { font-size: 13px; font-weight: 600; letter-spacing: .5px; }
.sh-lang .dropdown-menu {
	min-width: 140px; padding: 6px 0; border: none;
	background: var(--brand-secondary); border-radius: var(--brand-radius);
	box-shadow: var(--brand-shadow); right: 0; left: auto;
}
.sh-lang .dropdown-menu .dropdown-item {
	color: var(--brand-text); padding: 8px 14px; display: flex; align-items: center; gap: 8px;
	text-decoration: none;
}
.sh-lang .dropdown-menu .dropdown-item:hover { background: var(--brand-tertiary); }
.sh-lang .dropdown-menu img { height: 14px; }

/* Mobile toggler hidden on desktop in favor of sh-menu-btn */
.sh-main .navbar-toggler { display: none; }

/* Hamburger visibility: show below 1200px, hide at 1200+ */
.sh-main .sh-menu-btn { display: none !important; }
@media (max-width: 1199px) {
	.sh-main .sh-menu-btn { display: inline-flex !important; }
}

/* Mobile drawer close button + logo header: only show inside the drawer at <1200px */
.sh-nav .mobile-nav-close { display: none !important; }
.sh-nav.navbar-collapse::before { content: none !important; display: none !important; }
@media (max-width: 1199px) {
	.sh-nav .mobile-nav-close { display: inline-flex !important; }
	.sh-nav.navbar-collapse::before {
		content: "" !important;
		display: block !important;
		height: 96px;
		background: url('/images/logo_new.png') no-repeat 24px center / 64px auto, #fff;
		border-bottom: 1px solid #e5e9ef;
	}
}

/* Sticky compact behavior disabled — was causing content shift when the header
   left the document flow on scroll. Header now scrolls away naturally with the page. */

/* Sub-1500 — tighter brand + nav */
@media (max-width: 1499px) {
	.sh-brand { max-width: 260px; }
	.sh-brand-name { font-size: 12px; }
	.sh-nav .nav.navbar-nav > li > a,
	.sh-nav .header-nav .nav > li > a,
	.sh-nav li > a {
		font-size: 13px;
		padding-left: 8px !important;
		padding-right: 8px !important;
	}
}

/* Mobile */
@media (max-width: 1199px) {
	.sh-nav .nav.navbar-nav > li > a { padding: 10px 8px !important; font-size: 12px; }
}
@media (max-width: 1199px) {
	.sh-main .navbar-toggler { display: inline-flex; }
	.sh-brand-name { font-size: 13px; max-width: 160px; }
	.sh-top-inner { flex-wrap: wrap; gap: 8px; }
	.sh-top-right .sh-top-item a span,
	.sh-top-item:not(:first-child) a { font-size: 12px; }

	/* ===== Mobile slide-in nav drawer (white panel from the left) ===== */
	body.mobile-nav-open { overflow: hidden; }

	.sh-nav.navbar-collapse,
	.sh-nav.navbar-collapse.collapse,
	.sh-nav.navbar-collapse.collapsing,
	.sh-nav.navbar-collapse.show {
		display: block !important;
		visibility: visible !important;
		position: fixed !important;
		top: 0 !important; left: 0 !important; bottom: 0 !important; right: auto !important;
		width: 86vw !important; max-width: 380px !important;
		height: 100vh !important; max-height: 100vh !important; min-height: 100vh !important;
		background: #fff !important;
		box-shadow: 4px 0 30px rgba(0, 0, 0, .25);
		z-index: 100000 !important;
		transform: translateX(-105%);
		transition: transform .35s cubic-bezier(.4, 0, .2, 1) !important;
		overflow-y: auto !important;
		padding: 0 !important;
		border: none !important;
		flex-basis: auto !important;
		margin: 0 !important;
	}
	.sh-nav.navbar-collapse.show { transform: translateX(0) !important; }

	/* Backdrop */
	.mobile-nav-backdrop {
		position: fixed; inset: 0;
		background: rgba(10, 27, 61, .55);
		z-index: 99999;
		opacity: 0; pointer-events: none;
		transition: opacity .35s ease;
	}
	body.mobile-nav-open .mobile-nav-backdrop {
		opacity: 1; pointer-events: auto;
	}

	/* Drawer header (logo + close) */
	.sh-nav.navbar-collapse::before {
		content: "";
		display: block; height: 96px; flex-shrink: 0;
		background: url('/images/logo_new.png') no-repeat 24px center / 64px auto, #fff;
		border-bottom: 1px solid #e5e9ef;
	}
	.sh-nav .mobile-nav-close {
		position: absolute; top: 22px; right: 22px;
		width: 40px; height: 40px; border-radius: 50%;
		background: #fff; border: 1px solid #e5e9ef;
		color: var(--brand-text-dark); font-size: 22px;
		cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
		z-index: 2;
	}
	.sh-nav .mobile-nav-close:hover { background: #f5f7fb; }

	/* Top-level list — high-specificity selectors to beat the desktop rules */
	.sh-modern .sh-nav.navbar-collapse .nav.navbar-nav,
	.sh-modern .sh-nav .nav.navbar-nav,
	.sh-nav .nav.navbar-nav {
		display: flex !important;
		flex-direction: column !important;
		flex-wrap: nowrap !important;
		align-items: stretch !important;
		width: 100% !important; padding: 8px 0 !important;
	}
	.sh-modern .sh-nav .nav.navbar-nav > li,
	.sh-nav .nav.navbar-nav > li {
		display: block !important; width: 100% !important; float: none !important;
		border-bottom: 1px solid #f0f3f8 !important;
		flex: 0 0 auto !important;
		padding: 0 12px !important;
	}
	.sh-modern .sh-nav .nav.navbar-nav > li:last-child,
	.sh-nav .nav.navbar-nav > li:last-child { border-bottom: none !important; }

	.sh-modern .sh-nav .nav.navbar-nav > li > a,
	.sh-nav .nav.navbar-nav > li > a {
		display: flex !important;
		flex-direction: row !important;
		align-items: center !important;
		justify-content: space-between !important;
		color: var(--brand-text-dark) !important; background: #fff !important;
		padding: 10px 16px !important;
		font-size: 14px !important; font-weight: 600 !important;
		text-transform: uppercase; letter-spacing: .3px;
		border: none !important;
		white-space: normal !important;
		gap: 10px;
		min-height: 48px;
	}
	.sh-modern .sh-nav .nav.navbar-nav > li > a:hover,
	.sh-modern .sh-nav .nav.navbar-nav > li.is-open > a,
	.sh-nav .nav.navbar-nav > li > a:hover,
	.sh-nav .nav.navbar-nav > li.is-open > a {
		color: var(--brand-accent) !important;
		background: #f5f7fb !important;
	}

	/* Top-level chevron — simple small icon (no pill) */
	.sh-modern .sh-nav .nav.navbar-nav > li.has-children > a > .fa-chevron-down,
	.sh-nav .nav.navbar-nav > li.has-children > a > .fa-chevron-down {
		display: inline-flex !important; align-items: center; justify-content: center;
		width: 22px; height: 22px;
		background: transparent !important; color: var(--brand-text-dark) !important;
		font-size: 13px;
		margin-left: 8px;
		flex-shrink: 0;
		border-radius: 0 !important;
		transition: transform .25s ease;
	}
	.sh-modern .sh-nav .nav.navbar-nav > li.has-children > a > .fa-chevron-down::before,
	.sh-nav .nav.navbar-nav > li.has-children > a > .fa-chevron-down::before {
		content: "\f054" !important; /* chevron-right when closed */
	}
	.sh-modern .sh-nav .nav.navbar-nav > li.has-children.is-open > a > .fa-chevron-down,
	.sh-nav .nav.navbar-nav > li.has-children.is-open > a > .fa-chevron-down {
		color: var(--brand-accent) !important;
		transform: rotate(90deg);
	}
	/* Keep the same icon — rotation handles open/closed visual */
	.sh-modern .sh-nav .nav.navbar-nav > li.has-children.is-open > a > .fa-chevron-down::before,
	.sh-nav .nav.navbar-nav > li.has-children.is-open > a > .fa-chevron-down::before {
		content: "\f054" !important;
	}

	/* Kill the desktop ::after caret on mobile (was rendering as a second arrow) */
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a::after,
	.sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a::after,
	.sh-modern .sh-nav .nav.navbar-nav > li.has-children > a::after,
	.sh-nav .nav.navbar-nav > li.has-children > a::after { content: none !important; display: none !important; }

	/* Sub-menus — collapsed by default, single column accordion */
	.sh-nav .nav.navbar-nav .dropdown-menu,
	.sh-nav .nav.navbar-nav .sub-menu {
		display: none !important;
		position: static !important; top: auto !important; left: auto !important; right: auto !important;
		flex-direction: column !important;
		width: 100% !important; max-width: 100% !important;
		min-width: 0 !important;
		background: #f5f7fb !important;
		border: none !important; border-radius: 0 !important;
		box-shadow: none !important;
		padding: 4px 0 !important; margin: 0 !important;
	}
	.sh-nav .nav.navbar-nav li.has-children.is-open > .dropdown-menu,
	.sh-nav .nav.navbar-nav li.has-children.is-open > .sub-menu { display: block !important; }

	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li,
	.sh-modern .sh-nav .nav.navbar-nav .sub-menu li,
	.sh-nav .nav.navbar-nav .dropdown-menu li,
	.sh-nav .nav.navbar-nav .sub-menu li {
		display: block !important; list-style: none !important;
		width: 100% !important; float: none !important;
		border: none !important;
		margin: 0 !important;
		padding: 0 0 0 24px !important;
		position: relative;
	}
	/* Line marker (dash) before each sub-item */
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li::before,
	.sh-nav .nav.navbar-nav .dropdown-menu li::before {
		content: "" !important;
		position: absolute;
		left: 6px;
		top: 0;
		bottom: 0;
		margin: auto;
		width: 12px; height: 2px;
		background: var(--brand-accent);
		border-radius: 2px;
		display: block !important;
	}

	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li > a,
	.sh-modern .sh-nav .nav.navbar-nav .sub-menu li > a,
	.sh-nav .nav.navbar-nav .dropdown-menu li > a,
	.sh-nav .nav.navbar-nav .sub-menu li > a {
		display: flex !important; align-items: center; justify-content: space-between;
		width: 100% !important;
		color: var(--brand-text-dark) !important; background: transparent !important;
		padding: 8px 14px 8px 4px !important;
		font-size: 13.5px !important; font-weight: 500 !important;
		text-transform: none !important; letter-spacing: 0 !important;
		border: none !important;
		gap: 8px;
		line-height: 1.4;
		white-space: break-spaces;
	}
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li > a:hover,
	.sh-nav .nav.navbar-nav .dropdown-menu li > a:hover { color: var(--brand-accent) !important; }

	/* Deeper nesting: indent more */
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu .dropdown-menu,
	.sh-nav .nav.navbar-nav .dropdown-menu .dropdown-menu {
		background: transparent !important; padding: 0 !important;
	}
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu .dropdown-menu li,
	.sh-nav .nav.navbar-nav .dropdown-menu .dropdown-menu li {
		padding-left: 24px !important;
	}

	/* Sub-level parent chevron: single inline arrow that rotates when open */
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a > .fa-chevron-down,
	.sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a > .fa-chevron-down {
		display: inline-flex !important; align-items: center; justify-content: center;
		width: 18px; height: 18px;
		background: transparent !important; color: var(--brand-text-dark) !important;
		font-size: 11px !important;
		padding: 0 !important; border-radius: 0 !important;
		margin-left: 6px !important;
		transition: transform .25s ease;
	}
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a > .fa-chevron-down::before,
	.sh-nav .nav.navbar-nav .dropdown-menu li.has-children > a > .fa-chevron-down::before {
		content: "\f054" !important;
	}
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.has-children.is-open > a > .fa-chevron-down,
	.sh-nav .nav.navbar-nav .dropdown-menu li.has-children.is-open > a > .fa-chevron-down {
		transform: rotate(90deg);
		color: var(--brand-accent) !important;
	}
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu li.has-children.is-open > a > .fa-chevron-down::before,
	.sh-nav .nav.navbar-nav .dropdown-menu li.has-children.is-open > a > .fa-chevron-down::before {
		content: "\f054" !important;
	}

	/* Reset the dropdown panel itself — no bg, no padding offset */
	.sh-modern .sh-nav .nav.navbar-nav .dropdown-menu,
	.sh-modern .sh-nav .nav.navbar-nav .sub-menu {
		background: transparent !important;
		padding: 4px 0 8px !important;
	}

	/* Kill template's underline pseudo elements on mobile */
	.sh-nav .nav.navbar-nav > li > a::before,
	.sh-nav .nav.navbar-nav > li > a::after,
	.sh-nav .nav.navbar-nav .dropdown-menu li > a::before,
	.sh-nav .nav.navbar-nav .dropdown-menu li > a::after { content: none !important; }
}
@media (max-width: 575px) {
	.sh-top-right { flex-wrap: wrap; justify-content: flex-end; }
	.sh-top-item a span,
	.sh-top-item a:not(:has(i)) { display: none; }
	.sh-brand-name { display: none; }
}

/* Responsive container widths */
@media (min-width: 1600px) {
	.container,
	.sh-top .container,
	.sh-main .container,
	.site-footer .container,
	.hero-block .hero-content { max-width: 1600px; padding-left: 15px; padding-right: 15px; }
}

@media (max-width: 1599px) {
	.container,
	.sh-top .container,
	.sh-main .container,
	.site-footer .container,
	.hero-block .hero-content { max-width: 100%; padding-left: 30px; padding-right: 30px; }
}

@media (max-width: 1199px) {
	.container,
	.sh-top .container,
	.sh-main .container,
	.site-footer .container,
	.hero-block .hero-content { padding-left: 12px; padding-right: 12px; }
}

/* dropdown submenus */
.site-header .header-nav .nav > li .sub-menu,
.site-header .header-nav .nav > li .dropdown-menu {
	background: var(--brand-secondary); border: 1px solid var(--brand-border); border-radius: var(--brand-radius);
	padding: 6px 0; min-width: 240px; box-shadow: var(--brand-shadow);
}
.site-header .header-nav .nav > li .sub-menu li > a,
.site-header .header-nav .nav > li .dropdown-menu li > a {
	color: var(--brand-text) !important; padding: 8px 16px !important; font-size: 13px;
	border-bottom: 1px solid var(--brand-border);
}
.site-header .header-nav .nav > li .sub-menu li:last-child > a,
.site-header .header-nav .nav > li .dropdown-menu li:last-child > a { border-bottom: none; }
.site-header .header-nav .nav > li .sub-menu li > a:hover,
.site-header .header-nav .nav > li .dropdown-menu li > a:hover {
	background: var(--brand-tertiary); color: var(--brand-accent-3) !important;
}

/* search icon in main nav */
.site-header .nav-search-btn {
	background: transparent; border: none; color: var(--brand-text);
	width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center;
	margin-left: auto; cursor: pointer; transition: var(--brand-transition);
}
.site-header .nav-search-btn:hover { color: var(--brand-accent-3); }

.search-overlay {
	position: fixed; inset: 0; background: rgba(10, 27, 61, 0.96);
	display: none; align-items: center; justify-content: center; z-index: 2000; padding: 20px;
}
.search-overlay.is-open { display: flex; }
.search-overlay .search-box { width: 100%; max-width: 700px; }
.search-overlay input[type="search"] {
	width: 100%; font-size: 28px; padding: 16px 20px; border-radius: var(--brand-radius);
	background: rgba(255, 255, 255, 0.08); border: 2px solid var(--brand-accent); color: #fff;
}
.search-overlay input[type="search"]::placeholder { color: var(--brand-text-muted); }
.search-overlay .close-search {
	position: absolute; top: 24px; right: 24px;
	width: 44px; height: 44px; border-radius: 50%; background: rgba(255, 255, 255, 0.1);
	color: #fff; border: none; font-size: 20px; cursor: pointer;
}

/* mobile nav toggle */
.navbar-toggler.navicon span { background: var(--brand-text); }

/* ===== Hero block (home) ===== */
.hero-block {
	position: relative; width: 100%; min-height: 100vh; overflow: hidden;
	color: var(--brand-text);
	background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-secondary) 100%);
}
.hero-block.hero-empty { display: flex; align-items: center; justify-content: center; text-align: center; }

.hero-slider, .hero-slider .swiper, .hero-slider .swiper-wrapper { height: 100vh; min-height: 600px; }
.hero-slider .swiper-slide { position: relative; display: flex; align-items: center; justify-content: center; text-align: center; overflow: hidden; }

.hero-block .hero-media,
.hero-block .hero-media video,
.hero-block .hero-media img {
	position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0;
}

/* Ken Burns zoom on the active slide background — duration > autoplay so slide changes before zoom ends */
.hero-slider .swiper-slide .hero-media {
	transform: scale(1.02);
	will-change: transform;
}
.hero-slider .swiper-slide-active .hero-media {
	animation: heroKenBurns 7000ms linear forwards;
}
@keyframes heroKenBurns {
	0%   { transform: scale(1.02); }
	100% { transform: scale(1.18); }
}
.hero-block .hero-overlay {
	position: absolute; inset: 0; z-index: 1;
	background: linear-gradient(180deg, rgba(10,27,61,.55) 0%, rgba(10,27,61,.75) 50%, rgba(10,27,61,.9) 100%);
}
.hero-block .hero-content {
	position: relative; z-index: 2; max-width: var(--brand-container); padding: 80px 20px 120px;
	width: 100%;
}
.hero-block .hero-logo { max-width: 110px; margin: 0 auto 24px; display: block; }
.hero-block .hero-title {
	font-size: clamp(28px, 4.2vw, 56px); line-height: 1.15; font-weight: 700;
	margin: 0 0 14px; color: var(--brand-text); letter-spacing: -.5px;
}
.hero-block .hero-subtitle {
	font-size: clamp(15px, 1.6vw, 19px); line-height: 1.55;
	color: var(--brand-text-muted); margin: 0 auto 32px; max-width: 760px;
}
.hero-block .hero-ctas {
	display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin: 0;
}
.hero-block .hero-cta {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 14px 28px; border-radius: var(--brand-radius);
	font-weight: 600; font-size: 15px; letter-spacing: .3px;
	text-transform: uppercase; text-decoration: none;
	transition: var(--brand-transition);
}
.hero-block .hero-cta.is-primary {
	background: var(--brand-accent); color: #fff; border: 2px solid var(--brand-accent);
}
.hero-block .hero-cta.is-primary:hover { background: var(--brand-accent-2); border-color: var(--brand-accent-2); transform: translateY(-2px); color: #fff; }
.hero-block .hero-cta.is-secondary {
	background: transparent; color: #fff; border: 2px solid rgba(255, 255, 255, 0.6);
}
.hero-block .hero-cta.is-secondary:hover { background: rgba(255, 255, 255, 0.1); border-color: #fff; transform: translateY(-2px); color: #fff; }
.hero-block .hero-cta.is-accent {
	background: var(--brand-gold); color: var(--brand-primary); border: 2px solid var(--brand-gold);
}
.hero-block .hero-cta.is-accent:hover { background: #ffd066; transform: translateY(-2px); color: var(--brand-primary); }

/* Swiper pagination + nav arrows */
.hero-pagination.swiper-pagination {
	position: absolute; left: 0; right: 0; bottom: 90px; z-index: 5;
	display: flex; justify-content: center; gap: 10px;
}
.hero-pagination .swiper-pagination-bullet {
	width: 40px; height: 4px; border-radius: 0; background: rgba(255,255,255,.4); opacity: 1;
	transition: background .25s ease, transform .25s ease;
}
.hero-pagination .swiper-pagination-bullet-active { background: var(--brand-accent-3); transform: scaleY(1.5); }

.hero-arrow {
	position: absolute; top: 50%; transform: translateY(-50%);
	width: 48px; height: 48px; border-radius: 50%;
	background: rgba(255,255,255,.1); color: #fff; border: 1.5px solid rgba(255,255,255,.4);
	font-size: 22px; cursor: pointer; z-index: 5;
	display: inline-flex; align-items: center; justify-content: center;
	transition: var(--brand-transition);
}
.hero-arrow:hover { background: var(--brand-accent); border-color: var(--brand-accent); transform: translateY(-50%) scale(1.05); }
.hero-arrow-prev { left: 24px; }
.hero-arrow-next { right: 24px; }
@media (max-width: 767px) {
	.hero-arrow { width: 36px; height: 36px; font-size: 16px; }
	.hero-arrow-prev { left: 8px; }
	.hero-arrow-next { right: 8px; }
}

/* Hero autoplay progress bar */
.hero-progress {
	position: absolute; left: 0; right: 0; top: 0; z-index: 1010;
	height: 4px; background: rgba(255, 255, 255, .2);
	overflow: hidden;
}
.hero-progress-bar {
	height: 100%; width: 0%;
	background: var(--brand-gold);
	box-shadow: 0 0 8px rgba(245, 185, 66, .6);
	opacity: 1;
	transition: width .1s linear, opacity .35s ease;
	transform-origin: left center;
}
.hero-progress-bar.is-resetting {
	opacity: 0;
	transition: opacity .35s ease;
}

.hero-block .scroll-down {
	position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%); z-index: 3;
	color: rgba(255, 255, 255, 0.85); background: transparent; border: none; cursor: pointer;
	font-size: 28px; animation: heroBounce 2s ease-in-out infinite;
	width: 48px; height: 48px; display: inline-flex; align-items: center; justify-content: center;
	border-radius: 50%; border: 1.5px solid rgba(255, 255, 255, 0.4);
}
.hero-block .scroll-down:hover { background: rgba(255, 255, 255, 0.1); color: #fff; }

@keyframes heroBounce {
	0%, 100% { transform: translateX(-50%) translateY(0); }
	50%      { transform: translateX(-50%) translateY(8px); }
}

@media (max-width: 767px) {
	.hero-block { min-height: 75vh; }
	.hero-block .hero-content { padding: 60px 16px 90px; }
}

/* ===== Footer ===== */
.site-footer {
	background: var(--brand-primary);
	color: var(--brand-text-muted);
}
.site-footer .footer-top {
	background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-secondary) 100%) !important;
	background-image: none !important;
	padding: 70px 0 50px;
}
.site-footer .footer-top .row > [class*="col-"] { margin-bottom: 24px; }
.site-footer .footer-top .row > [class*="col-"]:last-child { margin-bottom: 0; }
.site-footer .footer-title {
	color: var(--brand-text); position: relative; padding-bottom: 12px; margin-bottom: 18px;
	font-weight: 600; text-transform: uppercase; letter-spacing: .5px; font-size: 16px;
}
.site-footer .footer-title::after {
	content: ""; position: absolute; left: 0; bottom: 0;
	width: 40px; height: 3px; background: var(--brand-accent);
}
.site-footer .contact-info-bx { padding: 0; margin: 0; list-style: none; }
.site-footer .contact-info-bx li { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px dashed var(--brand-border); color: var(--brand-text-muted); }
.site-footer .contact-info-bx li:last-child { border-bottom: none; }
.site-footer .contact-info-bx li i {
	flex: 0 0 32px !important;
	width: 32px !important;
	min-width: 32px !important;
	max-width: 32px !important;
	height: 32px !important;
	min-height: 32px !important;
	max-height: 32px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	align-self: flex-start;
	background: var(--brand-accent) !important;
	color: #fff !important;
	border-radius: 50% !important;
	font-size: 14px !important;
	padding: 0 !important;
	position: relative !important;
	top: auto !important; left: auto !important; right: auto !important;
	margin-top: 2px;
}
.site-footer .contact-info-bx li a { color: var(--brand-text-muted); }
.site-footer .contact-info-bx li a:hover { color: var(--brand-accent-3); }

.site-footer .thsn-timelist-list { padding: 0; margin: 0; list-style: none; }
.site-footer .thsn-timelist-list li {
	display: flex; justify-content: space-between; padding: 10px 0;
	border-bottom: 1px dashed var(--brand-border); color: var(--brand-text-muted);
}
.site-footer .thsn-timelist-list li:last-child { border-bottom: none; }
.site-footer .thsn-timelist-li-title { font-weight: 600; color: var(--brand-text); }

/* footer socials */
.site-footer .footer-socials { display: flex; gap: 10px; margin-top: 14px; padding: 0; list-style: none; }
.site-footer .footer-socials a {
	width: 38px; height: 38px; border-radius: 50%; background: rgba(255, 255, 255, 0.06);
	color: var(--brand-text); display: inline-flex; align-items: center; justify-content: center;
	transition: var(--brand-transition);
}
.site-footer .footer-socials a:hover { background: var(--brand-accent); transform: translateY(-2px); color: #fff; }

.site-footer iframe { border-radius: var(--brand-radius); min-height: 280px; }
.site-footer .footer-bottom {
	background: #050f25; color: var(--brand-text-muted); padding: 18px 0; border-top: 1px solid var(--brand-border);
}
.site-footer .footer-bottom span, .site-footer .footer-bottom a { color: var(--brand-text-muted); }

/* ===== Buttons ===== */
.btn-primary, .btn.btn-primary {
	background: var(--brand-accent); border-color: var(--brand-accent); color: #fff;
}
.btn-primary:hover, .btn.btn-primary:hover { background: var(--brand-accent-2); border-color: var(--brand-accent-2); }
.scroltop { background: var(--brand-accent) !important; color: #fff !important; }
.scroltop:hover { background: var(--brand-accent-2) !important; }

/* ===== Accessibility side panel ===== */
.a11y-panel {
	position: fixed; top: 0; right: 0; bottom: 0;
	width: 320px; max-width: 90vw;
	background: var(--brand-secondary);
	color: var(--brand-text);
	z-index: 99999;
	box-shadow: -10px 0 30px rgba(0, 0, 0, .3);
	transform: translateX(100%);
	transition: transform .35s cubic-bezier(.4, 0, .2, 1);
	display: flex; flex-direction: column;
	overflow-y: auto;
}
.a11y-panel:not([hidden]) { display: flex; }
.a11y-panel.is-open { transform: translateX(0); }

.a11y-backdrop {
	position: fixed; inset: 0; background: rgba(0, 0, 0, .35); z-index: 99998;
	opacity: 0; transition: opacity .35s ease; pointer-events: none;
}
.a11y-backdrop.is-open { opacity: 1; pointer-events: auto; }

.a11y-panel-head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 18px 20px; border-bottom: 1px solid var(--brand-border);
}
.a11y-panel-title { font-size: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: .4px; color: var(--brand-text); }
.a11y-panel-close {
	background: rgba(255, 255, 255, .08); border: none; color: var(--brand-text);
	width: 32px; height: 32px; border-radius: 50%; cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center;
	transition: var(--brand-transition);
}
.a11y-panel-close:hover { background: rgba(255, 255, 255, .18); color: var(--brand-accent-3); }

.a11y-panel-body { padding: 16px 20px 24px; display: flex; flex-direction: column; gap: 22px; }

.a11y-section {}
.a11y-section-title {
	display: flex; justify-content: space-between; align-items: center;
	font-size: 12px; text-transform: uppercase; letter-spacing: .5px;
	color: var(--brand-text-muted); margin: 0 0 10px;
	padding-bottom: 8px; border-bottom: 1px solid var(--brand-border);
}
.a11y-fs-label { color: var(--brand-text); font-weight: 600; text-transform: none; letter-spacing: 0; }

.a11y-stack { display: flex; flex-direction: column; gap: 8px; }
.a11y-row { display: flex; gap: 8px; flex-wrap: wrap; }

.a11y-btn {
	background: #fff; color: var(--brand-text-dark);
	border: 2px solid transparent;
	border-radius: 6px; padding: 10px 14px;
	font-size: 14px; font-weight: 600; cursor: pointer;
	transition: var(--brand-transition);
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	min-height: 40px; width: 100%;
}
.a11y-btn:hover { border-color: var(--brand-accent); }
.a11y-btn.is-active { border-color: var(--brand-accent); outline: 2px solid var(--brand-accent-3); outline-offset: -4px; }

.a11y-theme-btn {
	width: 44px; height: 44px; border-radius: 6px; padding: 0;
	font-weight: 700; font-size: 16px;
	display: inline-flex; align-items: center; justify-content: center;
	border: 2px solid transparent; cursor: pointer;
	transition: var(--brand-transition); flex: 0 0 auto;
}
.a11y-theme-btn.is-active { border-color: var(--brand-accent); outline: 2px solid var(--brand-accent-3); outline-offset: -4px; }
.a11y-theme-default { background: #fff; color: #000; }
.a11y-theme-black   { background: #000; color: #fff; }
.a11y-theme-blue    { background: #99c2ff; color: #0A1B3D; }
.a11y-theme-beige   { background: #f5e6c8; color: #3b2f1c; }
.a11y-theme-green   { background: #3a4a2e; color: #c4d49e; }

.a11y-img-btn { width: auto; padding: 10px; min-height: 44px; }
.a11y-img-btn i { font-size: 18px; }

/* Locking body scroll when panel open */
body.a11y-locked { overflow: hidden; }

/* ===== Accessibility body modes ===== */
/* Image controls */
body.a11y-img-hidden img,
body.a11y-img-hidden video,
body.a11y-img-hidden iframe { visibility: hidden !important; }
body.a11y-img-gray img,
body.a11y-img-gray video,
body.a11y-img-gray iframe { filter: grayscale(100%) !important; }

/* Theme: BLACK (high contrast — black bg, white text) */
body.a11y-theme-black,
body.a11y-theme-black * { color: #fff !important; background-image: none !important; }
body.a11y-theme-black,
body.a11y-theme-black header, body.a11y-theme-black footer,
body.a11y-theme-black .site-header, body.a11y-theme-black .site-footer,
body.a11y-theme-black .sh-modern, body.a11y-theme-black .sh-top, body.a11y-theme-black .sh-main,
body.a11y-theme-black .hero-block, body.a11y-theme-black .hero-overlay { background: #000 !important; }
body.a11y-theme-black a { color: #ffff66 !important; text-decoration: underline !important; }

/* Theme: BLUE — pale blue bg, dark navy text */
body.a11y-theme-blue,
body.a11y-theme-blue * { color: #0A1B3D !important; background-image: none !important; }
body.a11y-theme-blue,
body.a11y-theme-blue header, body.a11y-theme-blue footer,
body.a11y-theme-blue .site-header, body.a11y-theme-blue .site-footer,
body.a11y-theme-blue .sh-modern, body.a11y-theme-blue .sh-top, body.a11y-theme-blue .sh-main,
body.a11y-theme-blue .hero-block, body.a11y-theme-blue .hero-overlay { background: #d6e4ff !important; }
body.a11y-theme-blue a { color: #0A1B3D !important; text-decoration: underline !important; font-weight: 700; }

/* Theme: BEIGE — sepia bg, brown text */
body.a11y-theme-beige,
body.a11y-theme-beige * { color: #3b2f1c !important; background-image: none !important; }
body.a11y-theme-beige,
body.a11y-theme-beige header, body.a11y-theme-beige footer,
body.a11y-theme-beige .site-header, body.a11y-theme-beige .site-footer,
body.a11y-theme-beige .sh-modern, body.a11y-theme-beige .sh-top, body.a11y-theme-beige .sh-main,
body.a11y-theme-beige .hero-block, body.a11y-theme-beige .hero-overlay { background: #f7eed6 !important; }
body.a11y-theme-beige a { color: #5a3a0a !important; text-decoration: underline !important; font-weight: 600; }

/* Theme: GREEN — dark green bg, light green text */
body.a11y-theme-green,
body.a11y-theme-green * { color: #c4d49e !important; background-image: none !important; }
body.a11y-theme-green,
body.a11y-theme-green header, body.a11y-theme-green footer,
body.a11y-theme-green .site-header, body.a11y-theme-green .site-footer,
body.a11y-theme-green .sh-modern, body.a11y-theme-green .sh-top, body.a11y-theme-green .sh-main,
body.a11y-theme-green .hero-block, body.a11y-theme-green .hero-overlay { background: #2b3a22 !important; }
body.a11y-theme-green a { color: #e6f0c0 !important; text-decoration: underline !important; }

/* ===== Education Types section ===== */
.edu-types {
	background: var(--brand-bg-light);
	padding: 70px 0 80px;
}
.edu-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
@media (max-width: 1199px) { .edu-grid { grid-template-columns: 1fr; gap: 18px; } }

.edu-card {
	background: #fff;
	border-radius: var(--brand-radius-lg);
	padding: 40px 30px;
	border: 1px solid rgba(10, 27, 61, .05);
	box-shadow: 0 4px 18px rgba(10, 27, 61, .06);
	transition: var(--brand-transition);
	text-align: center;
	display: flex; flex-direction: column;
}
.edu-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 18px 40px rgba(10, 27, 61, .14);
	border-color: var(--brand-accent);
}
.edu-card-icon {
	width: 80px; height: 80px;
	border-radius: 50%;
	border: 2px solid var(--brand-primary);
	color: var(--brand-primary);
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 32px;
	margin: 0 auto 22px;
	transition: var(--brand-transition);
}
.edu-card:hover .edu-card-icon {
	background: var(--brand-accent); border-color: var(--brand-accent); color: #fff;
	transform: scale(1.05);
}
.edu-card-title {
	font-size: 22px; font-weight: 600;
	color: var(--brand-text-dark);
	margin: 0 0 14px;
	letter-spacing: -.2px;
}
.edu-card-desc {
	color: #5d6c83; font-size: 14.5px; line-height: 1.55;
	margin: 0 0 24px;
	flex: 1;
}
.edu-card-link {
	display: inline-flex; align-items: center; gap: 8px;
	color: var(--brand-primary); font-weight: 600;
	font-size: 14px; letter-spacing: .3px;
	border-bottom: 1px solid var(--brand-primary);
	padding-bottom: 4px; align-self: center;
	text-decoration: none;
	transition: var(--brand-transition);
}
.edu-card-link:hover { color: var(--brand-accent); border-bottom-color: var(--brand-accent); text-decoration: none; }
.edu-card-link i { font-size: 12px; transition: transform .25s ease; }
.edu-card-link:hover i { transform: rotate(45deg) translate(4px, -4px); }

/* ===== Interactive Services section ===== */
.interactive-services {
	background: var(--brand-bg-light);
	padding: 70px 0 80px;
}
.is-head { text-align: center; margin-bottom: 50px; }
.is-title {
	font-size: clamp(24px, 3vw, 38px); font-weight: 800;
	color: var(--brand-primary); letter-spacing: -.5px; margin: 0 0 6px;
}
.is-underline { display: block; width: 220px; max-width: 60%; height: 12px; margin: 0 auto; }

.is-grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px;
}
@media (max-width: 1199px) { .is-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; } }
@media (max-width: 575px) { .is-grid { grid-template-columns: 1fr; gap: 14px; } }

.is-card {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	background: #fff; color: var(--brand-text-dark); text-decoration: none;
	padding: 36px 18px; border-radius: var(--brand-radius-lg);
	box-shadow: 0 4px 16px rgba(10, 27, 61, .06);
	border: 1px solid rgba(10, 27, 61, .04);
	transition: var(--brand-transition);
	min-height: 180px; text-align: center;
}
.is-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(10, 27, 61, .14);
	border-color: var(--brand-accent);
	color: var(--brand-primary);
	text-decoration: none;
}
.is-card-icon {
	width: 64px; height: 64px; display: inline-flex; align-items: center; justify-content: center;
	font-size: 30px; color: var(--brand-primary);
	background: transparent; margin-bottom: 16px;
	transition: var(--brand-transition);
}
.is-card:hover .is-card-icon {
	color: #fff; background: var(--brand-accent); border-radius: 50%;
	transform: scale(1.05);
}
.is-card-title {
	font-size: 13px; font-weight: 700; letter-spacing: .6px;
	text-transform: uppercase; line-height: 1.3;
	color: inherit;
}

/* ===== Unified section head (applies to all home widgets) ===== */
.section-head.text-center,
.section-head { margin-bottom: 44px !important; text-align: center; }
.section-head.text-center .title,
.section-head .title {
	font-size: clamp(22px, 2.8vw, 34px) !important;
	font-weight: 600 !important;
	color: var(--brand-text-dark) !important;
	letter-spacing: -.3px !important;
	margin: 0 0 14px !important;
	display: inline-block;
	position: relative;
	text-transform: none;
}
.section-head.text-center .title::first-letter,
.section-head .title::first-letter { text-transform: uppercase; }
.section-head.text-center .title::after,
.section-head .title::after {
	content: "" !important;
	display: block;
	width: 220px; max-width: 60%;
	height: 12px;
	margin: 12px auto 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 12' preserveAspectRatio='none'><path d='M2 8 Q 60 -2 110 6 T 218 6' fill='none' stroke='%233B82F6' stroke-width='3' stroke-linecap='round'/></svg>");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100% 100%;
	position: static !important;
	background-color: transparent !important;
}

/* News section — modern card design */
.last-news.section-full {
	background: var(--brand-bg-light) !important;
	padding: 70px 0 80px;
}
.last-news .dlab-blog-grid-3 {
	display: flex !important;
	flex-wrap: wrap !important;
	align-items: stretch !important;
	margin: 0 -12px;
}
.last-news .dlab-blog-grid-3 > .post.card-container {
	padding: 12px;
	display: flex !important;
	flex-direction: column;
	position: relative !important;
	float: none !important;
}
.last-news .dlab-blog-grid-3 > .post.card-container > .blog-post {
	width: 100% !important;
	height: 100% !important;
	min-height: 100% !important;
	flex: 1 1 auto;
}
.last-news .blog-post.blog-grid {
	background: #fff;
	border-radius: var(--brand-radius-lg) !important;
	box-shadow: 0 4px 18px rgba(10, 27, 61, .07);
	border: 1px solid rgba(10, 27, 61, .04);
	overflow: hidden;
	transition: var(--brand-transition);
	display: flex !important; flex-direction: column !important;
	height: 100% !important;
	min-height: 100% !important;
}
.last-news .blog-post.blog-grid .dlab-post-media { flex: 0 0 auto; }
.last-news .dlab-info .post-title { min-height: 64px; }
.last-news .blog-post.blog-grid:hover {
	transform: translateY(-6px);
	box-shadow: 0 18px 40px rgba(10, 27, 61, .14);
	border-color: var(--brand-accent);
}
.last-news .dlab-post-media { position: relative; overflow: hidden; aspect-ratio: 16 / 10; background: #f0f3f8; }
.last-news .dlab-post-media a, .last-news .dlab-post-media img {
	display: block; width: 100%; height: 100%; object-fit: cover;
	transition: transform .5s ease;
}
.last-news .blog-post.blog-grid:hover .dlab-post-media img { transform: scale(1.06); }
.last-news .dlab-info { padding: 22px !important; display: flex; flex-direction: column; flex: 1; }
.last-news .dlab-info .post-tag a {
	display: inline-flex; align-items: center; gap: 6px;
	color: var(--brand-accent) !important; font-size: 12px; font-weight: 600;
	text-transform: uppercase; letter-spacing: .4px;
	padding: 4px 0;
}
.last-news .dlab-info .post-tag a i { color: var(--brand-accent); }
.last-news .dlab-info .post-title a {
	color: var(--brand-text-dark) !important;
	font-size: 16px; font-weight: 700; line-height: 1.35;
	display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
	overflow: hidden; text-decoration: none;
}
.last-news .dlab-info .post-title a:hover { color: var(--brand-accent) !important; }
.last-news .dlab-post-text { color: #5d6c83; font-size: 13.5px; line-height: 1.55; margin: 8px 0 14px; }
.last-news .dlab-post-text p { margin: 0; }
.last-news .post-footer {
	margin-top: auto;
	display: flex; align-items: center; justify-content: space-between; gap: 12px;
	padding-top: 14px; border-top: 1px dashed #e5e9ef;
}
.last-news .post-footer .post-date {
	color: var(--brand-accent); font-size: 13px; font-weight: 600;
	display: inline-flex; align-items: center; gap: 6px;
}
.last-news .post-footer .post-date i { font-size: 14px; }
.last-news .post-footer .dez-border .btn.btn-primary {
	background: var(--brand-accent); border-color: var(--brand-accent);
	color: #fff; padding: 8px 18px; font-size: 12px;
	font-weight: 600; letter-spacing: .3px; border-radius: var(--brand-radius);
	transition: var(--brand-transition);
}
.last-news .post-footer .dez-border .btn.btn-primary:hover {
	background: var(--brand-accent-2); border-color: var(--brand-accent-2);
	transform: translateY(-1px);
}

/* ===== Home gallery slider (40 images / 4 slides of 10) ===== */
.home-gallery { padding: 70px 0 80px; background: #fff; }
.hg-slider-wrap { position: relative; }
.hg-swiper { overflow: hidden; border-radius: 16px; box-shadow: 0 6px 24px rgba(10, 27, 61, .10); }
.hg-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-template-rows: repeat(2, 1fr);
	gap: 0;
}
@media (max-width: 1199px) { .hg-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 575px) { .hg-grid { grid-template-columns: repeat(2, 1fr); } }

.hg-item {
	position: relative;
	display: block; overflow: hidden;
	aspect-ratio: 1 / 1;
	background: #f0f3f8;
}
.hg-item img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .5s ease;
}
.hg-item:hover img { transform: scale(1.08); }

.hg-overlay {
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: center;
	background: rgba(10, 27, 61, .55);
	color: #fff; font-size: 28px;
	opacity: 0;
	transition: opacity .25s ease;
}
.hg-item:hover .hg-overlay { opacity: 1; }

/* Gallery slider arrows */
.hg-arrow {
	position: absolute; top: 50%; transform: translateY(-50%);
	width: 44px; height: 44px; border-radius: 50%;
	background: #fff; color: var(--brand-primary);
	border: none; box-shadow: 0 6px 16px rgba(10, 27, 61, .15);
	font-size: 20px; cursor: pointer; z-index: 5;
	display: inline-flex; align-items: center; justify-content: center;
	transition: var(--brand-transition);
}
.hg-arrow:hover { background: var(--brand-accent); color: #fff; transform: translateY(-50%) scale(1.06); }
.hg-arrow-prev { left: -22px; }
.hg-arrow-next { right: -22px; }
.hg-arrow.swiper-button-disabled { opacity: .35; pointer-events: none; }
@media (max-width: 767px) { .hg-arrow-prev { left: 4px; } .hg-arrow-next { right: 4px; } }

/* Gallery pagination dots */
.hg-pagination.swiper-pagination {
	position: absolute; left: 0; right: 0; bottom: 12px; z-index: 5;
	display: flex; justify-content: center; gap: 8px;
}
.hg-pagination .swiper-pagination-bullet {
	width: 10px; height: 10px; border-radius: 50%; background: rgba(255, 255, 255, .65);
	opacity: 1; transition: var(--brand-transition);
}
.hg-pagination .swiper-pagination-bullet-active { background: var(--brand-accent); width: 26px; border-radius: 5px; }

.hg-all-cta { display: flex; justify-content: center; margin-top: 40px; }

/* ===== Useful Links (partners) section ===== */
.useful-links {
	background: #fff;
	padding: 70px 0 80px;
}
.ul-head { margin-bottom: 40px; text-align: center; }
.ul-title {
	font-size: clamp(22px, 2.8vw, 34px); font-weight: 600;
	color: var(--brand-text-dark); letter-spacing: -.3px; margin: 0 0 6px;
}
.ul-underline { display: block; width: 220px; max-width: 60%; height: 12px; margin: 0 auto; }

.ul-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 0;
	border-top: 1px solid #eef0f4;
	border-left: 1px solid #eef0f4;
}
@media (max-width: 1199px) { .ul-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 767px)  { .ul-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 479px)  { .ul-grid { grid-template-columns: repeat(2, 1fr); } }

.ul-card {
	position: relative;
	display: flex; align-items: center; justify-content: center;
	min-height: 160px; padding: 24px;
	background: #fff;
	border-right: 1px solid #eef0f4;
	border-bottom: 1px solid #eef0f4;
	transition: var(--brand-transition);
	text-decoration: none;
}
.ul-card:hover {
	background: var(--brand-bg-light);
	box-shadow: 0 12px 30px rgba(10, 27, 61, .10);
	z-index: 2;
}
.ul-logo {
	max-width: 100%; max-height: 80px; width: auto; height: auto;
	object-fit: contain;
	filter: grayscale(0%);
	transition: var(--brand-transition);
}
.ul-card:hover .ul-logo { transform: scale(1.05); }

.ul-tooltip {
	position: absolute; bottom: calc(100% - 8px); left: 50%; transform: translate(-50%, 6px);
	background: var(--brand-accent); color: #fff;
	font-size: 13px; font-weight: 500; line-height: 1.35;
	padding: 10px 18px; border-radius: 6px;
	white-space: normal; width: max-content; max-width: 420px; min-width: 200px;
	text-align: center;
	opacity: 0; pointer-events: none; visibility: hidden;
	transition: opacity .2s ease, transform .2s ease, visibility .2s;
	box-shadow: 0 6px 18px rgba(10, 27, 61, .25);
	z-index: 3;
}
.ul-tooltip::after {
	content: ""; position: absolute; left: 50%; top: 100%;
	transform: translateX(-50%);
	border: 6px solid transparent; border-top-color: var(--brand-accent);
}
.ul-card:hover .ul-tooltip {
	opacity: 1; visibility: visible; transform: translate(-50%, 0);
}

/* ===== Counter Stats section ===== */
.counter-stats {
	background: linear-gradient(135deg, #103a8e 0%, var(--brand-accent) 60%, #4a86ff 100%);
	color: #fff;
	padding: 70px 0;
	position: relative; overflow: hidden;
}
.counter-stats::before {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(circle at 20% 30%, rgba(255,255,255,.10) 0, transparent 45%),
	            radial-gradient(circle at 80% 70%, rgba(255,255,255,.07) 0, transparent 50%);
	pointer-events: none;
}
.counter-stats .container { position: relative; z-index: 1; }
.counter-grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px;
	text-align: center;
}
@media (max-width: 1199px) { .counter-grid { grid-template-columns: repeat(2, 1fr); gap: 28px; } }
@media (max-width: 575px) { .counter-grid { grid-template-columns: 1fr; gap: 20px; } }

.counter-item { padding: 10px 8px; }
.counter-icon { font-size: 32px; color: rgba(255, 255, 255, .85); margin-bottom: 8px; }
.counter-value {
	display: inline-flex; align-items: baseline; gap: 2px;
	font-weight: 800; font-size: clamp(40px, 5vw, 64px); line-height: 1;
	color: #fff; letter-spacing: -1px;
	margin-bottom: 10px;
}
.counter-suffix { font-weight: 800; }
.counter-label {
	font-size: clamp(14px, 1.2vw, 17px); font-weight: 500;
	color: rgba(255, 255, 255, .9); letter-spacing: .2px;
}

/* ===== News "All" CTA (home page) ===== */
.news-all-cta { display: flex; justify-content: center; margin-top: 30px; width: 100%; flex-basis: 100%; }
.btn-all-news {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 14px 32px; border-radius: var(--brand-radius);
	background: var(--brand-accent); color: #fff; border: 2px solid var(--brand-accent);
	font-weight: 600; font-size: 14px; letter-spacing: .3px; text-transform: uppercase;
	transition: var(--brand-transition); text-decoration: none;
}
.btn-all-news:hover { background: var(--brand-accent-2); border-color: var(--brand-accent-2); color: #fff; transform: translateY(-2px); }
.btn-all-news i { font-size: 13px; }

/* ===== Inner page banner — hidden, replaced by breadcrumb card ===== */
.dlab-bnr-inr,
.page-content .dlab-bnr-inr { display: none !important; }
.dlab-bnr-inr::before {
	content: ""; position: absolute; inset: 0;
	background:
		radial-gradient(circle at 20% 20%, rgba(255, 255, 255, .07) 0%, transparent 40%),
		radial-gradient(circle at 80% 80%, rgba(255, 255, 255, .05) 0%, transparent 50%);
	pointer-events: none;
}
.dlab-bnr-inr > .container { position: relative; z-index: 1; }
.dlab-bnr-inr-entry { max-width: 980px; }
.dlab-bnr-inr h1,
.dlab-bnr-inr h1.text-white {
	font-size: clamp(24px, 3vw, 36px);
	font-weight: 700;
	color: #fff !important;
	margin: 0 0 14px;
	letter-spacing: -.3px;
	line-height: 1.25;
}

/* Hide the legacy in-banner breadcrumb if any view still has it */
.dlab-bnr-inr .breadcrumb-row { display: none !important; }

/* Breadcrumb card — sits inside .container, above the content */
.svm-crumb {
	background: transparent;
	padding: 0;
	margin: 50px 0 !important;
	font-size: 16px;
}
.svm-crumb .container > ol {
	display: flex; flex-wrap: wrap; align-items: center; gap: 4px;
	margin: 0; padding: 10px 18px; list-style: none;
	background: #fff;
	border-radius: var(--brand-radius);
	box-shadow: 0 2px 12px rgba(10, 27, 61, .06);
	border: 1px solid rgba(10, 27, 61, .04);
}
.svm-crumb li {
	color: #5d6c83;
	display: inline-flex; align-items: center;
	max-width: 100%;
}
.svm-crumb li + li::before {
	content: "\f105"; font-family: FontAwesome;
	margin: 0 10px;
	color: #b8c3d4;
	font-size: 12px;
}
.svm-crumb li a {
	color: var(--brand-accent);
	text-decoration: none;
	font-weight: 500;
	display: inline-flex; align-items: center; gap: 6px;
	transition: var(--brand-transition);
}
.svm-crumb li a:hover { color: var(--brand-primary); }
.svm-crumb li a i { font-size: 13px; opacity: .85; }
.svm-crumb li[aria-current="page"] {
	color: var(--brand-text-dark);
	font-weight: 600;
}
@media (max-width: 575px) {
	.svm-crumb .container > ol { padding: 10px 14px; font-size: 12.5px; }
	.svm-crumb li + li::before { margin: 0 6px; }
}

/* Content area: no padding, brand-light background to match home page sections */
.page-content,
.page-content .section-full.content-inner,
.page-content .content-area {
	padding: 0 !important;
	background: var(--brand-bg-light) !important;
}
.svm-crumb { background: var(--brand-bg-light); }

/* News listings (view-all, by-cat): small consistent gap before footer, matching news/view & home */
.page-content .section-full.content-inner {
	padding-top: 24px !important;
	padding-bottom: 0 !important;
}
.page-content .pagination-area { margin-top: 16px; margin-bottom: 0; }

/* Leader/view-all: leadership grid cards (override templete.min.css defaults) */
.page-content .dlab-team1 {
	background: #fff !important;
	border-radius: var(--brand-radius-lg);
	box-shadow: 0 4px 20px rgba(10, 27, 61, .07);
	border: 1px solid rgba(10, 27, 61, .04);
	overflow: hidden;
	transition: transform .2s ease, box-shadow .2s ease;
	display: flex;
	flex-direction: column;
}
.page-content .dlab-team1:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 28px rgba(10, 27, 61, .12);
}
.page-content .dlab-team1 .dlab-media {
	position: relative;
	overflow: hidden;
	aspect-ratio: 1;
	background: #f0f3f8;
}
.page-content .dlab-team1 .dlab-media a,
.page-content .dlab-team1 .dlab-media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.page-content .dlab-team1 .dlab-info {
	background: #fff !important;
	padding: 18px 20px 20px !important;
	text-align: center;
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-top: 1px solid rgba(10, 27, 61, .05);
}
.page-content .dlab-team1 .dlab-info::before,
.page-content .dlab-team1 .dlab-info::after { display: none !important; }
.page-content .dlab-team1 .dlab-title,
.page-content .dlab-team1 .dlab-title a {
	color: var(--brand-primary) !important;
	font-size: 16px;
	font-weight: 700;
	margin: 0 0 15px;
	text-transform: none;
	letter-spacing: 0;
}
.page-content .dlab-team1 .dlab-title a:hover { color: var(--brand-accent) !important; }
.page-content .dlab-team1 .position {
	color: #6b7a90 !important;
	font-size: 13px;
	line-height: 1.4;
}
.page-content .dlab-team1 .dlab-social-icon { display: none; }

/* Leader/view: single card wrapping the photo and the bio side-by-side */
.page-content .leader-card {
	background: #fff;
	border-radius: var(--brand-radius-lg);
	box-shadow: 0 4px 20px rgba(10, 27, 61, .07);
	border: 1px solid rgba(10, 27, 61, .04);
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
}
.page-content .leader-card__photo {
	flex: 0 0 38%;
	max-width: 38%;
	background: #f5f7fb;
	border-right: 1px solid rgba(10, 27, 61, .06);
}
.page-content .leader-card__photo img {
	width: 100%;
	height: auto;
	display: block;
}
.page-content .leader-card__meta {
	padding: 20px 24px 24px;
	border-top: 1px solid rgba(10, 27, 61, .06);
}
.page-content .leader-card__name {
	color: var(--brand-primary);
	font-size: 18px;
	font-weight: 700;
	margin: 0 0 4px;
}
.page-content .leader-card__position {
	color: #6b7a90;
	font-size: 14px;
}
.page-content .leader-card__body {
	flex: 1 1 0;
	min-width: 0;
	padding: 32px;
}
.page-content .leader-card__heading {
	color: var(--brand-primary);
	font-size: 22px;
	font-weight: 700;
	margin: 0 0 18px;
}
.page-content .leader-card__bio p { margin-bottom: 12px; }
.page-content .leader-card__bio ul,
.page-content .leader-card__bio ol { margin: 0 0 14px 20px; }
.page-content .leader-card__bio ul li,
.page-content .leader-card__bio ol li { margin-bottom: 8px; }

@media (max-width: 991px) {
	.page-content .leader-card__photo,
	.page-content .leader-card__body {
		flex: 0 0 100%;
		max-width: 100%;
		border-right: none;
	}
	.page-content .leader-card__body { padding: 22px; }
}

/* ===== Inner content area ===== */
.page-content { background: var(--brand-bg-light) !important; }

/* ===== Single news article ===== */
.page-content .blog-post.blog-single {
	background: #fff;
	border-radius: var(--brand-radius-lg);
	box-shadow: 0 4px 20px rgba(10, 27, 61, .07);
	border: 1px solid rgba(10, 27, 61, .04);
	overflow: hidden;
}
.page-content .blog-post.blog-single .dlab-info { padding: 32px !important; }
.page-content .blog-post.blog-single .dlab-post-meta ul {
	display: flex; flex-wrap: wrap; gap: 16px;
	margin: 0 0 18px; padding: 0; list-style: none;
}
.page-content .blog-post.blog-single .dlab-post-meta li {
	display: inline-flex; align-items: center; gap: 6px;
	color: #5d6c83; font-size: 13px;
}
.page-content .blog-post.blog-single .dlab-post-meta li i { color: var(--brand-accent); font-size: 13px; }
.page-content .blog-post.blog-single .dlab-post-meta li a {
	color: var(--brand-accent); font-weight: 600;
	transition: var(--brand-transition);
}
.page-content .blog-post.blog-single .dlab-post-meta li a:hover { color: var(--brand-accent-2); }
.page-content .blog-post.blog-single .dlab-title {
	color: var(--brand-primary);
	font-size: clamp(22px, 2.4vw, 30px);
	font-weight: 700; line-height: 1.3;
	margin: 0 0 22px; letter-spacing: -.3px;
}
.page-content .blog-post.blog-single .dlab-media {
	border-radius: var(--brand-radius);
	overflow: hidden; margin: 0 0 24px;
	box-shadow: 0 6px 20px rgba(10, 27, 61, .10);
}
.page-content .blog-post.blog-single .dlab-media img { width: 100%; height: auto; display: block; }
.page-content .blog-post.blog-single .dlab-post-text {
	color: #2c3a52; font-size: 16px; line-height: 1.75;
}
.page-content .blog-post.blog-single .dlab-post-text p,
.page-content .blog-post.blog-single .dlab-post-text span,
.page-content .blog-post.blog-single .dlab-post-text li,
.page-content .blog-post.blog-single .dlab-post-text div { font-size: 18px !important; }
.page-content .blog-post.blog-single .dlab-post-text p { margin: 0 0 14px; }
.page-content .blog-post.blog-single .dlab-post-text h1,
.page-content .blog-post.blog-single .dlab-post-text h2,
.page-content .blog-post.blog-single .dlab-post-text h3,
.page-content .blog-post.blog-single .dlab-post-text h4 {
	color: var(--brand-primary); font-weight: 700;
	margin: 24px 0 12px; line-height: 1.3;
}
.page-content .blog-post.blog-single .dlab-post-text a {
	color: var(--brand-accent); text-decoration: underline; text-underline-offset: 2px;
}
.page-content .blog-post.blog-single .dlab-post-text img {
	max-width: 100%; height: auto; border-radius: var(--brand-radius); margin: 12px 0;
}
.page-content .blog-post.blog-single .dlab-post-text ul,
.page-content .blog-post.blog-single .dlab-post-text ol { padding-left: 22px; margin: 0 0 14px; }
.page-content .blog-post.blog-single .dlab-post-text blockquote {
	border-left: 4px solid var(--brand-accent);
	background: var(--brand-bg-light);
	padding: 16px 20px; margin: 18px 0;
	border-radius: 0 8px 8px 0;
	color: var(--brand-text-dark); font-style: italic;
}

/* ===== Page article (page/view) ===== */
.page-content .page-article {
	background: #fff;
	border-radius: var(--brand-radius-lg);
	padding: 36px 38px;
	box-shadow: 0 4px 20px rgba(10, 27, 61, .07);
	border: 1px solid rgba(10, 27, 61, .04);
}
.page-content .page-article-title {
	color: var(--brand-primary);
	font-size: clamp(22px, 2.4vw, 30px);
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: -.3px;
	margin: 0 0 20px;
	padding-bottom: 16px;
	border-bottom: 2px solid var(--brand-accent);
}
.page-content .page-article-body {
	color: #2c3a52; font-size: 16px; line-height: 1.75;
}
.page-content .page-article-body p,
.page-content .page-article-body span,
.page-content .page-article-body li,
.page-content .page-article-body div { font-size: 16px !important; }
.page-content .page-article-body p { margin: 0 0 14px; }
.page-content .page-article-body h1,
.page-content .page-article-body h2,
.page-content .page-article-body h3,
.page-content .page-article-body h4 {
	color: var(--brand-primary); font-weight: 700;
	margin: 24px 0 12px; line-height: 1.3;
}
.page-content .page-article-body a {
	color: var(--brand-accent); text-decoration: underline; text-underline-offset: 2px;
}
.page-content .page-article-body img {
	max-width: 100%; height: auto;
	border-radius: var(--brand-radius); margin: 14px 0;
	box-shadow: 0 4px 14px rgba(10, 27, 61, .08);
}
.page-content .page-article-body ul,
.page-content .page-article-body ol {
	padding-left: 22px; margin: 0 0 14px;
}
.page-content .page-article-body li { margin-bottom: 6px; }
.page-content .page-article-body blockquote {
	border-left: 4px solid var(--brand-accent);
	background: var(--brand-bg-light);
	padding: 16px 20px; margin: 18px 0;
	border-radius: 0 8px 8px 0;
	color: var(--brand-text-dark); font-style: italic;
}
/* Tables — force fit within the article width, allow horizontal scroll for very wide ones */
.page-content .page-article-body,
.page-content .blog-post.blog-single .dlab-post-text { overflow-x: hidden; }

.page-content .page-article-body table,
.page-content .blog-post.blog-single .dlab-post-text table {
	width: 100% !important;
	max-width: 100% !important;
	border-collapse: collapse;
	margin: 16px 0;
	border-radius: var(--brand-radius);
	overflow: hidden;
	table-layout: auto;
	display: table;
}
.page-content .page-article-body table th,
.page-content .page-article-body table td,
.page-content .blog-post.blog-single .dlab-post-text table th,
.page-content .blog-post.blog-single .dlab-post-text table td {
	padding: 10px 14px;
	border: 1px solid #e5e9ef;
	font-size: 14px;
	word-break: break-word;
	overflow-wrap: break-word;
	white-space: normal;
	min-width: 0;
}
.page-content .page-article-body table th,
.page-content .blog-post.blog-single .dlab-post-text table th {
	background: var(--brand-bg-light); color: var(--brand-primary); font-weight: 600;
	text-align: center;
}
/* Strip any inline width/height on table cells from WYSIWYG editors that would force overflow */
.page-content .page-article-body table[style],
.page-content .page-article-body table[width],
.page-content .page-article-body table tr[style],
.page-content .page-article-body table td[style],
.page-content .page-article-body table th[style] { width: auto !important; max-width: 100% !important; }

/* Wrap any non-table wide blocks too (iframes, images) */
.page-content .page-article-body img,
.page-content .page-article-body iframe,
.page-content .blog-post.blog-single .dlab-post-text img,
.page-content .blog-post.blog-single .dlab-post-text iframe {
	max-width: 100% !important; height: auto;
}

/* Tablet — keep tables full width but tighter cells */
@media (max-width: 991px) {
	.page-content .page-article-body,
	.page-content .blog-post.blog-single .dlab-post-text {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
	.page-content .page-article-body table,
	.page-content .blog-post.blog-single .dlab-post-text table {
		font-size: 14px !important;
	}
	.page-content .page-article-body table th,
	.page-content .page-article-body table td,
	.page-content .blog-post.blog-single .dlab-post-text table th,
	.page-content .blog-post.blog-single .dlab-post-text table td {
		padding: 9px 10px !important;
		min-width: 80px;
	}
}

/* Mobile — table scrolls horizontally if too wide, body text remains 16px */
@media (max-width: 767px) {
	.page-content .page-article {
		padding: 22px 18px !important;
	}
	.page-content .blog-post.blog-single .dlab-info {
		padding: 22px 18px !important;
	}
	/* Make tables horizontally scrollable, never compress columns below readable */
	.page-content .page-article-body table,
	.page-content .blog-post.blog-single .dlab-post-text table {
		display: block !important;
		width: 100% !important;
		max-width: 100% !important;
		overflow-x: auto !important;
		-webkit-overflow-scrolling: touch;
		white-space: nowrap;
		font-size: 14px !important;
	}
	.page-content .page-article-body table tbody,
	.page-content .page-article-body table thead,
	.page-content .page-article-body table tr,
	.page-content .blog-post.blog-single .dlab-post-text table tbody,
	.page-content .blog-post.blog-single .dlab-post-text table thead,
	.page-content .blog-post.blog-single .dlab-post-text table tr {
		display: table; width: 100%; table-layout: fixed;
	}
	.page-content .page-article-body table th,
	.page-content .page-article-body table td,
	.page-content .blog-post.blog-single .dlab-post-text table th,
	.page-content .blog-post.blog-single .dlab-post-text table td {
		padding: 8px 10px !important;
		min-width: 90px;
		white-space: normal;
		font-size: 13.5px !important;
	}

	/* Body text on mobile — keep 16px minimum, not smaller */
	.page-content .page-article-body,
	.page-content .blog-post.blog-single .dlab-post-text { font-size: 16px !important; line-height: 1.65; }
	.page-content .page-article-body p,
	.page-content .page-article-body span,
	.page-content .page-article-body li,
	.page-content .page-article-body div,
	.page-content .blog-post.blog-single .dlab-post-text p,
	.page-content .blog-post.blog-single .dlab-post-text span,
	.page-content .blog-post.blog-single .dlab-post-text li,
	.page-content .blog-post.blog-single .dlab-post-text div { font-size: 16px !important; }
}

/* Phone (≤480px) — last-resort compaction */
@media (max-width: 480px) {
	.page-content .page-article,
	.page-content .blog-post.blog-single .dlab-info {
		padding: 18px 14px !important;
	}
	.page-content .page-article-title,
	.page-content .blog-post.blog-single .dlab-title { font-size: 20px !important; }
	.page-content .page-article-body table,
	.page-content .blog-post.blog-single .dlab-post-text table { font-size: 13px !important; }
	.page-content .page-article-body table th,
	.page-content .page-article-body table td,
	.page-content .blog-post.blog-single .dlab-post-text table th,
	.page-content .blog-post.blog-single .dlab-post-text table td {
		padding: 6px 8px !important; min-width: 80px;
	}
}

/* ===== Sidebar widgets on inner pages ===== */
.page-content .col-xl-3 .widget,
.page-content .col-lg-4 .widget {
	background: #fff;
	border-radius: var(--brand-radius-lg);
	padding: 22px; margin-bottom: 18px;
	box-shadow: 0 4px 18px rgba(10, 27, 61, .06);
	border: 1px solid rgba(10, 27, 61, .04);
}
.page-content .col-xl-3 .widget-title,
.page-content .col-lg-4 .widget-title,
.page-content .col-xl-3 .widget h5,
.page-content .col-lg-4 .widget h5 {
	color: var(--brand-primary); font-size: 16px; font-weight: 700;
	margin: 0 0 14px; padding-bottom: 12px;
	border-bottom: 2px solid var(--brand-accent);
}

/* ===== News listing page (/news/view-all + /news/by-cat) cards ===== */
.page-content .blog-grid,
.page-content .event-post.post-grid {
	background: #fff !important;
	border-radius: var(--brand-radius-lg) !important;
	overflow: hidden;
	box-shadow: 0 4px 18px rgba(10, 27, 61, .07);
	border: 1px solid rgba(10, 27, 61, .04);
	transition: var(--brand-transition);
	display: flex !important; flex-direction: column !important;
	height: 100%;
}
.page-content .blog-grid:hover,
.page-content .event-post.post-grid:hover {
	transform: translateY(-6px);
	box-shadow: 0 16px 38px rgba(10, 27, 61, .14);
	border-color: var(--brand-accent);
}

/* Force the row to stretch all cards to equal height (news grids only, not article+sidebar rows) */
.page-content .section-full > .container > .row.news-grid-row {
	display: flex; flex-wrap: wrap; align-items: stretch;
}
.page-content .section-full > .container > .row.news-grid-row > [class*="col-"] { display: flex; }
.page-content .section-full > .container > .row.news-grid-row > [class*="col-"] > * { width: 100%; }

/* Image area */
.page-content .blog-grid .dlab-post-media,
.page-content .event-post.post-grid .dlab-post-media {
	position: relative; overflow: hidden;
	aspect-ratio: 16 / 10;
	background: #f0f3f8;
}
.page-content .blog-grid .dlab-post-media a,
.page-content .blog-grid .dlab-post-media img,
.page-content .event-post.post-grid .dlab-post-media a,
.page-content .event-post.post-grid .dlab-post-media img {
	display: block; width: 100%; height: 100%; object-fit: cover;
	transition: transform .5s ease;
}
.page-content .blog-grid:hover .dlab-post-media img,
.page-content .event-post.post-grid:hover .dlab-post-media img { transform: scale(1.06); }

/* Body */
.page-content .blog-grid .dlab-info,
.page-content .event-post.post-grid .dlab-post-info {
	padding: 22px !important;
	flex: 1; display: flex; flex-direction: column;
}

/* Meta row (date + view count) */
.page-content .event-post.post-grid .dlab-post-meta ul {
	display: flex; gap: 14px; padding: 0; margin: 0 0 12px; list-style: none;
}
.page-content .event-post.post-grid .dlab-post-meta li {
	display: inline-flex; align-items: center; gap: 6px;
	color: var(--brand-accent); font-size: 13px; font-weight: 600;
}
.page-content .event-post.post-grid .dlab-post-meta li i {
	color: var(--brand-accent); font-size: 13px;
}

/* Title */
.page-content .blog-grid .post-title,
.page-content .event-post.post-grid .post-title {
	color: var(--brand-primary) !important;
	font-size: 16px !important; font-weight: 700 !important;
	line-height: 1.4; margin: 0;
}
.page-content .blog-grid .post-title a,
.page-content .event-post.post-grid .post-title a {
	color: var(--brand-primary) !important; text-decoration: none;
	display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.page-content .blog-grid .post-title a:hover,
.page-content .event-post.post-grid .post-title a:hover { color: var(--brand-accent) !important; }

/* ===== Sidebar widgets (news/page side) ===== */
.page-content .side-bar .widget {
	background: #fff;
	border-radius: var(--brand-radius-lg);
	padding: 16px;
	margin-bottom: 14px;
	box-shadow: 0 4px 18px rgba(10, 27, 61, .06);
	border: 1px solid rgba(10, 27, 61, .04);
}
.page-content .side-bar .widget-title,
.page-content .side-bar .widget-title.style-1,
.page-content .side-bar .widget h5 {
	color: var(--brand-primary);
	font-size: 14px; font-weight: 700;
	margin: 0 0 10px; padding-bottom: 8px;
	border-bottom: 2px solid var(--brand-accent) !important;
	text-transform: none; letter-spacing: 0;
	position: relative;
}
/* Suppress the green ::before/::after stripe the template's style.min.css adds */
.page-content .side-bar .widget-title::before,
.page-content .side-bar .widget-title::after,
.page-content .side-bar .widget-title.style-1::before,
.page-content .side-bar .widget-title.style-1::after,
.page-content .side-bar .widget h5::before,
.page-content .side-bar .widget h5::after { content: none !important; display: none !important; }

/* Search box inside sidebar */
.page-content .side-bar .search-bx .input-group {
	display: flex; border: 1.5px solid #d6dee9; border-radius: var(--brand-radius); overflow: hidden;
}
.page-content .side-bar .search-bx .form-control {
	border: none; padding: 10px 14px; font-size: 14px; flex: 1;
}
.page-content .side-bar .search-bx button {
	background: var(--brand-accent); color: #fff; border: none;
	padding: 0 16px; cursor: pointer;
}
.page-content .side-bar .search-bx button:hover { background: var(--brand-accent-2); }

/* Top-news cards in sidebar */
.page-content .side-bar .widget-post {
	display: flex;
	padding: 10px 0;
	margin: 0;
	border-bottom: 1px dashed #e7ecf3;
}
.page-content .side-bar .widget-post:last-child { border-bottom: none; padding-bottom: 0; }
.page-content .side-bar .widget-post:first-child { padding-top: 0; }
.page-content .side-bar .widget-post .dlab-post-media {
	flex: 0 0 64px; width: 64px; height: 64px; border-radius: 8px;
	overflow: hidden;
}
.page-content .side-bar .widget-post .dlab-post-media img {
	width: 100% !important; height: 100% !important; object-fit: cover;
}
.page-content .side-bar .widget-post .dlab-post-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.page-content .side-bar .widget-post .dlab-post-meta ul {
	display: flex; gap: 8px; padding: 0; margin: 0; list-style: none;
}
.page-content .side-bar .widget-post .dlab-post-meta li {
	color: var(--brand-accent); font-size: 11.5px; font-weight: 600;
	display: inline-flex; align-items: center; gap: 4px;
	text-transform: none;
}
.page-content .side-bar .widget-post .dlab-post-meta li i {
	color: var(--brand-accent); font-size: 11.5px;
}
.page-content .side-bar .widget-post .post-title {
	margin: 0; font-size: 13px; line-height: 1.35; font-weight: 600;
}
.page-content .side-bar .widget-post .post-title a {
	color: var(--brand-text-dark); text-decoration: none;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.page-content .side-bar .widget-post .post-title a:hover { color: var(--brand-accent); }

/* ===== Contacts page ===== */
.page-content .contact-card {
	background: #fff;
	border-radius: var(--brand-radius-lg);
	padding: 32px 30px;
	box-shadow: 0 4px 20px rgba(10, 27, 61, .07);
	border: 1px solid rgba(10, 27, 61, .04);
	height: 100%;
}
.page-content .contact-card-title {
	color: var(--brand-primary);
	font-size: clamp(20px, 2vw, 26px);
	font-weight: 700;
	margin: 0 0 10px;
	padding-bottom: 14px;
	border-bottom: 2px solid var(--brand-accent);
}
.page-content .contact-card-org {
	color: #5d6c83; font-size: 14px; line-height: 1.5;
	margin: 12px 0 22px;
}
.page-content .contact-list { padding: 0; margin: 0; list-style: none; }
.page-content .contact-list li {
	display: flex; gap: 14px;
	padding: 14px 0;
	border-bottom: 1px dashed #e7ecf3;
}
.page-content .contact-list li:last-child { border-bottom: none; }
.page-content .contact-list .contact-icon {
	flex: 0 0 40px; width: 40px; height: 40px;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--brand-accent); color: #fff;
	border-radius: 50%; font-size: 16px;
}
.page-content .contact-list strong {
	display: block; color: var(--brand-primary);
	font-size: 14px; font-weight: 600;
	letter-spacing: .3px; margin-bottom: 4px;
}
.page-content .contact-list p {
	margin: 0; color: #2c3a52; font-size: 14.5px;
}
.page-content .contact-list a { color: var(--brand-accent); text-decoration: none; }
.page-content .contact-list a:hover { color: var(--brand-accent-2); text-decoration: underline; }

.page-content .contact-socials {
	display: flex; gap: 8px;
	padding-top: 18px;
	margin-top: 18px;
	border-top: 1px solid #e7ecf3;
}

.page-content .contact-form-title {
	color: var(--brand-primary);
	font-size: 20px; font-weight: 700;
	margin: 0 0 18px;
}
.page-content .contact-form .form-row {
	display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
@media (max-width: 575px) { .page-content .contact-form .form-row { grid-template-columns: 1fr; gap: 0; } }
.page-content .contact-form .form-group { margin-bottom: 14px; }
.page-content .contact-form .control-label {
	display: block; font-weight: 600; font-size: 13.5px;
	color: var(--brand-primary); margin-bottom: 6px;
}
.page-content .contact-form .form-control {
	width: 100%; padding: 11px 14px;
	border: 1.5px solid #d6dee9; border-radius: var(--brand-radius);
	font-size: 14.5px; color: var(--brand-text-dark);
	background: #fff; transition: var(--brand-transition);
}
.page-content .contact-form textarea.form-control { min-height: 130px; font-family: inherit; resize: vertical; }
.page-content .contact-form .form-control:focus {
	outline: none; border-color: var(--brand-accent);
	box-shadow: 0 0 0 3px rgba(46, 107, 230, .15);
}
.page-content .contact-form .help-block { color: #dc2626; font-size: 12.5px; margin-top: 4px; }
.page-content .contact-submit {
	display: inline-flex; align-items: center; gap: 8px;
	background: var(--brand-accent); color: #fff; border: none;
	padding: 12px 30px; border-radius: var(--brand-radius);
	font-weight: 600; font-size: 14px; letter-spacing: .3px;
	cursor: pointer; transition: var(--brand-transition);
	margin-top: 4px;
}
.page-content .contact-submit:hover { background: var(--brand-accent-2); transform: translateY(-1px); }

.page-content .contact-map-card {
	background: #fff; border-radius: var(--brand-radius-lg);
	box-shadow: 0 4px 20px rgba(10, 27, 61, .07);
	border: 1px solid rgba(10, 27, 61, .04);
	overflow: hidden;
	margin: 8px 0 60px;
}
.page-content .contact-map-card iframe { display: block; width: 100%; }

/* ===== Error page (404 / 403 / 500) ===== */
.error-page {
	padding: 40px 0 80px;
	background: var(--brand-bg-light);
}
.error-card {
	background: #fff;
	border-radius: var(--brand-radius-lg);
	max-width: 720px; margin: 0 auto;
	padding: 60px 40px;
	text-align: center;
	box-shadow: 0 4px 24px rgba(10, 27, 61, .08);
	border: 1px solid rgba(10, 27, 61, .04);
}
.error-code {
	font-size: clamp(80px, 14vw, 160px);
	line-height: 1; font-weight: 800;
	letter-spacing: -4px;
	background: linear-gradient(135deg, var(--brand-primary), var(--brand-accent));
	-webkit-background-clip: text; background-clip: text;
	color: transparent;
	margin: 0 0 8px;
}
.error-title {
	color: var(--brand-primary);
	font-size: clamp(20px, 2.4vw, 28px);
	font-weight: 700;
	margin: 0 0 14px;
}
.error-message {
	color: #5d6c83; font-size: 15px; line-height: 1.6;
	margin: 0 auto 32px; max-width: 520px;
}
.error-actions {
	display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
}
.error-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 12px 24px; border-radius: var(--brand-radius);
	font-weight: 600; font-size: 14px; letter-spacing: .3px;
	text-decoration: none;
	transition: var(--brand-transition);
}
.error-btn-primary {
	background: var(--brand-accent); color: #fff;
	border: 2px solid var(--brand-accent);
}
.error-btn-primary:hover { background: var(--brand-accent-2); border-color: var(--brand-accent-2); transform: translateY(-1px); color: #fff; }
.error-btn-secondary {
	background: transparent; color: var(--brand-primary);
	border: 2px solid #d6dee9;
}
.error-btn-secondary:hover { border-color: var(--brand-accent); color: var(--brand-accent); transform: translateY(-1px); }

/* ===== Search results summary ===== */
.search-summary {
	background: #fff;
	border-left: 4px solid var(--brand-accent);
	padding: 16px 22px;
	border-radius: var(--brand-radius);
	box-shadow: 0 2px 10px rgba(10, 27, 61, .05);
	margin: 0 0 28px;
}
.search-summary-title {
	margin: 0; font-size: 17px; font-weight: 600;
	color: var(--brand-primary);
}
.search-summary-title strong { color: var(--brand-accent); }
.search-summary-empty {
	margin: 10px 0 0; color: #5d6c83; font-size: 14px;
	display: inline-flex; align-items: center; gap: 8px;
}
.search-summary-empty i { color: var(--brand-accent); }

/* ===== Pagination ===== */
.pagination, .pagination-bx ul {
	display: flex; gap: 5px; padding: 0; margin: 30px 0 0; list-style: none;
	justify-content: center;
}
.pagination li, .pagination-bx ul li { display: inline-block; }
.pagination li a, .pagination-bx ul li a,
.pagination li span, .pagination-bx ul li span {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 38px; height: 38px; padding: 0 12px;
	border-radius: var(--brand-radius);
	background: #fff; color: var(--brand-text-dark);
	border: 1px solid #e5e9ef;
	font-weight: 600; font-size: 14px;
	transition: var(--brand-transition); text-decoration: none;
}
.pagination li a:hover, .pagination-bx ul li a:hover {
	background: var(--brand-accent); color: #fff; border-color: var(--brand-accent);
}
.pagination li.active a, .pagination li.active span,
.pagination-bx ul li.active a {
	background: var(--brand-accent); color: #fff; border-color: var(--brand-accent);
}

.pagination>li:first-child>a, .pagination>li:first-child>span{
	border-radius: 8px 0 0 8px;
}
.pagination>li:last-child>a, .pagination>li:last-child>span{
	border-radius: 0 8px 8px 0;
}


/* ===== Sitemap page ===== */
.main-block.page-content {
	background: var(--brand-bg-light);
	padding: 0 0 60px;
}
.main-block .single__news-page-title {
	color: var(--brand-primary);
	font-size: clamp(20px, 2vw, 26px);
	font-weight: 700;
	padding: 0 0 14px;
	margin: 14px 0 22px;
	border-bottom: 2px solid var(--brand-accent);
}
.main-block .single-news {
	background: #fff;
	border-radius: var(--brand-radius-lg);
	padding: 28px 32px;
	margin: 18px 0 0;
	box-shadow: 0 4px 20px rgba(10, 27, 61, .07);
	border: 1px solid rgba(10, 27, 61, .04);
}
.main-block .sitemap > ul {
	padding: 0; margin: 0; list-style: none;
}
.main-block .sitemap ul ul {
	padding-left: 22px; margin: 6px 0;
}
.main-block .sitemap li {
	padding: 6px 0; color: var(--brand-text-dark); font-size: 14.5px;
}
.main-block .sitemap li a {
	color: var(--brand-text-dark);
	display: inline-flex; align-items: center; gap: 6px;
	padding: 4px 0;
	text-decoration: none;
	transition: var(--brand-transition);
}
.main-block .sitemap li a:hover { color: var(--brand-accent); }
.main-block .sitemap li i {
	font-size: 11px; color: var(--brand-accent); opacity: .75;
}

/* ===== Virtual Reception form page ===== */
.vr-page { padding: 18px 0 60px; background: var(--brand-bg-light); min-height: 60vh; }
.vr-card {
	max-width: 880px; margin: 0 auto; background: #fff;
	border-radius: var(--brand-radius-lg); box-shadow: var(--brand-shadow);
	padding: 40px 36px; border-top: 5px solid var(--brand-accent);
}
.vr-header { text-align: center; margin-bottom: 28px; }
.vr-title { color: var(--brand-primary); font-weight: 700; font-size: clamp(22px, 2.4vw, 30px); margin: 0 0 8px; }
.vr-subtitle { color: #5d6c83; margin: 0; font-size: 15px; }
.vr-success {
	background: #ecfdf5; border: 1px solid #10b981; color: #065f46;
	padding: 14px 18px; border-radius: var(--brand-radius);
	margin-bottom: 24px; display: flex; gap: 10px; align-items: center;
}
.vr-success i { font-size: 18px; }
.vr-form .form-group { margin-bottom: 16px; }
.vr-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 640px) { .vr-row { grid-template-columns: 1fr; gap: 0; } }
.vr-label { display: block; font-weight: 600; color: var(--brand-primary); margin-bottom: 6px; font-size: 14px; }
.vr-input, .vr-select, .vr-form textarea {
	width: 100%; padding: 12px 14px; border: 1.5px solid #d6dee9; border-radius: var(--brand-radius);
	font-size: 15px; color: var(--brand-text-dark); background: #fff;
	transition: var(--brand-transition);
}
.vr-form textarea { resize: vertical; min-height: 120px; font-family: inherit; }
.vr-input:focus, .vr-select:focus, .vr-form textarea:focus { outline: none; border-color: var(--brand-accent); box-shadow: 0 0 0 3px rgba(46, 107, 230, 0.15); }
.vr-error { color: #dc2626; font-size: 13px; margin-top: 4px; }
.vr-actions { text-align: center; margin-top: 8px; }
.vr-submit {
	background: var(--brand-accent); color: #fff; border: none;
	padding: 14px 36px; border-radius: var(--brand-radius);
	font-size: 15px; font-weight: 600; letter-spacing: .3px;
	cursor: pointer; transition: var(--brand-transition);
	display: inline-flex; align-items: center; gap: 8px;
}
.vr-submit:hover { background: var(--brand-accent-2); transform: translateY(-2px); }

/* Make the social/hemis groups breathe on small viewports */
.site-header .top-bar .mottos .theme { margin-left: auto; }
@media (max-width: 1199px) {
	.site-header .top-bar .dlab-topbar-right > ul { flex-wrap: wrap; justify-content: flex-end; gap: 10px; }
	.site-header .top-bar .hemis-list { order: 3; flex-basis: 100%; justify-content: center; margin-top: 4px; }
}

/* ===== Mobile/tablet header polish ===== */
@media (max-width: 1199px) {
	/* Top bar reflows into stacked rows */
	.sh-top-inner {
		flex-direction: column; align-items: stretch;
		gap: 8px; padding: 10px 0;
	}
	.sh-top-left {
		flex-direction: column; align-items: center; gap: 10px; width: 100%;
	}
	.sh-socials { justify-content: center; }
	.sh-top-links { justify-content: center; flex-wrap: wrap; }
	.sh-top-links a span { font-size: 12px; }
	.sh-top-right {
		flex-wrap: wrap; justify-content: center; gap: 10px; width: 100%;
	}
	.sh-top-item a { font-size: 12px; }

	/* Main bar — compact */
	.sh-main-inner { min-height: 64px; gap: 8px; }
	.sh-brand { max-width: 70%; gap: 8px; }
	.sh-brand-logo { width: 44px; height: 44px; }
	.sh-brand-name { display: none; }

	.sh-tools { gap: 6px; margin-left: auto; }
	.sh-tools .sh-icon-btn { width: 36px; height: 36px; }
}

@media (max-width: 575px) {
	.sh-soc-btn { width: 28px; height: 28px; font-size: 13px; }
	.sh-icon-btn { width: 28px; height: 28px; }
	.sh-icon-btn i { font-size: 12px; }
	.sh-top-links a { padding: 4px 8px; font-size: 11px; }
	.sh-top-links a i { font-size: 11px; }
	.sh-top-item a { font-size: 11px; }
	.sh-top-item a i { font-size: 12px; }

	.sh-brand-logo { width: 38px; height: 38px; padding: 2px; }
	.sh-main-inner { min-height: 56px; padding: 6px 0; }

	/* Hero arrows + content tighter */
	.hero-block .hero-content { padding: 50px 12px 80px; }
	.hero-block .hero-title { font-size: clamp(22px, 6vw, 32px); }
	.hero-block .hero-ctas { gap: 10px; }
	.hero-block .hero-cta { padding: 11px 18px; font-size: 13px; }
}
