/* [ Flexbox ] */

.flexbox {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	margin-left: -10px;
	margin-right: -10px;
}

.flexbox .sm-col-1,
.flexbox .sm-col-2,
.flexbox .sm-col-3,
.flexbox .sm-col-4,
.flexbox .sm-col-5,
.flexbox .sm-col-6,
.flexbox .sm-col-7,
.flexbox .sm-col-8,
.flexbox .sm-col-9,
.flexbox .sm-col-10,
.flexbox .md-col-1,
.flexbox .md-col-2,
.flexbox .md-col-3,
.flexbox .md-col-4,
.flexbox .md-col-5,
.flexbox .md-col-6,
.flexbox .md-col-7,
.flexbox .md-col-8,
.flexbox .md-col-9,
.flexbox .md-col-10,
.flexbox .lg-col-1,
.flexbox .lg-col-2,
.flexbox .lg-col-3,
.flexbox .lg-col-4,
.flexbox .lg-col-5,
.flexbox .lg-col-6,
.flexbox .lg-col-7,
.flexbox .lg-col-8,
.flexbox .lg-col-9,
.flexbox .lg-col-10 {
	margin-left: 10px;
	margin-right: 10px;
}

.flexbox .sm-col-1 {
	width: 100%;
}

.flexbox .sm-col-2 {
	width: calc(1/2 * 100% - 20px);
}

.flexbox .sm-col-3 {
	width: calc(1/3 * 100% - 20px);
}

.flexbox .sm-col-4 {
	width: calc(1/4 * 100% - 20px);
}

.flexbox .sm-col-5 {
	width: calc(1/5 * 100% - 20px);
}

.flexbox .sm-col-6 {
	width: calc(1/6 * 100% - 20px);
}

.flexbox .sm-col-7 {
	width: calc(1/7 * 100% - 20px);
}

.flexbox .sm-col-8 {
	width: calc(1/8 * 100% - 20px);
}

.flexbox .sm-col-9 {
	width: calc(1/9 * 100% - 20px);
}

.flexbox .sm-col-10 {
	width: calc(1/10 * 100% - 20px);
}

	.flexbox .sm-col-3.width-20 {
		width: calc(22% - 20px);
	}
	.flexbox .sm-col-3.width-30 {
		width: calc(30% - 20px);
	}

	.flexbox .sm-col-3.width-40 {
		width: calc(40% - 20px);
	}

	.flexbox .sm-col-3.width-60 {
		width: calc(56% - 20px);
	}

@media screen and (min-width: 768px) {
	.flexbox .md-col-1 {
		width: 100%;
	}

	.flexbox .md-col-2 {
		width: calc(1/2 * 100% - 20px);
	}

	.flexbox .md-col-3 {
		width: calc(1/3 * 100% - 20px);
	}

	.flexbox .md-col-4 {
		width: calc(1/4 * 100% - 20px);
	}

	.flexbox .md-col-5 {
		width: calc(1/5 * 100% - 20px);
	}

	.flexbox .md-col-6 {
		width: calc(1/6 * 100% - 20px);
	}

	.flexbox .md-col-7 {
		width: calc(1/7 * 100% - 20px);
	}

	.flexbox .md-col-8 {
		width: calc(1/8 * 100% - 20px);
	}

	.flexbox .md-col-9 {
		width: calc(1/9 * 100% - 20px);
	}

	.flexbox .md-col-10 {
		width: calc(1/10 * 100% - 20px);
	}
	.flexbox .md-col-3.width-25 {
		width: calc(25% - 20px);
	}
	.flexbox .md-col-3.width-50 {
		width: calc(50% - 20px);
	}
}

@media screen and (min-width: 1024px) {
	.flexbox .lg-col-1 {
		width: 100%;
	}

	.flexbox .lg-col-2 {
		width: calc(1/2 * 100% - 20px);
	}

	.flexbox .lg-col-3 {
		width: calc(1/3 * 100% - 20px);
	}

	.flexbox .lg-col-4 {
		width: calc(1/4 * 100% - 20px);
	}

	.flexbox .lg-col-5 {
		width: calc(1/5 * 100% - 20px);
	}

	.flexbox .lg-col-6 {
		width: calc(1/6 * 100% - 20px);
	}

	.flexbox .lg-col-7 {
		width: calc(1/7 * 100% - 20px);
	}

	.flexbox .lg-col-8 {
		width: calc(1/8 * 100% - 20px);
	}

	.flexbox .lg-col-9 {
		width: calc(1/9 * 100% - 20px);
	}

	.flexbox .lg-col-10 {
		width: calc(1/10 * 100% - 20px);
	}
	.flexbox .md-col-3.width-20,
	.flexbox .sm-col-3.width-20 {
		width: calc(22% - 20px);
	}

	.flexbox .md-col-3.width-30,
	.flexbox .sm-col-3.width-30 {
		width: calc(30% - 20px);
	}

	.flexbox .md-col-3.width-40,
	.flexbox .sm-col-3.width-40 {
		width: calc(40% - 20px);
	}

	.flexbox .md-col-3.width-60,
	.flexbox .sm-col-3.width-60 {
		width: calc(56% - 20px);
	}
}

#clear-filters {
	float: right;
	margin-top: 10px;
	text-decoration: none;
	display: none;
}

#clear-filters:after {
	display:  inline-block;
	content: 'x';
	padding-left: 5px;
}

.event-month {
	font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin:  0px !important;
    line-height:  16.5px;
}

.event-day {
	font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin:  0px;
    font-weight: 700 !important;
    line-height:  27px;
}

.show-post:not(.show-map-marker) .flexbox {
	border-bottom:  1px solid rgb(20, 24, 39);
	padding:  10px;
}

.gm-style-iw-d .show-post {
	border-bottom: 0px;
	padding: 0px;
	overflow: hidden;
}

.show-post .h4 {
	font-size:  18px;
	    margin-bottom: 0px;
		line-height: 1.25em;
		text-align: left;
		    padding-bottom: 0px;
    border-bottom: 0px;
}

.show-post .h4 a {
	color: #cf343c !important;
}

.start-time {
	font-size: 14px;
	margin:  0px !important;
	line-height:  12px;
	line-height:  16.5px;
}

.game-logo {
	max-width: 50px !important;
	margin-top: 5px;
	margin-bottom: 5px;
}

.venue-address {
	font-size:  14px !important;
	line-height:  16px !important;
	letter-spacing:  0.3px;
	text-transform: uppercase;
	font-weight:  400;
	margin-bottom:  10px;
}

.venue-address a {
	font-weight:  700 !important;
	text-decoration:  underline !important;
	color: rgb(20, 24, 39) !important;
}

.venue-address a:hover {
	text-decoration:  none !important;
	opacity:  1 !important;
}

.show-links a {
	font-size: 12px;
	font-weight:  700;
	text-decoration:  underline;
}

.show-links div {
	margin: 0px 5px;
}

.show-links a:hover {
	text-decoration:  none;
}

.venue-links {
	margin-bottom:10px;
}

.venue-links .external-link {
	fill: #008aa4;
	position:  relative;
	top: 4px;
	margin-left:  4px;
}

.venue-links a:hover .external-link {
	fill:  #21a7bd;
}

.left-column-venue img {
	    margin-bottom: 25px;
    max-width: 250px;
}

.left-column-venue {
	text-align:  center;
	margin-bottom:  30px;
}

.venue-single-map {
	margin-bottom:  30px !important;
}

.venue-social {
	margin-top: 10px;
}

.x-social-icon svg {
	    padding: 4px;
}

.single-venue-post .md-col-3 {
	padding:  0px 20px;
}

::-webkit-scrollbar {
  -webkit-appearance: none;
  width: 10px;
}

::-webkit-scrollbar-thumb {
  border-radius: 5px;
  background-color: rgba(0,0,0,.5);
  -webkit-box-shadow: 0 0 1px rgba(255,255,255,.5);
}

.page-id-140071 .fl-node-soz8u0qyieah {
	display:  none !Important;
}

.page-id-140071 .fl-node-l4np3oz8wem7 {
	padding-top:  100px; padding-bottom:  100px;
}

/* Single show */

.single-custom-post {
	width:  100%;
	max-width: 1240px;
	margin:  0 auto;
	padding: 50px 0px;
}

.single-custom-post h2 {
	 font-size: 20px;
	    font-family: 'Barlow Condensed', sans-serif;
    line-height: 1.4em;
    text-transform: uppercase;
}

.single-custom-post #single-map {
	width: 100%;
	margin: 0px;
}

.single-custom-post-container {
	width: 100%;
}

.single-custom-post-container p {
	font-size: 18px;
	line-height: 1.4;
}

.show-list-time img {
	padding-right: 10px;
}

.show-list-time {
	font-size: 14px;
}

.tax-area h2 {
	    color: black;
    font-family: 'Barlow Condensed';
    font-weight: bold;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.latest-posts-title p {
	font-size: 24px;
}

.tax-area h1 .dark {
	color: #2E2E3A !important;
}

.custom-latest-posts {
	align-items: center;
	padding-left :80px;
	padding-right: 80px;
	max-width: 1200px;
	margin: 0 auto;
}

.custom-latest-posts .flexbox {
	align-items: stretch;
}

.custom-latest-posts .md-col-2 {
	min-height: 305px;
}

.custom-latest-posts .post-categories a {
	color: #000000;
	text-transform: uppercase;
	font-size: 16px;
	font-weight: bold !important;
	letter-spacing: -0.5px;
}

.custom-latest-posts .post-title a,
.custom-latest-posts h3.post-title  {
	font-family: Barlow;
	font-weight: normal;
	font-size: 24px;
	letter-spacing: -0.5px;
	line-height: 32px !important;
	text-transform: none;
	color: #000000 !important;
	text-decoration: underline;
}

.custom-latest-posts h3.post-title {
	padding-top: 10px;
	padding-bottom: 20px;
}

.custom-latest-posts .content-area {
	padding-top: 20px;
	padding-bottom: 20px;
}

.custom-latest-posts .post-thumbnail {
  height: 100%;
  display: flex;
}

.custom-latest-posts {
	justify-content: center;
	margin-top: 40px;
}

.custom-latest-posts h2 {
	margin-bottom: 0px;
}

.standings-wrapper {
	margin-bottom: 80px !important;
	margin-top: 80px !important;
	max-width: 1080px;
    margin: 40px auto;
    padding: 0px 30px;
}

.custom-latest-posts img {
	width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ntl-buttons .btn {
	margin-bottom: 25px;
}

.area-standings {
	margin-top: 80px;
	margin-bottom: 40px;
	    padding: 0px 25px;
}

.standings-left {
	text-align: center;
	position: relative;
}

.area-social-media {
	align-items: center;
	max-width: 1200px;
	margin: 80px auto 80px;
	padding: 0px;
		text-align: center;
		background-image: url(../images/white-hero.png);
	background-size: cover;
	background-repeat: no-repeat;
	box-shadow: 1px -1px 16px -1px rgba(0,0,0,0.24);
-webkit-box-shadow: 1px -1px 16px -1px rgba(0,0,0,0.24);
-moz-box-shadow: 1px -1px 16px -1px rgba(0,0,0,0.24);
}

.area-social-media .md-col-2 {
	width: 50%;
	margin: 0px;
}

.area-social-media iframe {
	margin-bottom: 0px !important;
}

.social-icon-links img {
	width: 50px;
	margin-right: 20px;
}

.standings-left img {
	max-width: 400px;
}

.standings-left p {
	font-size: 3rem;
    color: #cf333c;
    font-weight: bold;
}

.standings-left p.current-standings-header {
	color: black;
    font-family: 'Barlow Condensed';
    margin-bottom: 0px;
    font-size: 97px;
}

.simple-slider .show-post .featured-image {
	max-width: 250px;
	    margin: 50px auto 20px;
}

.simple-slider .tagline {
	    color: black;
    font-family: 'Barlow Condensed';
    font-weight: bold;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.area-hero {
    z-index: 20;
}

.slide .venue-name {
	margin-bottom: 0px;
}

.slide .venue-name,
.slide .venue-name a {
	font-size: 30px;
	color: black !important;
	    font-weight: bold;
}

.slide .venue-address  {
	font-size: 30px !important;
	line-height: 1.2em !important;
	font-family: 'Barlow Condensed';
	margin-bottom: 32px !important;
}

@media (max-width: 768px) {
    .tax-area .fl-col-small:not(.fl-col-small-full-width) {
        max-width: 100%;
    }

	.area-hero .fl-col-content {
		padding-left: 30px !important;
		padding-right: 30px !important;
		padding-top: 60px !important;
		padding-bottom: 60px !important;
	}

	.area-hero h1, .area-hero .dark {
		font-size: 40px !important;
	}

	.area-hero h2 {
		font-size: 80px !important;
	}

	.area-hero .fl-node-ysfodkj2iq19 h2 {
		font-size: 30px !important;
	}

	.current-standings-header {
		font-size: 60px !important;
	}

	.custom-latest-posts .content-area {
		margin-bottom: 30px;
	}

	.area-social-media .md-col-2  {
		width: 100%;
	}
}

@media screen and (max-width: 767px) {
	.featured-show {
		display: flex;
	}

	.featured-show h2 {
		font-size: 35px;
		text-align: left;
	}

	.featured-show .featured-image {
		width: 25%;
	}

	.featured-show .featured-show-content {
		width: 75%;
		padding-left: 25px;
	}

		.featured-show  .venue-name,
		.featured-show  .venue-address {
			text-align: left;
		}

	.show-post h3 {
		font-size: 35px;
		text-align: center;
	}
	.slide,
	.simple-slider {
		height: 440px !important;
		padding-top: 20px;
	}

	.simple-slider .show-post .featured-image {
		margin-top: 0px;
	}
}

.show-post.ntl-show-post-cancelled {
  background: #F3F3F3;
}
.show-post.ntl-show-post-cancelled .show-list-time {
  text-decoration: line-through;
  color: #999;
}
.ntl-cancelled-badge {
  display: inline-block;
  color: var(--ntl-red, #D0342C);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: .3px;
  text-decoration: none;
  margin-right: 8px;
}

.show-post.rescheduled .flexbox {
	    filter: grayscale(100%);
    background-color: #E9EBED;
}

.show-post.rescheduled  {
position: relative;
}

.show-post.rescheduled:after {
	    position: absolute;
    content: 'Canceled This Week';
    bottom: 50%;
    left: 0px;
    width: 25%;
    font-size: 12px;
    font-weight: bold;
    text-transform: uppercase;
    text-align: center;
    line-height: 1.25em;
    color: #cf343c !important;
}

.show-post.rescheduled .event-month,
.show-post.rescheduled .start-time {
	text-decoration: line-through;
}

.gm-style img {
	max-width: 100%;
}

@media screen and (max-width: 767px) {
	.fl-node-2vntld065hmf.fl-module-heading .fl-heading {
		font-size: 40px;
	}
}

.preset-input {
	margin-top: 4px;
	font-size: 16px;
	font-weight: bold;
	color: black;
}
.preset-input input {
	margin-right: 8px;
	display: inline-block;
}

.single .show-post .rescheduled {
	text-decoration: line-through;
}

.single .show-post .rescheduled::after {
	 display: inline-block;
	 content: "Cancelled This Week";
	 text-transform: uppercase;
	 margin-left: 20px;
	     font-size: 12px;
    font-weight: bold;
    text-transform: uppercase;
    text-align: center;
    line-height: 1.25em;
    color: #cf343c !important;
}

.radius-expanded-note {
    padding: 12px 16px;
    margin: 0 0 16px 0;
    background: #f5f5f5;
    border-left: 4px solid #008aa4;
    font-weight: 700;
    font-size: 16px;
}

.bring-games-btn {
	color: #ffffff;
    text-transform: uppercase;
    font-family: "Barlow Condensed";
    font-weight: 700;
    font-size: 18px;
    border: 2px solid #008aa4;
    border-radius: 25px;
    padding-top: 5px;
    padding-right: 20px;
    padding-bottom: 5px;
    padding-left: 20px;
    background-color: #008aa4;
}

.geo-hint {
  margin: .5rem 0 0;
  padding: .5rem .75rem;
  border: 1px solid #e2e2e2;
  border-radius: .375rem;
  font-size: .9rem;
  background: #fffbe6;
  position: relative;
}
.geo-hint ul { margin: .25rem 0 .25rem 1.25rem; }
.geo-hint-close {
  position: absolute; top: .25rem; right: .4rem;
  background: transparent; border: 0; font-size: 1.1rem; line-height: 1; cursor: pointer;
}

/* ── Map popup styles ─────────────────────────────────────────────────────── */

.ntl-map-popup .leaflet-popup-content-wrapper {
    border-radius: 10px;
    padding: 0;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0,0,0,0.18);
}

.ntl-map-popup .leaflet-popup-content {
    margin: 0;
    min-width: 220px;
}

.map-popup {
    font-family: -apple-system, "Segoe UI", sans-serif;
    font-size: 13px;
}

.map-popup-venue {
    background: #1a1f3a;
    color: #fff;
    padding: 10px 14px;
}

.map-popup-venue strong {
    display: block;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 3px;
}

.map-popup-directions {
    display: block;
    color: rgba(255,255,255,.8) !important;
    font-size: 12px;
	font-weight: bold;
    line-height: 1.4;
    text-decoration: underline !important;
}

.map-popup-directions:hover {
    color: rgba(255,255,255,1) !important;
    text-decoration:none !important;
}

.map-popup-show {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 14px;
    border-bottom: 1px solid #f0f0f0;
}

.map-popup-show:last-child {
    border-bottom: none;
}

.map-popup-show.rescheduled {
    opacity: 0.55;
}

.map-popup-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 30px;
    text-align: center;
}

.map-popup-month {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    color: #D0342C;
    letter-spacing: 0.5px;
    line-height: 1;
}

.map-popup-day {
    font-size: 20px;
    font-weight: 800;
    color: #111;
    line-height: 1;
}

.map-popup-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
    min-width: 0;
}

.map-popup-logo {
    width: auto;
    height: 18px;
    object-fit: contain;
    object-position: left;
}

.map-popup-info a {
    font-size: 12px;
    font-weight: 600;
    color: #111;
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.map-popup-info a:hover {
    color: #D0342C;
    text-decoration: underline;
}

.map-popup-time {
    font-size: 11px;
    color: #888;
}

/* ════════════════════════════════════════════════════════════════════════
   NTL SHOW FINDER — app-matching redesign
   ════════════════════════════════════════════════════════════════════════ */

:root {
  --ntl-red: #D0342C;
  --ntl-ink: #111111;
  --ntl-border: #E8E8E8;
  --ntl-bg-soft: #F5F5F5;
}

.ntl-finder {
  font-family: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  max-width: 1280px;
  margin: 0 auto;
  padding: 16px;
  box-sizing: border-box;
}
.ntl-finder * { box-sizing: border-box; }

/* ── Top bar: search + filter + locate ───────────────────────────────── */

.ntl-finder-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  background: #ffffff;
  border-radius: 50px;
  padding: 16px;
}

.ntl-search-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  border: none;
  border-radius: 50px;
  min-width: 0;
}
.ntl-search-wrap .ntl-search-icon { color: #aaa; flex-shrink: 0; }
.ntl-search-wrap input {
  border: none;
  background: transparent;
  outline: none;
  font-size: 15px;
  color: #333;
  flex: 1;
  min-width: 0;
}
.ntl-search-wrap input::placeholder { color: #999; }

.ntl-bar-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #FCEFEC;
  border: none;
  border-radius: 50px;
  padding: 13px 20px;
  font-size: 14px;
  font-weight: 700;
  color: var(--ntl-ink);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  position: relative;
  transition: background .15s;
}
.ntl-bar-btn svg { flex-shrink: 0; }
.ntl-bar-btn-active { background: var(--ntl-ink); color: #fff; }

.ntl-bar-btn .ntl-badge {
  position: absolute;
  top: -6px;
  right: -6px;
}

@media (max-width: 640px) {
  .ntl-bar-btn-label { display: none; }
  .ntl-bar-btn { padding: 12px; border-radius: 50%; }
}

.ntl-badge {
  position: absolute;
  top: -3px; right: -3px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--ntl-ink);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ntl-badge[hidden] {
  display: none;
}

/* ── List / Map segmented toggle (hidden on desktop) ─────────────────── */

.ntl-view-toggle {
  display: flex;
  background: #F0F0F0;
  border-radius: 10px;
  padding: 3px;
  gap: 2px;
  margin-bottom: 12px;
}
.ntl-view-btn {
  flex: 1;
  padding: 9px;
  border: none;
  border-radius: 7px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  background: transparent;
  color: #888;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: all .15s;
}
.ntl-view-btn.active {
  background: #fff;
  color: var(--ntl-red);
  box-shadow: 0 1px 3px rgba(0,0,0,.1);
}

/* ── Active filter chips ──────────────────────────────────────────────── */

.ntl-chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: -32px;
}
.ntl-chips[hidden] {
  display: none;
}
.ntl-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 12px;
  border-radius: 50px;
  background: #FFF0F0;
  border: 1px solid #FFCCCC;
  font-size: 12px;
  font-weight: 700;
  color: var(--ntl-red);
  cursor: pointer;
  white-space: nowrap;
}
.ntl-chip-static { cursor: default; }

/* ── Finder body — side-by-side on desktop, toggled below 1024px ──────── */

.ntl-finder-body {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 20px;
  align-items: start;
      margin-top: 80px;
}

.ntl-map-col, .ntl-list-col { min-width: 0; }

.ntl-map {
  width: 100%;
  height: 640px;
  border-radius: 14px;
  overflow: hidden;
  position: sticky;
  top: 16px;
}

.ntl-list-col {
  max-height: 640px;
  overflow-y: auto;
  border: 1px solid var(--ntl-border);
  border-radius: 14px;
}

@media (max-width: 1023px) {
  .ntl-finder-body { display: block; }
  .ntl-map-col, .ntl-list-col { display: none; }
  .ntl-finder-body[data-active-view="list"] .ntl-list-col { display: block; }
  .ntl-finder-body[data-active-view="map"] .ntl-map-col { display: block; }
  .ntl-map { height: 320px; position: static; border-radius: 12px 12px 0 0; }
  .ntl-list-col { max-height: none; border-radius: 0 0 12px 12px; border-top: none; }
}

@media (min-width: 1024px) {
  .ntl-view-toggle { display: none; }
}

/* ── Results meta row ─────────────────────────────────────────────────── */

.ntl-results-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  border-bottom: 1px solid #F0F0F0;
  font-size: 12px;
  color: #888;
}
.ntl-results-sort { color: var(--ntl-red); font-weight: 700; }
.ntl-empty-state {
  padding: 48px 16px;
  text-align: center;
  color: #888;
  font-size: 14px;
}

/* ── Show cards ───────────────────────────────────────────────────────── */

.ntl-card {
  padding: 12px 16px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  border-bottom: 1px solid #F5F5F5;
  cursor: pointer;
  background: #fff;
  border-left: 3px solid transparent;
  transition: background .1s;
}
.ntl-card:hover { background: #FAFAFA; }
.ntl-card:last-child { border-bottom: none; }

.ntl-card-thumb {
  width: 54px;
  height: 54px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ntl-card-thumb img { width: 54px; height: 54px; object-fit: contain; }
.ntl-card-thumb-fallback {
  width: 54px; height: 54px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 20px; font-weight: 800;
}

.ntl-card-body { flex: 1; min-width: 0; }

.ntl-card-title {
  font-size: 15px;
  font-weight: 800;
  color: var(--ntl-ink);
  margin-bottom: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ntl-card-venue-row {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 2px;
  min-width: 0;
}
.ntl-card-venue-logo {
  width: 18px;
  height: 18px;
  border-radius: 3px;
  object-fit: cover;
  flex-shrink: 0;
}
.ntl-card-venue {
  font-size: 20px;
  color: #000;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ntl-card-address {
  font-size: 14px;
  color: #000;
  margin-bottom: 5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ntl-card-date-row { margin-bottom: 3px; }
.ntl-card-date-pill {
  font-size: 14px;
  font-weight: 700;
  color: var(--ntl-red);
  background: #FFF0F0;
  padding: 2px 8px;
  border-radius: 50px;
  display: inline-block;
}
.ntl-card-date-pill-today { color: #fff; background: var(--ntl-red); }

.ntl-card-schedule { font-size: 14px; color: #000; margin-top: 1px; }
.ntl-card-dist { font-size: 14px; color: #000; margin-top: 3px; }
.ntl-card-cancelled-label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  color: var(--ntl-red); margin-bottom: 3px;
}
.ntl-card-cancelled { background: #F3F3F3; }
.ntl-card-cancelled .ntl-card-date-pill,
.ntl-card-cancelled .ntl-card-schedule { text-decoration: line-through; }

.ntl-card-chevron { color: #ccc; font-size: 18px; align-self: center; flex-shrink: 0; }

/* ── Filter sheet (modal on all sizes, bottom-sheet feel on mobile) ──── */

.ntl-filter-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(0,0,0,.5);
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.ntl-filter-overlay[hidden] {
  display: none;
}

.ntl-filter-sheet {
  background: #fff;
  border-radius: 20px 20px 0 0;
  width: 100%;
  max-height: 88vh;
  overflow-y: auto;
}

@media (min-width: 640px) {
  .ntl-filter-overlay { align-items: center; }
  .ntl-filter-sheet { border-radius: 20px; max-width: 480px; max-height: 85vh; }
}

.ntl-filter-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid #F0F0F0;
}
.ntl-filter-header button {
  background: none;
  border: none;
  cursor: pointer;
}
#filter-close { color: #333; padding: 4px; display: flex; }
.ntl-filter-title-main { font-size: 17px; font-weight: 700; color: var(--ntl-ink); }
.ntl-clear-link { font-size: 14px; color: #888; font-weight: 600; }

.ntl-filter-body { padding: 20px; }

.ntl-filter-group { margin-bottom: 24px; }
.ntl-filter-title { font-size: 18px; font-weight: 800; color: var(--ntl-ink); margin-bottom: 14px; }
.ntl-filter-title-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.ntl-filter-value { font-size: 18px; font-weight: 700; color: var(--ntl-ink); }
.ntl-filter-divider { height: 1px; background: #F0F0F0; border: none; margin: 0 0 24px; }

.ntl-pill-row { display: flex; flex-wrap: wrap; gap: 10px; }
.ntl-pill {
  padding: 10px 16px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  border: 2px solid var(--ntl-border);
  background: #fff;
  color: #333;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ntl-pill.active {
  border-color: var(--pill-color, var(--ntl-red));
  background: var(--pill-color, var(--ntl-red));
  color: #fff;
  box-shadow: 0 2px 8px rgba(208,52,44,.27);
}
.ntl-pill-game { padding: 6px 12px 6px 6px; }
.ntl-pill-logo {
  width: 32px; height: 32px;
  border-radius: 6px;
  overflow: hidden;
  background: #111;
  flex-shrink: 0;
  display: block;
}
.ntl-pill-logo img { width: 100%; height: 100%; object-fit: cover; }

.ntl-date-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  flex-wrap: wrap;
}
.ntl-date-label { font-size: 12px; color: #999; }
.ntl-date-row input[type="date"] {
  border: 1.5px solid var(--ntl-border);
  border-radius: 8px;
  padding: 6px 10px;
  font-size: 13px;
}

.ntl-hint { font-size: 13px; color: #aaa; margin-top: 8px; }

#radius-slider { width: 100%; accent-color: var(--ntl-red); }

#state-select {
  width: 100%;
  padding: 12px 16px;
  border-radius: 10px;
  border: 1.5px solid var(--ntl-border);
  font-size: 15px;
  color: #333;
  background: #fff;
  outline: none;
}

.ntl-filter-footer {
  padding: 0 20px 28px;
  display: flex;
  gap: 12px;
  align-items: center;
}
.ntl-btn-secondary {
  flex: 1;
  padding: 14px;
  background: none;
  border: 1.5px solid var(--ntl-border);
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  color: #888;
  cursor: pointer;
}
.ntl-btn-primary {
  flex: 2;
  padding: 16px;
  background: var(--ntl-ink);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
}

#ntl-leaflet-map {
  position: relative;
}