/* =================================================================
 * T-Birds Polish — global look & feel.
 * Loaded by /wp-content/mu-plugins/tbird-site-fixes.php
 * ============================================================== */

:root {
	--tb-red: #bb1f24;
	--tb-red-dark: #8a1418;
	--tb-gold: #ffc832;
	--tb-ink: #0e1014;
	--tb-ink-soft: #2a2d33;
	--tb-bg-soft: #f6f7f9;
	--tb-line: #e5e7eb;
	--tb-shadow-sm: 0 1px 2px rgba(15,17,23,.05), 0 1px 3px rgba(15,17,23,.08);
	--tb-shadow-md: 0 4px 14px rgba(15,17,23,.08), 0 2px 6px rgba(15,17,23,.06);
	--tb-shadow-lg: 0 18px 40px rgba(15,17,23,.16), 0 8px 18px rgba(15,17,23,.08);
}

/* ---------- Header polish ---------- */
body header.entry-header,
body .site-header,
body header[class*="elementor-location-header"] {
	transition: box-shadow .25s ease;
}
header[class*="elementor-location-header"] {
	box-shadow: var(--tb-shadow-sm);
}
header[class*="elementor-location-header"] .elementor-nav-menu a.elementor-item {
	font-weight: 600;
	letter-spacing: .03em;
	transition: color .15s ease, background-color .15s ease;
}
header[class*="elementor-location-header"] .elementor-nav-menu a.elementor-item:hover,
header[class*="elementor-location-header"] .elementor-nav-menu a.elementor-item.elementor-item-active {
	background: var(--tb-red);
	color: #fff !important;
}
/* Social icons in header */
header[class*="elementor-location-header"] .elementor-social-icon {
	transition: transform .15s ease, box-shadow .15s ease;
}
header[class*="elementor-location-header"] .elementor-social-icon:hover {
	transform: translateY(-2px);
	box-shadow: var(--tb-shadow-md);
}

/* ---------- Smart Slider hero ---------- */
div#n2-ss-2,
.elementor-widget-smartslider {
	position: relative;
}
.elementor-widget-smartslider::after {
	content: "";
	position: absolute;
	inset: auto 0 0 0;
	height: 50%;
	background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.45) 100%);
	pointer-events: none;
	z-index: 5;
}
/* Slide image fallback: if a post has no featured image, fill with brand red */
div#n2-ss-2 .n2-ss-slide-background[style*="background-image: none"],
div#n2-ss-2 .n2-ss-slide-background:not([style*="background-image"]) {
	background: linear-gradient(135deg, var(--tb-red) 0%, var(--tb-ink) 100%) !important;
}
/* Make slider arrows pop */
div#n2-ss-2 .nextend-arrow {
	background: rgba(0,0,0,.5) !important;
	border-radius: 999px !important;
	padding: 6px !important;
	transition: background .15s ease;
}
div#n2-ss-2 .nextend-arrow:hover {
	background: var(--tb-red) !important;
}

/* ---------- Welcome / intro section ---------- */
.elementor-widget-heading h2,
.elementor-widget-heading h1 {
	letter-spacing: .01em;
}
.elementor-widget-text-editor p {
	line-height: 1.65;
}
/* The "Welcome to..." H2 — gets a small accent underline */
.elementor-widget-heading .elementor-heading-title {
	position: relative;
}

/* ---------- JOIN US call-to-action card ---------- */
.elementor-widget-call-to-action .elementor-cta {
	border-radius: 14px;
	overflow: hidden;
	box-shadow: var(--tb-shadow-md);
	transition: transform .25s ease, box-shadow .25s ease;
}
.elementor-widget-call-to-action .elementor-cta:hover {
	transform: translateY(-4px);
	box-shadow: var(--tb-shadow-lg);
}
.elementor-widget-call-to-action .elementor-cta__bg-overlay {
	opacity: .6 !important;
}
.elementor-widget-call-to-action .elementor-cta__title {
	font-weight: 800;
	letter-spacing: .05em;
	font-size: clamp(2rem, 4vw, 3rem) !important;
	margin-bottom: .25rem !important;
}
.elementor-widget-call-to-action .elementor-cta__description {
	font-size: 1.05rem;
	max-width: 60ch;
	margin-left: auto;
	margin-right: auto;
}
.elementor-widget-call-to-action .elementor-cta__button {
	background: var(--tb-red) !important;
	color: #fff !important;
	border: 0 !important;
	padding: .85rem 1.6rem !important;
	border-radius: 999px !important;
	font-weight: 700 !important;
	letter-spacing: .08em !important;
	transition: background .15s ease, transform .15s ease !important;
}
.elementor-widget-call-to-action .elementor-cta__button:hover {
	background: var(--tb-red-dark) !important;
	transform: translateY(-2px);
}

/* ---------- Bottom 3-column block (TEAMS / NEWS / CALENDAR) ---------- */
/* Target the section that has heading widgets named Teams/CLub News/Club Calendar */
body .elementor-section:has(.elementor-widget-nav-menu):has(.elementor-widget-jkit_post_list),
body .elementor-section .elementor-widget-nav-menu,
body .elementor-section .elementor-widget-jkit_post_list,
body .elementor-section .elementor-widget-sidebar {
	/* nothing global here, just hooks */
}

/* Bottom-of-home card columns — scoped to content sections only, NOT header/footer */
body > div.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-jkit_post_list,
body > div.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-sidebar,
.elementor[data-elementor-type="wp-post"] .elementor-section .elementor-widget-nav-menu,
.elementor[data-elementor-type="wp-page"] .elementor-section .elementor-widget-nav-menu {
	background: var(--tb-bg-soft);
	border: 1px solid var(--tb-line);
	border-radius: 14px;
	padding: 1.5rem 1.25rem !important;
	box-shadow: var(--tb-shadow-sm);
	transition: transform .25s ease, box-shadow .25s ease;
	margin: 0 .5rem;
}
body > div.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-jkit_post_list:hover,
body > div.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-sidebar:hover,
.elementor[data-elementor-type="wp-post"] .elementor-section .elementor-widget-nav-menu:hover,
.elementor[data-elementor-type="wp-page"] .elementor-section .elementor-widget-nav-menu:hover {
	transform: translateY(-3px);
	box-shadow: var(--tb-shadow-md);
}

/* Column headings as colored chips */
.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-heading + .elementor-widget-nav-menu,
.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-heading + .elementor-widget-jkit_post_list,
.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-heading + .elementor-widget-sidebar {
	margin-top: -.25rem;
}

/* Card-section column headings: bigger, red, underlined */
.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-heading:where(:has(+ .elementor-widget-nav-menu, + .elementor-widget-jkit_post_list, + .elementor-widget-sidebar)) {
	margin-bottom: .25rem !important;
}
.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-heading:where(:has(+ .elementor-widget-nav-menu, + .elementor-widget-jkit_post_list, + .elementor-widget-sidebar)) .elementor-heading-title {
	color: var(--tb-red) !important;
	font-weight: 800 !important;
	letter-spacing: .04em !important;
	position: relative;
	display: inline-block;
	padding-bottom: .35rem;
}
.elementor:not([data-elementor-type="header"]):not([data-elementor-type="footer"]) .elementor-section .elementor-widget-heading:where(:has(+ .elementor-widget-nav-menu, + .elementor-widget-jkit_post_list, + .elementor-widget-sidebar)) .elementor-heading-title::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 36px;
	height: 3px;
	border-radius: 3px;
	background: var(--tb-gold);
}

/* Lists inside the cards */
body main .elementor-widget-nav-menu .elementor-nav-menu li a.elementor-item {
	padding: .5rem .25rem !important;
	border-bottom: 1px dashed var(--tb-line);
	transition: color .15s ease, padding-left .15s ease;
}
body main .elementor-widget-nav-menu .elementor-nav-menu li:last-child a.elementor-item {
	border-bottom: 0;
}
body main .elementor-widget-nav-menu .elementor-nav-menu li a.elementor-item:hover {
	color: var(--tb-red) !important;
	padding-left: .5rem !important;
}

body main .elementor-widget-jkit_post_list .jkit-postlist-item {
	border-bottom: 1px dashed var(--tb-line);
	padding: .5rem 0 !important;
}
body main .elementor-widget-jkit_post_list .jkit-postlist-item:last-child {
	border-bottom: 0;
}

/* ---------- Footer ---------- */
footer[class*="elementor-location-footer"] {
	padding-top: 2rem;
	padding-bottom: 1rem;
}
footer[class*="elementor-location-footer"] .elementor-widget-heading h2 {
	font-weight: 800;
	letter-spacing: .04em;
}
footer[class*="elementor-location-footer"] .elementor-social-icon {
	transition: transform .15s ease;
}
footer[class*="elementor-location-footer"] .elementor-social-icon:hover {
	transform: translateY(-2px) scale(1.05);
}

/* Inject a clean copyright line at the bottom of the footer */
footer[class*="elementor-location-footer"]::after {
	content: "© 2026 Connetquot Sayville BBP T-Birds Hockey Club · All rights reserved";
	display: block;
	text-align: center;
	color: rgba(255,255,255,.5);
	font-size: .8rem;
	letter-spacing: .03em;
	padding: 1.25rem 1rem 1.5rem;
	border-top: 1px solid rgba(255,255,255,.08);
	background: #000;
}

/* ---------- New footer content (Quick Links etc.) ---------- */

/* Force the Elementor section/container/column to span the full width
   so our grid can actually breathe (Elementor's boxed default = 1140px). */
footer[class*="elementor-location-footer"] {
	padding: 0 !important;
}
footer[class*="elementor-location-footer"] > section {
	padding: 0 !important;
}
footer[class*="elementor-location-footer"] .elementor-container {
	max-width: 100% !important;
	width: 100% !important;
}
footer[class*="elementor-location-footer"] .elementor-column,
footer[class*="elementor-location-footer"] .elementor-widget-wrap,
footer[class*="elementor-location-footer"] .elementor-widget-html {
	width: 100% !important;
	max-width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

.tb-footer-content {
	color: #d4d6db;
	width: 100%;
	max-width: 1240px;
	margin: 0 auto;
	padding: 2.5rem 2rem 1rem;
	box-sizing: border-box;
}

.tb-footer-grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1fr;
	gap: 3rem;
	align-items: start;
}
@media (max-width: 1100px) {
	.tb-footer-grid {
		grid-template-columns: 1.4fr 1fr 1fr 1fr;
		gap: 2rem;
	}
}
@media (max-width: 860px) {
	.tb-footer-grid {
		grid-template-columns: 1fr 1fr;
		gap: 2rem 1.5rem;
	}
}
@media (max-width: 480px) {
	.tb-footer-content {
		padding: 2rem 1.25rem .75rem;
	}
	.tb-footer-grid {
		grid-template-columns: 1fr;
		gap: 1.75rem;
	}
}

.tb-footer-brand {
	font-size: 1rem;
	line-height: 1.4;
	color: #fff;
}
.tb-footer-brand strong {
	color: #fff;
	font-weight: 800;
	font-size: 1.15rem;
	letter-spacing: .01em;
	display: block;
	margin-bottom: .25rem;
}
.tb-footer-tag {
	margin-top: .5rem;
	font-size: .85rem;
	color: #9ca3af;
	line-height: 1.55;
}

/* Section heading per column — block-level with red underline below */
.tb-footer-h {
	color: #fff;
	font-size: .8rem;
	font-weight: 800;
	letter-spacing: .1em;
	text-transform: uppercase;
	margin: 0 0 1rem;
	padding-bottom: .55rem;
	border-bottom: none;
	position: relative;
	white-space: nowrap;
}
.tb-footer-h::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 32px;
	height: 2px;
	background: var(--tb-red);
	border-radius: 2px;
}

.tb-footer-links {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: .45rem;
}
.tb-footer-links a {
	color: #d4d6db !important;
	font-size: .92rem;
	text-decoration: none !important;
	transition: color .15s ease, transform .15s ease;
	display: inline-block;
}
.tb-footer-links a:hover {
	color: #fff !important;
	transform: translateX(3px);
}

.tb-footer-social {
	margin-top: .75rem;
	display: flex;
	gap: .5rem;
}
.tb-fs {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 999px;
	color: #fff !important;
	background: #1f242b;
	transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.tb-fs:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 14px rgba(0,0,0,.4);
}
.tb-fs-fb:hover { background: #1877f2; }
.tb-fs-yt:hover { background: #ff0000; }
.tb-fs-ig:hover { background: linear-gradient(135deg, #833ab4 0%, #fd1d1d 50%, #fcb045 100%); }
@media (max-width: 900px) {
	.tb-footer-grid {
		grid-template-columns: 1fr 1fr;
	}
}
@media (max-width: 520px) {
	.tb-footer-grid {
		grid-template-columns: 1fr;
	}
}
/* Hide any Elementor-native heading/text/social-icons widgets in the footer
   in case the legacy widgets are still present alongside our html widget. */
footer[class*="elementor-location-footer"] .elementor-widget-heading:not(.tb-skip),
footer[class*="elementor-location-footer"] > section > .elementor-container > .elementor-column > .elementor-widget-wrap > .elementor-widget-text-editor:not(.tb-skip),
footer[class*="elementor-location-footer"] > section > .elementor-container > .elementor-column > .elementor-widget-wrap > .elementor-widget-social-icons {
	display: none !important;
}

/* ---------- Buttons (red brand pill style) ---------- */
.elementor-button-link,
.elementor-button,
.wp-block-button__link,
.mf-input-submit {
	border-radius: 999px !important;
	font-weight: 700 !important;
	letter-spacing: .06em !important;
	transition: transform .15s ease, box-shadow .15s ease !important;
}
.elementor-button-link:hover,
.elementor-button:hover,
.wp-block-button__link:hover,
.mf-input-submit:hover {
	transform: translateY(-2px);
	box-shadow: var(--tb-shadow-md);
}

/* ---------- Mobile improvements ---------- */
@media (max-width: 767px) {
	body .elementor-section .elementor-widget-nav-menu,
	body .elementor-section .elementor-widget-jkit_post_list,
	body .elementor-section .elementor-widget-sidebar {
		margin: .5rem 0;
	}
	.elementor-widget-call-to-action .elementor-cta__title {
		font-size: 1.75rem !important;
	}
}

/* ============================================================ */
/* TEAM PAGES (Varsity / JV / Freshman)                            */
/* ============================================================ */

.tb-team-page {
	max-width: 1080px;
	margin: 0 auto;
	padding: 1rem 0 2rem;
}

.tb-team-coaches,
.tb-team-roster {
	margin: 0 0 2rem;
}

.tb-team-page h3 {
	color: var(--tb-ink);
	font-weight: 800 !important;
	font-size: 1.35rem;
	letter-spacing: .04em;
	margin: 0 0 1rem;
	display: flex;
	align-items: baseline;
	gap: .75rem;
	border-bottom: 2px solid var(--tb-red);
	padding-bottom: .4rem;
}
.tb-roster-count {
	font-size: .8rem;
	font-weight: 600;
	letter-spacing: .05em;
	color: #6b7280;
	background: var(--tb-bg-soft);
	padding: 2px 8px;
	border-radius: 999px;
	border: 1px solid var(--tb-line);
}

/* Coach grid */
.tb-coach-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: .75rem;
}
.tb-coach-card {
	background: linear-gradient(135deg, var(--tb-red) 0%, var(--tb-red-dark) 100%);
	color: #fff;
	border-radius: 12px;
	padding: .9rem 1rem;
	box-shadow: var(--tb-shadow-sm);
	transition: transform .15s ease, box-shadow .15s ease;
}
.tb-coach-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--tb-shadow-md);
}
.tb-coach-name {
	font-weight: 700;
	font-size: 1rem;
	line-height: 1.25;
}
.tb-coach-role {
	font-size: .8rem;
	opacity: .85;
	margin-top: .15rem;
}

/* Player grid */
.tb-player-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: .6rem;
}
.tb-player-card {
	display: flex;
	align-items: center;
	gap: .75rem;
	background: #fff;
	border: 1px solid var(--tb-line);
	border-left: 4px solid var(--tb-red);
	border-radius: 10px;
	padding: .65rem .9rem;
	box-shadow: var(--tb-shadow-sm);
	transition: transform .15s ease, box-shadow .15s ease, border-left-color .15s ease;
}
.tb-player-card:hover {
	transform: translateX(2px);
	box-shadow: var(--tb-shadow-md);
	border-left-color: var(--tb-gold);
}
.tb-num {
	font-weight: 800;
	font-size: 1.2rem;
	min-width: 1.75rem;
	color: var(--tb-red);
	font-variant-numeric: tabular-nums;
}
.tb-player-name {
	font-weight: 600;
	letter-spacing: .01em;
	color: var(--tb-ink);
}

/* Team Red / Gold variations */
.tb-team-gold h3 { border-bottom-color: var(--tb-gold); }
.tb-team-gold .tb-player-card { border-left-color: var(--tb-gold); }
.tb-team-gold .tb-num { color: #b08108; }

.tb-num-note {
	margin-top: 1.5rem;
	padding: .9rem 1rem;
	background: #fff8e1;
	border: 1px dashed #f0c75e;
	border-radius: 10px;
	color: #6b5311;
	font-size: .9rem;
	text-align: center;
}

/* ============================================================ */
/* BYLAWS PAGE                                                     */
/* ============================================================ */

.tb-bylaws-page {
	max-width: 1100px;
	margin: 0 auto;
	padding: 1rem 1rem 2.5rem;
}
.tb-bylaws-title {
	font-weight: 800 !important;
	font-size: clamp(1.75rem, 3vw, 2.25rem) !important;
	margin: 0 0 .25rem !important;
	color: var(--tb-ink);
	padding-bottom: .35rem;
	border-bottom: 3px solid var(--tb-red);
	display: inline-block;
}
.tb-bylaws-sub {
	color: #6b7280;
	font-size: 1rem;
	margin: 0 0 1.5rem;
}
.tb-bylaws-body {
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: 2rem;
	align-items: start;
}
@media (max-width: 860px) {
	.tb-bylaws-body { grid-template-columns: 1fr; gap: 1rem; }
}
.tb-bylaws-toc {
	position: sticky;
	top: 1rem;
	background: var(--tb-bg-soft);
	border: 1px solid var(--tb-line);
	border-radius: 12px;
	padding: 1rem 1.1rem;
	max-height: calc(100vh - 2rem);
	overflow: auto;
}
.tb-bylaws-toc h4 {
	margin: 0 0 .75rem !important;
	font-size: .8rem !important;
	font-weight: 800 !important;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--tb-red);
}
.tb-bylaws-toc-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: .2rem;
	counter-reset: none;
}
.tb-bylaws-toc-list a {
	display: flex;
	align-items: baseline;
	gap: .5rem;
	padding: .4rem .25rem;
	color: var(--tb-ink-soft);
	text-decoration: none !important;
	font-size: .9rem;
	line-height: 1.3;
	border-radius: 4px;
	transition: background .15s ease, color .15s ease, padding-left .15s ease;
}
.tb-bylaws-toc-list a:hover {
	color: var(--tb-red);
	background: rgba(187,31,36,.06);
	padding-left: .5rem !important;
}
.tb-bylaws-toc-num {
	font-weight: 700;
	color: var(--tb-red);
	min-width: 2rem;
	font-size: .8rem;
}

.tb-bylaws-content {
	background: #fff;
	border: 1px solid var(--tb-line);
	border-radius: 12px;
	padding: 1.5rem 1.75rem;
	box-shadow: var(--tb-shadow-sm);
}
.tb-bylaws-content p {
	line-height: 1.7;
	color: var(--tb-ink-soft);
}
.tb-bylaws-content ol,
.tb-bylaws-content ul {
	padding-left: 1.5rem;
	line-height: 1.7;
	color: var(--tb-ink-soft);
}
.tb-bylaws-h {
	font-weight: 800 !important;
	font-size: 1.25rem !important;
	margin: 2rem 0 .75rem !important;
	color: var(--tb-ink);
	padding-bottom: .35rem;
	border-bottom: 2px solid var(--tb-red);
	scroll-margin-top: 1rem;
}
.tb-bylaws-h:first-child {
	margin-top: 0 !important;
}
.tb-bylaws-num {
	display: inline-block;
	background: var(--tb-red);
	color: #fff;
	font-size: .7rem;
	font-weight: 800;
	letter-spacing: .1em;
	padding: 3px 8px;
	border-radius: 999px;
	margin-right: .5rem;
	vertical-align: middle;
}

/* ============================================================ */
/* CLUB NEWS ARCHIVE                                               */
/* ============================================================ */

/* The Club News blog index — turn the bare Hello-Elementor archive
   into a modern card grid with featured image, date, and Read More.
   the_excerpt is filtered in tbird-site-fixes.php to add .tb-news-* markup. */

/* Wrap the page-content in a centered container with a wider max-width */
body.blog .page-content {
	max-width: 1180px;
	margin: 0 auto;
	padding: 1.25rem 1rem 2.5rem;
}

/* Page title (h1 "Archives") on its own row */
body.blog .page-content > .page-title,
body.blog .page-content > header,
body.blog .page-content > h1 {
	font-weight: 800 !important;
	font-size: clamp(1.75rem, 3vw, 2.5rem) !important;
	margin: 0 0 .35rem !important;
	border-bottom: 3px solid var(--tb-red);
	display: inline-block;
	padding-bottom: .35rem;
}
/* Add a subtitle under "Archives" */
body.blog .page-content > :first-child + p,
body.blog .page-content > .page-title::after {
}
body.blog .page-content > .page-title + article {
	margin-top: 1.5rem;
}

/* Wrap all articles in a CSS grid by promoting them via a flex/grid container.
   Hello Elementor outputs articles as direct children of .page-content, so
   we use display: grid on .page-content itself, but force header/title/nav
   to span the full row. */
body.blog .page-content {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 1.25rem;
	align-items: stretch;
}
body.blog .page-content > :not(article) {
	grid-column: 1 / -1;
}
body.blog .page-content > .page-title {
	margin-bottom: 0 !important;
}
/* Subtitle right after the title */
body.blog .page-content > .page-title + * {
	margin-top: 0 !important;
}

body.blog article.post {
	background: #fff;
	border: 1px solid var(--tb-line);
	border-radius: 14px;
	margin: 0;
	padding: 0;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	box-shadow: var(--tb-shadow-sm);
	transition: transform .2s ease, box-shadow .2s ease;
}
body.blog article.post:hover {
	transform: translateY(-4px);
	box-shadow: var(--tb-shadow-md);
}

/* Featured image — Hello Elementor outputs <a><img class="wp-post-image"></a>
   as a direct child of article. Style that as a 16:9 banner. */
body.blog article.post > a:has(img.wp-post-image) {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--tb-bg-soft);
	order: -2;
}
body.blog article.post > a > img.wp-post-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .35s ease;
	margin: 0;
	border-radius: 0;
}
body.blog article.post:hover > a > img.wp-post-image {
	transform: scale(1.04);
}
/* If no thumb image, show a branded gradient strip */
body.blog article.post:not(:has(img.wp-post-image))::before {
	content: "";
	display: block;
	height: 6px;
	background: linear-gradient(90deg, var(--tb-red) 0%, var(--tb-red-dark) 100%);
	order: -2;
}

/* Title — keep above body, after image */
body.blog article.post .entry-title {
	order: -1;
}

/* Title sits inside the article above the body wrapper */
body.blog article.post .entry-title {
	margin: 0 !important;
	padding: 1rem 1.25rem .25rem;
	font-size: 1.2rem !important;
	font-weight: 800 !important;
	line-height: 1.3;
	border: none !important;
	display: block !important;
}
body.blog article.post .entry-title a {
	color: var(--tb-ink) !important;
	text-decoration: none !important;
}
body.blog article.post:hover .entry-title a {
	color: var(--tb-red) !important;
}

body.blog article.post .tb-news-body {
	padding: 0 1.25rem 1.1rem;
	display: flex;
	flex-direction: column;
	gap: .55rem;
	flex-grow: 1;
}
body.blog article.post .tb-news-meta {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: .8rem;
	letter-spacing: .04em;
	color: #6b7280;
	text-transform: uppercase;
	font-weight: 600;
}
body.blog article.post .tb-news-date::before {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	background: var(--tb-red);
	border-radius: 999px;
	margin-right: .5rem;
	vertical-align: middle;
}
body.blog article.post .tb-news-excerpt {
	color: var(--tb-ink-soft);
	font-size: .95rem;
	line-height: 1.55;
	flex-grow: 1;
}
body.blog article.post .tb-news-excerpt p {
	margin: 0;
}
body.blog article.post .tb-news-readmore {
	display: inline-flex;
	align-items: center;
	color: var(--tb-red);
	font-weight: 700;
	font-size: .9rem;
	letter-spacing: .03em;
	text-decoration: none !important;
	margin-top: .25rem;
	width: fit-content;
	transition: gap .15s ease, color .15s ease;
}
body.blog article.post .tb-news-readmore:hover {
	color: var(--tb-red-dark);
	gap: .35rem;
}

/* Pagination */
body.blog .post-navigation,
body.blog .nav-links,
body.blog nav.pagination {
	display: flex;
	justify-content: center;
	gap: .5rem;
	margin-top: 1.5rem;
}
body.blog nav .page-numbers,
body.blog .post-navigation a {
	display: inline-flex;
	align-items: center;
	padding: .5rem .85rem;
	border-radius: 999px;
	background: #fff;
	border: 1px solid var(--tb-line);
	color: var(--tb-ink-soft);
	text-decoration: none !important;
	font-weight: 600;
	font-size: .9rem;
	transition: background .15s ease, color .15s ease, border-color .15s ease;
}
body.blog nav .page-numbers:hover,
body.blog nav .page-numbers.current {
	background: var(--tb-red);
	color: #fff;
	border-color: var(--tb-red);
}

@media (max-width: 540px) {
	body.blog .entry-content {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	body.blog article.post .entry-title {
		font-size: 1.1rem !important;
	}
}

/* ============================================================ */
/* VARSITY HISTORY PAGE                                            */
/* ============================================================ */

.tb-history-page {
	max-width: 1000px;
	margin: 0 auto;
	padding: 1rem 0 2.5rem;
}
.tb-hist-section {
	margin: 0 0 2.25rem;
}
.tb-hist-header {
	font-weight: 800 !important;
	font-size: 1.35rem !important;
	letter-spacing: .03em;
	margin: 0 0 1rem !important;
	padding: .5rem .9rem;
	background: linear-gradient(90deg, var(--tb-red) 0%, var(--tb-red-dark) 100%);
	color: #fff !important;
	border-radius: 8px;
	display: flex;
	align-items: center;
	gap: .75rem;
	box-shadow: var(--tb-shadow-sm);
}
.tb-hist-meta {
	margin-left: auto;
	font-size: .75rem;
	font-weight: 600;
	letter-spacing: .08em;
	text-transform: uppercase;
	background: rgba(255,255,255,.18);
	padding: 2px 10px;
	border-radius: 999px;
}
.tb-hist-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .25rem .75rem;
}
.tb-hist-row {
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: 1rem;
	align-items: baseline;
	padding: .5rem .25rem;
	border-bottom: 1px dashed var(--tb-line);
}
.tb-hist-year {
	font-variant-numeric: tabular-nums;
	font-weight: 700;
	color: var(--tb-red);
	font-size: .95rem;
	letter-spacing: .02em;
}
.tb-hist-name {
	color: var(--tb-ink);
	font-size: .95rem;
	line-height: 1.4;
}
.tb-hist-name.tb-na {
	color: #94a3b8;
	font-style: italic;
}
.tb-hist-name.tb-current {
	font-weight: 700;
	color: var(--tb-red);
}
.tb-hist-name.tb-current::after {
	content: " — Current";
	font-size: .7rem;
	font-weight: 600;
	color: #fff;
	background: var(--tb-red);
	padding: 2px 8px;
	border-radius: 999px;
	margin-left: .5rem;
	letter-spacing: .05em;
}
@media (max-width: 720px) {
	.tb-hist-grid { grid-template-columns: 1fr; }
}

/* ============================================================ */
/* CODES OF CONDUCT PAGES                                          */
/* ============================================================ */

.tb-coc-page {
	max-width: 980px;
	margin: 0 auto;
	padding: 1rem 1rem 2.5rem;
}
.tb-coc-intro h2 {
	font-weight: 800 !important;
	font-size: clamp(1.75rem, 3vw, 2.25rem) !important;
	color: var(--tb-ink);
	margin: 0 0 .5rem !important;
	display: inline-block;
	padding-bottom: .35rem;
	border-bottom: 3px solid var(--tb-red);
}
.tb-coc-intro p {
	font-size: 1.05rem;
	line-height: 1.65;
	color: var(--tb-ink-soft);
	max-width: 70ch;
	margin: 0 0 1.5rem;
}

/* Hub grid of 5 cards */
.tb-coc-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 1rem;
	margin-top: 1.5rem;
}
.tb-coc-card {
	display: block;
	background: #fff;
	border: 1px solid var(--tb-line);
	border-top: 4px solid var(--tb-red);
	border-radius: 14px;
	padding: 1.25rem 1.25rem 1rem;
	text-decoration: none !important;
	color: inherit !important;
	box-shadow: var(--tb-shadow-sm);
	transition: transform .2s ease, box-shadow .2s ease, border-top-color .2s ease;
	position: relative;
	overflow: hidden;
}
.tb-coc-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--tb-shadow-md);
	border-top-color: var(--tb-gold);
}
.tb-coc-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 999px;
	background: var(--tb-red);
	color: #fff !important;
	font-weight: 800;
	font-size: 1rem;
	letter-spacing: .04em;
	margin-bottom: .75rem;
}
.tb-coc-card h3 {
	margin: 0 0 .35rem !important;
	font-weight: 800 !important;
	font-size: 1.2rem !important;
	color: var(--tb-ink);
}
.tb-coc-card p {
	font-size: .92rem;
	line-height: 1.5;
	color: #4b5563;
	margin: 0 0 .75rem;
}
.tb-coc-link {
	display: inline-block;
	color: var(--tb-red);
	font-weight: 700;
	font-size: .9rem;
	letter-spacing: .03em;
}
.tb-coc-card:hover .tb-coc-link {
	color: var(--tb-red-dark);
}
.tb-coc-card-commandments {
	grid-column: 1 / -1;
	background: linear-gradient(135deg, #fffbe6 0%, #fff 70%);
	border-top-color: var(--tb-gold);
}
.tb-coc-card-commandments .tb-coc-icon {
	background: var(--tb-gold);
	color: var(--tb-ink) !important;
}
.tb-coc-card-commandments:hover {
	border-top-color: var(--tb-red);
}

/* Sub-pages (individual codes) */
.tb-coc-sub .tb-coc-back {
	display: block;
	width: fit-content;
	font-size: .9rem;
	color: var(--tb-red);
	font-weight: 600;
	text-decoration: none;
	margin: 0 0 1rem;
	transition: transform .15s ease;
}
.tb-coc-sub .tb-coc-back:hover {
	transform: translateX(-3px);
	color: var(--tb-red-dark);
}
.tb-coc-title {
	font-weight: 800 !important;
	font-size: clamp(1.75rem, 3vw, 2.25rem) !important;
	margin: 0 0 .35rem !important;
	color: var(--tb-ink);
	padding-bottom: .35rem;
	border-bottom: 3px solid var(--tb-red);
	display: inline-block;
}
.tb-coc-sub-intro {
	color: #6b7280;
	font-size: 1rem;
	margin: 0 0 1.5rem;
}
.tb-coc-section {
	margin: 1.5rem 0;
}
.tb-coc-section h3 {
	font-weight: 800 !important;
	font-size: 1.2rem !important;
	margin: 0 0 .5rem !important;
	color: var(--tb-red);
}
.tb-coc-section p {
	line-height: 1.65;
	color: var(--tb-ink-soft);
	margin: 0 0 .75rem;
}
.tb-coc-list {
	list-style: none;
	padding: 0;
	margin: 1.5rem 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: .5rem;
}
.tb-coc-list li {
	position: relative;
	padding: .85rem 1rem .85rem 2.5rem;
	background: var(--tb-bg-soft);
	border: 1px solid var(--tb-line);
	border-radius: 10px;
	line-height: 1.5;
	color: var(--tb-ink);
}
.tb-coc-list li::before {
	content: "✓";
	position: absolute;
	left: .9rem;
	top: .85rem;
	font-weight: 800;
	color: var(--tb-red);
}
.tb-coc-list li.tb-coc-quote {
	background: linear-gradient(135deg, #fffbe6 0%, #fff 70%);
	border-left: 4px solid var(--tb-gold);
	font-style: italic;
	color: var(--tb-ink);
	padding-left: 1.5rem;
}
.tb-coc-list li.tb-coc-quote::before {
	content: "“";
	font-size: 1.5rem;
	left: .35rem;
	top: .25rem;
	color: var(--tb-gold);
}
.tb-coc-attribution {
	margin-top: 1.5rem;
	color: #6b7280;
	font-size: .85rem;
	text-align: right;
}

/* ============================================================ */
/* ABOUT PAGE                                                      */
/* ============================================================ */

.tb-about-page {
	max-width: 1000px;
	margin: 0 auto;
	padding: 1rem 0 2.5rem;
}
.tb-about-intro h2 {
	font-weight: 800;
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	color: var(--tb-ink);
	margin: 0 0 1rem;
	display: inline-block;
	padding-bottom: .35rem;
	border-bottom: 3px solid var(--tb-gold);
}
.tb-about-intro p {
	font-size: 1.05rem;
	line-height: 1.65;
	color: var(--tb-ink-soft);
	margin: 0 0 1rem;
}
.tb-about-tagline {
	font-size: 1.25rem !important;
	color: var(--tb-red) !important;
	letter-spacing: .04em;
	font-style: italic;
}

.tb-about-board {
	margin-top: 2.5rem;
}
.tb-about-board h3 {
	font-weight: 800 !important;
	font-size: 1.4rem !important;
	color: var(--tb-ink);
	letter-spacing: .03em;
	margin: 0 0 1.25rem !important;
	border-bottom: 2px solid var(--tb-red);
	padding-bottom: .4rem;
	display: inline-block;
}
.tb-board-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 1rem;
}
.tb-board-card {
	background: #fff;
	border: 1px solid var(--tb-line);
	border-top: 4px solid var(--tb-red);
	border-radius: 12px;
	padding: 1.1rem 1.25rem;
	box-shadow: var(--tb-shadow-sm);
	transition: transform .15s ease, box-shadow .15s ease, border-top-color .15s ease;
}
.tb-board-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--tb-shadow-md);
	border-top-color: var(--tb-gold);
}
.tb-board-role {
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--tb-red);
	margin-bottom: .25rem;
}
.tb-board-name {
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--tb-ink);
	margin-bottom: .35rem;
}
.tb-board-email a {
	font-size: .85rem;
	color: #4b5563;
	word-break: break-word;
}
.tb-board-email a:hover {
	color: var(--tb-red);
}

.tb-about-cta {
	margin-top: 2.5rem;
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	justify-content: center;
}
.tb-about-btn {
	display: inline-block;
	padding: .85rem 1.75rem;
	border-radius: 999px;
	font-weight: 700;
	letter-spacing: .06em;
	text-decoration: none !important;
	transition: transform .15s ease, box-shadow .15s ease;
}
.tb-about-btn:hover {
	transform: translateY(-2px);
	box-shadow: var(--tb-shadow-md);
}
.tb-about-btn-primary {
	background: var(--tb-red);
	color: #fff !important;
}
.tb-about-btn-primary:hover {
	background: var(--tb-red-dark);
}
.tb-about-btn-secondary {
	background: transparent;
	color: var(--tb-red) !important;
	border: 2px solid var(--tb-red);
}
.tb-about-btn-secondary:hover {
	background: var(--tb-red);
	color: #fff !important;
}

/* ============================================================ */
/* HOMEPAGE SECTION POLISH                                         */
/* ============================================================ */

/* Welcome section (2b7a53a) — give it breathing room, better typography,
   and a small accent under the heading. */
body.home .elementor-element-2b7a53a {
	padding: 3rem 1rem !important;
}
body.home .elementor-element-2b7a53a .elementor-widget-heading .elementor-heading-title {
	font-weight: 800 !important;
	letter-spacing: .02em !important;
	font-size: clamp(1.5rem, 2.5vw, 2rem) !important;
	max-width: 36ch;
	margin: 0 auto !important;
	position: relative;
	padding-bottom: .65rem !important;
	color: var(--tb-ink) !important;
}
body.home .elementor-element-2b7a53a .elementor-widget-heading .elementor-heading-title::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	width: 60px;
	height: 3px;
	background: var(--tb-red);
	border-radius: 3px;
}
body.home .elementor-element-2b7a53a .elementor-widget-text-editor {
	max-width: 720px;
	margin: 1.25rem auto 0 !important;
}
body.home .elementor-element-2b7a53a .elementor-widget-text-editor p {
	font-size: 1.02rem !important;
	line-height: 1.7 !important;
	color: var(--tb-ink-soft) !important;
	text-align: center;
}
/* SCHSHL link — wrap the logo + text into a nice clickable pill */
body.home .elementor-element-2b7a53a .elementor-widget-image {
	margin: 1.25rem auto .25rem !important;
}
body.home .elementor-element-2b7a53a .elementor-widget-image img {
	transition: transform .25s ease;
}
body.home .elementor-element-2b7a53a .elementor-widget-image a:hover img {
	transform: translateY(-2px);
}

/* JOIN US team-photo CTA (57a454d) — bigger heading, better text, gold accent */
body.home .elementor-element-57a454d .elementor-cta__title {
	font-weight: 800 !important;
	letter-spacing: .08em !important;
	font-size: clamp(2rem, 4vw, 3.2rem) !important;
	margin-bottom: .35rem !important;
}
body.home .elementor-element-57a454d .elementor-cta__description {
	font-size: 1.05rem !important;
	max-width: 56ch;
	margin: 0 auto 1.25rem !important;
	line-height: 1.55 !important;
}
body.home .elementor-element-57a454d .elementor-cta__bg-overlay {
	background: linear-gradient(180deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,.7) 100%) !important;
	opacity: 1 !important;
}
body.home .elementor-element-57a454d .elementor-cta {
	border-radius: 0;
	min-height: 320px;
}
body.home .elementor-element-57a454d .elementor-cta__content::after {
	content: "";
	display: block;
	width: 80px;
	height: 4px;
	background: var(--tb-gold);
	margin: 1rem auto 0;
	border-radius: 4px;
}

/* Bottom 3-column section (dd84b0d) — cohesive, balanced cards. */
body.home .elementor-element-dd84b0d {
	padding: 3rem 1rem !important;
	background: var(--tb-bg-soft);
}
body.home .elementor-element-dd84b0d > .elementor-container {
	gap: 1.5rem !important;
}

/* Wrap each column body in a card. We style the widget-wrap of each
   column so the column heading sits ABOVE its card. */
body.home .elementor-element-dd84b0d .elementor-column > .elementor-widget-wrap {
	background: #fff !important;
	border: 1px solid var(--tb-line) !important;
	border-radius: 14px !important;
	padding: 1.5rem 1.25rem !important;
	box-shadow: var(--tb-shadow-sm);
	min-height: 340px;
	display: flex !important;
	flex-direction: column;
	transition: transform .2s ease, box-shadow .2s ease;
}
body.home .elementor-element-dd84b0d .elementor-column:hover > .elementor-widget-wrap {
	transform: translateY(-3px);
	box-shadow: var(--tb-shadow-md);
}
/* Cancel the per-widget card styling I set earlier — now the COLUMN is the card */
body.home .elementor-element-dd84b0d .elementor-widget-nav-menu,
body.home .elementor-element-dd84b0d .elementor-widget-jkit_post_list,
body.home .elementor-element-dd84b0d .elementor-widget-sidebar {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0 !important;
	margin: 0 !important;
	min-height: 0;
}

/* Column headings */
body.home .elementor-element-dd84b0d .elementor-widget-heading {
	margin-bottom: 1rem !important;
	padding-bottom: .75rem;
	border-bottom: 2px solid var(--tb-line);
	position: relative;
}
body.home .elementor-element-dd84b0d .elementor-widget-heading::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -2px;
	width: 40px;
	height: 2px;
	background: var(--tb-red);
}
body.home .elementor-element-dd84b0d .elementor-widget-heading .elementor-heading-title {
	font-size: .9rem !important;
	letter-spacing: .14em !important;
	text-transform: uppercase !important;
	font-weight: 800 !important;
	color: var(--tb-ink) !important;
	padding: 0 !important;
	margin: 0 !important;
}
body.home .elementor-element-dd84b0d .elementor-widget-heading .elementor-heading-title::after {
	display: none !important;
}

/* TEAMS column — make nav-menu items look like proper rows */
body.home .elementor-element-dd84b0d .elementor-widget-nav-menu .elementor-nav-menu li a.elementor-item {
	padding: .85rem .25rem !important;
	font-weight: 600 !important;
	font-size: 1rem !important;
	color: var(--tb-ink) !important;
	border-bottom: 1px solid var(--tb-line) !important;
	display: flex !important;
	align-items: center;
	justify-content: space-between;
	transition: color .15s ease, padding-left .15s ease;
}
body.home .elementor-element-dd84b0d .elementor-widget-nav-menu .elementor-nav-menu li a.elementor-item::after {
	content: "→";
	color: var(--tb-red);
	font-weight: 700;
	font-size: 1rem;
	transition: transform .15s ease;
	margin-left: .5rem;
}
body.home .elementor-element-dd84b0d .elementor-widget-nav-menu .elementor-nav-menu li:last-child a.elementor-item {
	border-bottom: 0 !important;
}
body.home .elementor-element-dd84b0d .elementor-widget-nav-menu .elementor-nav-menu li a.elementor-item:hover {
	color: var(--tb-red) !important;
	padding-left: .5rem !important;
}
body.home .elementor-element-dd84b0d .elementor-widget-nav-menu .elementor-nav-menu li a.elementor-item:hover::after {
	transform: translateX(3px);
}

/* CLUB NEWS jkit_post_list items */
body.home .elementor-element-dd84b0d .jkit-postlist .jkit-postlist-item {
	padding: .75rem 0 !important;
	border-bottom: 1px solid var(--tb-line);
	display: flex;
	gap: .75rem;
	align-items: flex-start;
}
body.home .elementor-element-dd84b0d .jkit-postlist .jkit-postlist-item:last-child {
	border-bottom: 0;
}
body.home .elementor-element-dd84b0d .jkit-postlist .jkit-post-title,
body.home .elementor-element-dd84b0d .jkit-postlist .jkit-postlist-content a {
	font-weight: 600 !important;
	color: var(--tb-ink) !important;
	transition: color .15s ease;
	font-size: .92rem !important;
	line-height: 1.4 !important;
	text-decoration: none !important;
}
body.home .elementor-element-dd84b0d .jkit-postlist .jkit-post-title:hover,
body.home .elementor-element-dd84b0d .jkit-postlist .jkit-postlist-content a:hover {
	color: var(--tb-red) !important;
}
/* If thumb is present, constrain its size */
body.home .elementor-element-dd84b0d .jkit-postlist .jkit-postlist-thumbnail,
body.home .elementor-element-dd84b0d .jkit-postlist .jkit-postlist-thumbnail img {
	width: 80px !important;
	height: 60px !important;
	min-width: 80px;
	object-fit: cover !important;
	border-radius: 6px;
	margin: 0 !important;
}

/* CLUB CALENDAR (Tribe widget) — clean up the empty state and any list */
body.home .elementor-element-dd84b0d .tribe-compatibility-container {
	font-size: .92rem;
}
/* Hide redundant subheading "Upcoming Events" inside the widget */
body.home .elementor-element-dd84b0d .tribe-events-widget-events-list__header,
body.home .elementor-element-dd84b0d .tribe-events-widget-events-list__view-more-link-wrapper,
body.home .elementor-element-dd84b0d .tribe-events-c-subscribe-dropdown__container,
body.home .elementor-element-dd84b0d .tribe-events-widget__title {
	display: none !important;
}
/* Style the "no upcoming events" notice as a friendly empty state */
body.home .elementor-element-dd84b0d .tribe-events-widget-events-list__no-results,
body.home .elementor-element-dd84b0d .tribe-events-c-messages__message-notice,
body.home .elementor-element-dd84b0d .tribe-common-l-container .tribe-events-c-messages,
body.home .elementor-element-dd84b0d [class*="no-results"],
body.home .elementor-element-dd84b0d [class*="empty"] {
	padding: 1.25rem 1rem !important;
	background: var(--tb-bg-soft) !important;
	border: 1px dashed var(--tb-line) !important;
	border-radius: 10px !important;
	color: #6b7280 !important;
	text-align: center !important;
	font-style: italic;
}
/* Style each upcoming event row when they exist (forward-compatible) */
body.home .elementor-element-dd84b0d .tribe-events-widget-events-list__event-row {
	padding: .75rem 0 !important;
	border-bottom: 1px solid var(--tb-line);
	margin: 0;
}
body.home .elementor-element-dd84b0d .tribe-events-widget-events-list__event-row:last-child {
	border-bottom: 0;
}
body.home .elementor-element-dd84b0d .tribe-events-widget-events-list__event-title a {
	font-weight: 600 !important;
	color: var(--tb-ink) !important;
	font-size: .92rem !important;
}
body.home .elementor-element-dd84b0d .tribe-events-widget-events-list__event-date-tag {
	background: var(--tb-red) !important;
	color: #fff !important;
	border-radius: 8px;
	padding: 4px 8px !important;
}

/* Hide the empty / spacer section if present */
body.home .elementor-element-63afe80 {
	display: none !important;
}

/* Smart Slider hero polish — ONLY target the slider widget itself,
   NOT the outer section (2e9e531b wraps the whole page body). */
body.home .elementor-widget-smartslider {
	background: var(--tb-ink);
}
body.home div#n2-ss-2 .n-uc-16ea8b2d74a56,
body.home div#n2-ss-2 [class*="16ea8b2d74a56"] {
	max-width: 1100px;
}
/* Slider arrows: bigger and on-brand */
body.home div#n2-ss-2 .nextend-arrow {
	background: rgba(255,255,255,.95) !important;
	border-radius: 999px !important;
	width: 44px !important;
	height: 44px !important;
	display: flex !important;
	align-items: center;
	justify-content: center;
	box-shadow: 0 6px 14px rgba(0,0,0,.25) !important;
	transition: background .15s ease, transform .15s ease !important;
}
body.home div#n2-ss-2 .nextend-arrow:hover {
	background: var(--tb-red) !important;
	transform: scale(1.05);
}
body.home div#n2-ss-2 .nextend-arrow img {
	width: 20px !important;
	filter: invert(0);
}
body.home div#n2-ss-2 .nextend-arrow:hover img {
	filter: invert(1) brightness(2);
}

/* On mobile, give bottom column section single-column spacing */
@media (max-width: 767px) {
	body.home .elementor-element-dd84b0d .elementor-widget-nav-menu,
	body.home .elementor-element-dd84b0d .elementor-widget-jkit_post_list,
	body.home .elementor-element-dd84b0d .elementor-widget-sidebar {
		min-height: 0;
		margin: 0 0 1rem !important;
	}
	body.home .elementor-element-57a454d .elementor-cta {
		min-height: 240px;
	}
}

/* ---------- "Click here for more information" / generic anchor styling ---------- */
.elementor-widget-text-editor a {
	color: var(--tb-red);
	font-weight: 600;
}
.elementor-widget-text-editor a:hover {
	color: var(--tb-red-dark);
	text-decoration: underline;
}

/* ---------- Hide the duplicate "FOLLOW US ON SOCIAL MEDIA" sub-line ---------- */
footer[class*="elementor-location-footer"] .elementor-widget-text-editor p:only-child:where(:has-text("News, Highlights")) {
	/* :has-text isn't a CSS selector — keep it as-is (no-op) for safety */
}
