/*
 Theme Name:   Kadence Child
 Theme URI:    https://www.kadencewp.com/
 Description:  Child theme for Kadence
 Author:       Will
 Template:     kadence
 Version:      1.0.0
*/



/* LI Run Finder - single race page */
.lirf-wrap { max-width: 1200px; margin: 0 auto; padding: 24px; }


.lirf-hero { position: relative; margin-bottom: 18px; }
.lirf-hero__img {
  height: 260px;
  border-radius: 16px;
  background-size: cover;
  background-position: center;
  position: relative;
}
.lirf-hero__img--empty {
  background: linear-gradient(135deg, rgba(0,0,0,.06), rgba(0,0,0,.02));
}


/* Ensure hero stacking works */
.lirf-hero { position: relative; }

/* The image sits behind */
.lirf-hero__img {
  position: relative;
  z-index: 1;
}

/* Hero card */
.lirf-hero__card {
  margin-left: auto;
  margin-right: auto;
  margin-top: 14px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  padding: 18px 18px 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
  max-width: 1200px;
}


/* Optional: give the image a little breathing room */
.lirf-hero__img{
  margin-bottom: 0 !important;
}


.lirf-title { margin: 0 0 10px; font-size: 34px; line-height: 1.1; }
.lirf-sub__line { margin: 4px 0; }
.lirf-sub__muted { opacity: .75; }
.lirf-dot { margin: 0 8px; opacity: .5; }

.lirf-cta { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.lirf-btn {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.14);
  text-decoration: none;
  font-weight: 700;
}
.lirf-btn--primary {
  background: #1e88e5;
  color: #fff;
  border-color: transparent;
}
.lirf-btn--block { display: block; text-align: center; width: 100%; }

.lirf-byline { margin-top: 10px; opacity: .8; font-size: 14px; }

.lirf-features {
  margin: 18px 0 14px;
  padding: 14px 14px 10px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: rgba(0,0,0,.02);
}
.lirf-features__title { font-weight: 800; margin-bottom: 10px; }
.lirf-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.lirf-chip {
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  font-size: 13px;
  font-weight: 700;
}


/* Grouped Amenities */
.lirf-feature-groups {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

@media (max-width: 980px) {
  .lirf-feature-groups {
    grid-template-columns: 1fr;
  }
}

.lirf-feature-group {
  padding-top: 4px;
}

.lirf-feature-group__title {
  font-weight: 900;
  margin-bottom: 8px;
  opacity: .85;
}



/* Badges under title */
.lirf-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 8px 0 10px;
}
.lirf-badge {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.14);
  background: rgba(255,255,255,.85);
  font-weight: 800;
  font-size: 12.5px;
}



.lirf-grid {
  display: grid;
  grid-template-columns: 1.65fr .95fr;
  gap: 18px;
  margin-top: 14px;
}

@media (max-width: 980px) {
  .lirf-grid { grid-template-columns: 1fr; }
  .lirf-hero__card { margin-top: 12px; }
}


.lirf-section { margin: 0 0 18px; }
.lirf-h2 { font-size: 18px; margin: 0 0 10px; }

.lirf-prose { line-height: 1.6; }
.lirf-kvwrap { display: grid; gap: 10px; }
.lirf-kv { padding: 12px; border: 1px solid rgba(0,0,0,.08); border-radius: 12px; background: #fff; }
.lirf-k { font-weight: 800; margin-bottom: 6px; }
.lirf-v { opacity: .9; }

.lirf-side .lirf-card {
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  background: #fff;
  padding: 14px;
  box-shadow: 0 8px 18px rgba(0,0,0,.05);
}
.lirf-card__title { font-weight: 900; margin-bottom: 10px; }
.lirf-row { display: grid; grid-template-columns: 110px 1fr; gap: 10px; padding: 8px 0; border-top: 1px solid rgba(0,0,0,.06); }
.lirf-row:first-of-type { border-top: 0; }
.lirf-row__k { opacity: .7; font-weight: 700; }
.lirf-row__v { font-weight: 700; }
.lirf-muted { opacity: .75; font-size: 14px; }
.lirf-side__cta { margin-top: 12px; }


.lirf-wrap { padding-top: 10px; }




/* Home: Upcoming races grid */
.lirf-home-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 980px) { .lirf-home-grid { grid-template-columns: 1fr; } }

.lirf-home-card {
  display: block;
  text-decoration: none;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 8px 18px rgba(0,0,0,.06);
  transition: transform .15s ease, box-shadow .15s ease;
}

.lirf-home-card__img {
  height: 150px;
  background-size: cover;
  background-position: center;
}
.lirf-home-card__img--empty {
  background: linear-gradient(135deg, rgba(0,0,0,.06), rgba(0,0,0,.02));
}

.lirf-home-card__body { padding: 12px; }
.lirf-home-card__date { opacity: .75; font-weight: 700; font-size: 13px; margin-bottom: 6px; }
.lirf-home-card__title { font-weight: 900; line-height: 1.2; margin-bottom: 10px; color: inherit; }

.lirf-home-card__badges { display: flex; gap: 8px; flex-wrap: wrap; }
.lirf-home-badge {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  font-weight: 800;
  font-size: 12px;
  background: rgba(255,255,255,.9);
}

.lirf-home-empty { opacity: .75; padding: 10px 0; }





/* Make cards feel clickable + fix no-image state */
.lirf-home-card:hover { transform: translateY(-2px); box-shadow: 0 14px 30px rgba(0,0,0,.10); }

.lirf-home-card__img--empty{
  position: relative;
  background: linear-gradient(135deg, rgba(0,0,0,.08), rgba(0,0,0,.02));
}
.lirf-home-card__img--empty:after{
  content: "🏁";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 34px;
  opacity: .35;
}





/* Races page: sidebar filters */
.lirf-filter { margin-bottom: 18px; }
.lirf-filter__title { font-weight: 900; margin-bottom: 10px; }
.lirf-filter__chips { display: flex; flex-wrap: wrap; gap: 8px; }

.lirf-chip{
  display:inline-flex;
  align-items:center;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.14);
  text-decoration:none;
  font-weight: 800;
  font-size: 13px;
  line-height: 1;
}
.lirf-chip.is-active{
  background: #0b4aa2;
  border-color: #0b4aa2;
  color: #fff;
}
.lirf-chip.is-active:hover{
  filter: brightness(0.95);
}


/* LIRF: checkbox-style filter options (scrolling lists) */
.lirf-filter__options{
	display:flex;
	flex-direction:column;
	gap:4px;

	/* Scroll behavior */
	max-height: 220px;
	overflow-y:auto;
	padding-right:6px;
}

/* Each option row */
.lirf-option{
	display:flex;
	align-items:center;
	gap:6px;

	padding:4px 6px;
	border-radius:10px;
	text-decoration:none;
	color:inherit;
}

.lirf-option:hover{
	background:#f3f4f6;
}

/* Checkbox square */
.lirf-option__box{
	width:18px;
	height:18px;
	border:2px solid #cbd5e1;
	border-radius:4px;
	display:inline-flex;
	align-items:center;
	justify-content:center;
	flex:0 0 18px;
}

/* Active state */
.lirf-option.is-active .lirf-option__box{
	background:#2563eb;
	border-color:#2563eb;
}

.lirf-option.is-active .lirf-option__box::after{
	content:"✓";
	color:#fff;
	font-size:12px;
	line-height:1;
}

/* Optional: tighten long names so they wrap nicely */
.lirf-option__text{
	line-height:1.2;
}


/* Races page: results list (1 column) */
.lirf-results-grid{
  display: grid;
  grid-template-columns: 1fr;   /* <-- force single column */
  gap: 14px;
}

@media (max-width: 980px){ .lirf-results-grid{ grid-template-columns: 1fr; } }

.lirf-results-empty{ padding: 10px 0; opacity: .75; }

.lirf-pagination{ display:flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }
.lirf-page{
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.14);
  text-decoration:none;
  font-weight: 900;
}
.lirf-page.is-active{ background: rgba(0,0,0,.06); }


/* Races page – filter pill styles (matches actual markup) */
.lirf-filter__chips .lirf-chip{
  background: #fff;
  color: #0b4aa2;
  border-color: #d0d7de;
}

.lirf-filter__chips .lirf-chip.is-active{
  background: #0b4aa2;
  color: #fff;
  border-color: #0b4aa2;
}

.lirf-filter__chips .lirf-chip:hover{
  filter: brightness(.96);
}



/* Races page layout tweaks */
.lirf-races-layout {
  gap: 28px;
}

/* Sidebar width */
.lirf-races-layout .lirf-sidebar {
  flex: 0 0 300px;      /* fixed comfortable width */
  max-width: 340px;
}

/* Results take the rest */
.lirf-races-layout .lirf-results {
  flex: 1 1 auto;
  min-width: 0;
}





/* Sidebar mini lists (Other races / Previous years) */
.lirf-mini-list{
  display: grid;
  gap: 10px;
}
.lirf-mini-item{
  display: block;
  padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  text-decoration: none;
  background: rgba(255,255,255,.85);
}
.lirf-mini-item:hover{
  box-shadow: 0 10px 18px rgba(0,0,0,.06);
  transform: translateY(-1px);
}
.lirf-mini-title{
  font-weight: 900;
  line-height: 1.2;
  color: inherit;
}
.lirf-mini-meta{
  margin-top: 4px;
  font-size: 13px;
  opacity: .75;
  font-weight: 700;
}




/* Photo credit overlay */
.lirf-imgwrap { position: relative; overflow: hidden; }
.lirf-imgcredit{
  position: absolute;
  right: 10px;
  bottom: 10px;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  background: rgba(0,0,0,.55);
  padding: 6px 8px;
  border-radius: 10px;
  line-height: 1;
}

/* Gallery grid */
.lirf-gallery{
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 980px){
  .lirf-gallery{ grid-template-columns: 1fr; }
}
.lirf-gallery__item{
  display:block;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 8px 18px rgba(0,0,0,.06);
  text-decoration:none;
}
.lirf-gallery__item img{
  width:100%;
  height:auto;
  display:block;
}


/* Photo credit overlay on hero image */
.lirf-imgwrap { position: relative; }

.lirf-imgcredit{
  position: absolute;
  right: 12px;
  bottom: 10px;
  background: rgba(0,0,0,.55);
  color: #fff;
  padding: 4px 8px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
}




/* Calendar page */
.lirf-cal-wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 18px;
}

.lirf-cal-toolbar{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom: 12px;
}

.lirf-cal-label{ font-weight: 800; }

.lirf-cal-select{
  min-width: 260px;
  padding: 8px;
  border-radius: 10px;
}

.lirf-cal-btn{
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.14);
  background: #1e88e5;
  color: #fff;
  font-weight: 800;
}

.lirf-cal-btn--ghost{
  background: #fff;
  color: #111;
}



.lirf-notes {
  margin: 8px 0 0;
  padding-left: 18px;
}
.lirf-notes li {
  margin: 6px 0;
}

/* Listing In Progress Banner */

.lirf-listing-alert{
	border-left: 10px solid #f0b429;
	background:#fff4da;
	padding:16px 18px;
	margin:18px 0 10px 0;
	border-radius:10px;
	box-shadow:0 6px 14px rgba(0,0,0,.08);
}

.lirf-listing-alert__title{
	font-weight:800;
	font-size:18px;
	margin-bottom:6px;
}

.lirf-listing-alert__text{
	font-size:15px;
	line-height:1.45;
}

.lirf-listing-alert__link{
	margin-top:10px;
	font-weight:600;
}

.lirf-listing-alert__link a{
	color:#1e73be;
	text-decoration:none;
}

.lirf-listing-alert__link a:hover{
	text-decoration:underline;
}



/* Filter header: title + clear button */
.lirf-filter__head,
.lirf-filter__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}

.lirf-filter__clear{
  font-size:13px;
  text-decoration:none;
  border:1px solid #d7dbe3;
  padding:6px 10px;
  border-radius:10px;
  background:#fff;
}

.lirf-filter__clear:hover{
  text-decoration:none;
}

.lirf-filter__clear.is-disabled{
  opacity:.45;
  pointer-events:none;
}

/* Clear all filters button */
.lirf-clearall-wrap{
  margin:0 0 14px 0;
}

.lirf-clearall{
  display:block;
  text-align:center;
  font-weight:600;
  text-decoration:none;
  border:1px solid #d7dbe3;
  padding:10px 12px;
  border-radius:12px;
  background:#fff;
}

.lirf-clearall:hover{
  text-decoration:none;
}

.lirf-clearall.is-disabled{
  opacity:.45;
  pointer-events:none;
}


/* --- Race Logo next to title --- */
.lirf-hero__head {
  display: flex;
  gap: 16px;
  align-items: center;
}

.lirf-race-logo {
  width: 84px;
  height: 84px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  flex: 0 0 auto;
}

.lirf-race-logo img{
  width: 100%;
  height: 100%;
  object-fit: contain;     /* <-- key change: no cropping */
  padding: 8px;            /* gives breathing room */
  background: #fff;        /* nice if logo has transparency */
  display: block;
}

/* --- Race Photos gallery --- */
.lirf-race-gallery {
  margin-top: 28px;
}

.lirf-race-gallery__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 900px) {
  .lirf-race-gallery__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .lirf-race-gallery__grid {
    grid-template-columns: 1fr;
  }
}

.lirf-race-gallery__item {
  margin: 0;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
}

.lirf-race-gallery__item img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

.lirf-race-gallery__credit {
  padding: 8px 10px;
  font-size: 12px;
  opacity: .75;
}

/* =========================
   Filter sidebar: scrollable checkbox-style list
   ========================= */
.lirf-filter__list{
  max-height: 190px;
  overflow: auto;
  padding: 8px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  background: #fff;
}

.lirf-filter__option{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 8px;
  border-radius: 10px;
  text-decoration: none;
  color: inherit;
}

.lirf-filter__option:hover{
  background: rgba(11,74,162,0.06);
}

.lirf-filter__cb{
  width: 16px;
  height: 16px;
  border-radius: 4px;
  border: 1px solid rgba(0,0,0,.25);
  background: #fff;
  flex: 0 0 auto;
}

.lirf-filter__option.is-active .lirf-filter__cb{
  border-color: #0b4aa2;
  background: #0b4aa2;
  box-shadow: inset 0 0 0 3px #fff;
}

.lirf-filter__text{
  font-size: 14px;
  font-weight: 600;
}


/* ==========================================================
   Results header: count + view toggle
   ========================================================== */
.lirf-results-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.lirf-view-toggle {
  display: flex;
  gap: 6px;
}

.lirf-view-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.14);
  background: #fff;
  color: #555;
  text-decoration: none;
  transition: background .15s ease, color .15s ease;
}

.lirf-view-btn:hover {
  background: rgba(0,0,0,.04);
  color: #111;
  text-decoration: none;
}

.lirf-view-btn.is-active {
  background: #0b4aa2;
  border-color: #0b4aa2;
  color: #fff;
}


/* ==========================================================
   Results grids
   ========================================================== */

/* Block view: 2-column image card grid */
.lirf-results-grid--block {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

@media (max-width: 680px) {
  .lirf-results-grid--block {
    grid-template-columns: 1fr;
  }
}

/* List view: stacked compact rows */
.lirf-results-grid--list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}


/* ==========================================================
   Race card – shared base
   ========================================================== */
.lirf-race-card {
  display: block;
  text-decoration: none;
  color: inherit;
  border: 1px solid rgba(0,0,0,.09);
  border-radius: 14px;
  background: #fff;
  overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease;
}

.lirf-race-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(0,0,0,.10);
  text-decoration: none;
}


/* ==========================================================
   Block card image
   ========================================================== */
.lirf-race-card__img {
  height: 160px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.lirf-race-card__img--logo {
  background-size: contain !important;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #fff;
}

.lirf-race-card__img--empty {
  background: linear-gradient(135deg, rgba(0,0,0,.07), rgba(0,0,0,.02));
  position: relative;
}

.lirf-race-card__img--empty::after {
  content: "🏁";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 32px;
  opacity: .28;
}


/* ==========================================================
   Block card body
   ========================================================== */
.lirf-race-card__body {
  padding: 12px 14px 14px;
}

.lirf-race-card__dateline {
  font-size: 13px;
  font-weight: 700;
  opacity: .70;
  margin-bottom: 2px;
}

.lirf-race-card__sep {
  margin: 0 5px;
  opacity: .5;
}

.lirf-race-card__loc {
  font-size: 12px;
  font-weight: 600;
  opacity: .60;
  margin-bottom: 4px;
}

.lirf-race-card__title {
  font-size: 1.05em;
  font-weight: 900;
  line-height: 1.25;
  margin: 4px 0 8px;
  color: inherit;
}

.lirf-race-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

/* Distance chip: blue accent */
.lirf-chip--distance {
  background: rgba(11,74,162,.10);
  border-color: rgba(11,74,162,.30);
  color: #0b4aa2;
  font-weight: 800;
}


/* ==========================================================
   List card layout
   ========================================================== */
.lirf-race-card--list {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 12px;
  align-items: center;
  padding: 10px 14px;
  border-radius: 12px;
}

.lirf-race-card--list .lirf-race-card__meta {
  border-right: 1px solid rgba(0,0,0,.07);
  padding-right: 12px;
}

.lirf-race-card--list .lirf-race-card__dateline {
  font-size: 12px;
  margin-bottom: 2px;
}

.lirf-race-card--list .lirf-race-card__loc {
  font-size: 12px;
  margin-bottom: 0;
}

.lirf-race-card--list .lirf-race-card__main {
  min-width: 0;
}

.lirf-race-card--list .lirf-race-card__title {
  font-size: 1em;
  margin: 0 0 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lirf-race-card--list .lirf-race-card__chips {
  gap: 4px;
}

.lirf-race-card--list .lirf-chip {
  font-size: 11px;
  padding: 4px 8px;
}


/* Mobile: list card stacks vertically */
@media (max-width: 520px) {
  .lirf-race-card--list {
    grid-template-columns: 1fr;
  }

  .lirf-race-card--list .lirf-race-card__meta {
    border-right: none;
    border-bottom: 1px solid rgba(0,0,0,.07);
    padding-right: 0;
    padding-bottom: 6px;
  }
}
