/* MotoLegend Ignition redesign */
:root {
  --bg: #050607;
  --bg-alt: #090b0d;
  --bg-card: #101316;
  --bg-card-hover: #171b1f;
  --accent: #ff7a1a;
  --accent-light: #ffb35c;
  --accent-dark: #b63b12;
  --accent-glow: rgba(255, 122, 26, .28);
  --steel: #5b7f93;
  --steel-light: #9ec8d9;
  --text: #f4f0e8;
  --text-secondary: #b9afa3;
  --text-muted: #776c62;
  --border: rgba(255, 122, 26, .16);
  --border-hover: rgba(255, 179, 92, .42);
}

body {
  background:
    radial-gradient(circle at 80% 0%, rgba(91, 127, 147, .16), transparent 28rem),
    radial-gradient(circle at 12% 18%, rgba(255, 122, 26, .11), transparent 22rem),
    linear-gradient(180deg, #030405 0%, #0a0b0d 42%, #050607 100%);
  color: var(--text);
}

.grid-bg {
  background-image:
    linear-gradient(rgba(255, 122, 26, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(91, 127, 147, .04) 1px, transparent 1px);
  background-size: 82px 82px;
  mask-image: linear-gradient(to bottom, #000, transparent 76%);
}

.grain-overlay {
  opacity: .06;
  mix-blend-mode: soft-light;
}

.site-nav {
  background: rgba(5, 6, 7, .78);
  border-bottom: 1px solid rgba(255, 122, 26, .18);
  box-shadow: 0 18px 70px rgba(0, 0, 0, .35);
  backdrop-filter: blur(18px) saturate(1.3);
}

.nav-inner {
  height: 64px;
}

.nav-logo {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  color: var(--text);
  font-size: 1.35rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.nav-logo::before {
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 22px var(--accent);
}

.nav-link {
  border: 1px solid transparent;
  border-radius: 10px;
  color: #b7aea4;
}

.nav-link:hover,
.nav-link.active {
  color: var(--accent-light);
  border-color: rgba(255, 122, 26, .22);
  background: rgba(255, 122, 26, .09);
}

.auth-bar .auth-btn,
.auth-bar .auth-logout,
.nav-auth .auth-btn,
.nav-auth .auth-logout {
  border-radius: 10px;
  background: rgba(16, 19, 22, .7);
  border-color: rgba(255, 122, 26, .18);
}

.hero {
  min-height: 100svh;
  justify-content: flex-start;
  text-align: left;
  padding: 0;
  isolation: isolate;
  background: #030405;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(90deg, rgba(3, 4, 5, .96) 0%, rgba(3, 4, 5, .76) 38%, rgba(3, 4, 5, .22) 70%, rgba(3, 4, 5, .62) 100%),
    linear-gradient(180deg, rgba(3, 4, 5, .08), #050607 94%),
    url("/assets/hero-ignition.webp") center / cover no-repeat;
  transform: scale(1.02);
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255, 122, 26, .09) 1px, transparent 1px),
    linear-gradient(rgba(158, 200, 217, .06) 1px, transparent 1px);
  background-size: 86px 86px;
  mask-image: linear-gradient(to bottom, transparent 0%, #000 18%, #000 78%, transparent 100%);
}

.hero-bg {
  z-index: 2;
  mix-blend-mode: screen;
}

.orb {
  filter: blur(95px);
}

.orb-1 {
  background: radial-gradient(circle, rgba(255, 122, 26, .72), transparent 68%);
  left: 2%;
  top: 18%;
  opacity: .22;
}

.orb-2 {
  background: radial-gradient(circle, rgba(91, 127, 147, .60), transparent 68%);
  right: 5%;
  bottom: 2%;
  opacity: .18;
}

.orb-3 {
  background: radial-gradient(circle, rgba(255, 179, 92, .54), transparent 70%);
  right: 42%;
  top: 62%;
  opacity: .12;
}

.hero-content {
  position: absolute;
  left: 0;
  bottom: clamp(5.2rem, 11vh, 8rem);
  z-index: 3;
  width: min(980px, 100%);
  padding: 0 clamp(1.25rem, 6vw, 6rem);
  margin: 0;
}

.hero-date {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  margin-bottom: 1.15rem;
  padding: .5rem .72rem;
  border: 1px solid rgba(255, 122, 26, .24);
  border-radius: 10px;
  background: rgba(16, 19, 22, .54);
  backdrop-filter: blur(14px);
  color: var(--accent-light);
  font-size: .72rem;
  letter-spacing: .22em;
}

.hero-date::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 16px var(--accent);
}

.hero-title {
  max-width: 930px;
  font-size: clamp(3.7rem, 10vw, 9.6rem);
  line-height: .82;
  letter-spacing: .01em;
  text-shadow: 0 22px 70px rgba(0, 0, 0, .62);
}

.hero-title .gradient-text {
  background: linear-gradient(100deg, #fff2df 0%, #ffb35c 36%, #ff6a18 70%, #8fd3ea 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.hero-subtitle {
  max-width: 660px;
  margin: 1.15rem 0 1.45rem;
  color: #ddd4ca;
  font-size: clamp(1rem, 2vw, 1.28rem);
  line-height: 1.55;
  text-shadow: 0 2px 24px rgba(0, 0, 0, .92);
}

.hero-line {
  width: min(460px, 52vw);
  height: 2px;
  margin: 0;
  background: linear-gradient(90deg, var(--accent), var(--accent-light), transparent);
  box-shadow: 0 0 20px rgba(255, 122, 26, .45);
}

.scroll-indicator {
  left: auto;
  right: clamp(1.25rem, 5vw, 5rem);
  bottom: 2.2rem;
  z-index: 4;
  transform: none;
}

.scroll-text {
  color: var(--accent-light);
}

.stats {
  background: linear-gradient(180deg, #090b0d, #060708);
  border-color: rgba(255, 122, 26, .18);
  box-shadow: 0 -24px 80px rgba(0, 0, 0, .35);
}

.stats-grid {
  gap: 14px;
}

.stat-item {
  background: linear-gradient(180deg, rgba(255, 255, 255, .055), rgba(255, 255, 255, .018));
  border: 1px solid rgba(255, 122, 26, .14);
  border-radius: 14px;
  box-shadow: 0 18px 45px rgba(0, 0, 0, .18);
}

.stat-value {
  color: var(--accent-light);
  text-shadow: 0 0 24px rgba(255, 122, 26, .22);
}

.section-label {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  padding: .45rem .7rem;
  border: 1px solid rgba(255, 122, 26, .18);
  border-radius: 999px;
  background: rgba(255, 122, 26, .08);
  color: var(--accent-light);
}

.section-label::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 14px var(--accent);
}

.section-title {
  font-size: clamp(2.7rem, 7vw, 5.4rem);
  text-shadow: 0 16px 50px rgba(0, 0, 0, .36);
}

.section-subtitle {
  color: #bdb3a9;
  font-size: 1.08rem;
}

.timeline-section,
.fifty-section,
.charts-section,
.comments-section {
  background: radial-gradient(circle at top right, rgba(91, 127, 147, .08), transparent 28rem);
}

.timeline-line {
  width: 3px;
  background: linear-gradient(to bottom, transparent, var(--accent-light) 7%, var(--steel-light) 48%, var(--accent) 92%, transparent);
  box-shadow: 0 0 26px rgba(255, 122, 26, .22);
}

.timeline-dot {
  background: var(--accent-light);
  border-color: #060708;
  box-shadow: 0 0 0 7px rgba(255, 122, 26, .08), 0 0 28px rgba(255, 122, 26, .62);
}

.era-card,
.gallery-card,
.fifty-card,
.fact-card,
.donate-box,
.faq-card,
.discussion-panel,
.forum-topics,
.community-stat-card,
.community-panel-card,
.topic-suggestion-card,
.spec-modal {
  background: linear-gradient(180deg, rgba(22, 26, 30, .88), rgba(10, 12, 14, .82));
  border: 1px solid rgba(255, 122, 26, .15);
  border-radius: 10px;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .28), inset 0 1px rgba(255, 255, 255, .05);
  backdrop-filter: blur(12px);
}

.era-card:hover,
.gallery-card:hover,
.fifty-card:hover,
.fact-card:hover,
.topic-suggestion-card:hover {
  border-color: rgba(255, 179, 92, .42);
  box-shadow: 0 32px 80px rgba(0, 0, 0, .38), 0 0 44px rgba(255, 122, 26, .10);
  transform: translateY(-8px);
}

.era-img-wrapper,
.gallery-img-wrapper,
.fifty-img-wrapper {
  background: linear-gradient(135deg, #24130a, #070809);
}

.era-img-wrapper img,
.gallery-img-wrapper img,
.fifty-img-wrapper img {
  filter: brightness(.86) saturate(1.06) contrast(1.04);
}

.era-card:hover img,
.gallery-card:hover img,
.fifty-card:hover img {
  filter: brightness(1.04) saturate(1.12) contrast(1.05);
}

.era-content,
.gallery-info,
.fifty-info {
  position: relative;
}

.era-content::before,
.gallery-info::before,
.fifty-info::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), var(--steel-light), transparent);
  opacity: .5;
}

.era-meta,
.gallery-year,
.fifty-decade,
.chart-title,
.discussion-kicker,
.thread-hero-kicker {
  color: var(--accent-light);
}

.era-title,
.gallery-name,
.fifty-name,
.faq-question,
.donate-title,
.forum-atmosphere-title,
.thread-hero-title {
  color: #fff6ec;
}

.era-specs,
.spec-grid {
  background: rgba(255, 122, 26, .18);
}

.spec-item,
.spec-grid-item {
  background: rgba(5, 6, 7, .82);
}

.era-tag,
.spec-tag,
.fifty-type,
.forum-pill,
.forum-ribbon-chip.accent {
  background: rgba(255, 122, 26, .10);
  border-color: rgba(255, 122, 26, .22);
  color: var(--accent-light);
}

.gallery-section,
.facts-section,
.donate-section {
  background: linear-gradient(180deg, #090b0d, #060708);
  border-top: 1px solid rgba(255, 122, 26, .16);
}

.gallery-scroll {
  padding-top: 8px;
}

.section-essentials {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  max-width: 760px;
  margin: 22px auto 0;
}

.section-essentials span,
.section-essentials strong {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 122, 26, .18);
  background: linear-gradient(180deg, rgba(255, 122, 26, .12), rgba(255, 255, 255, .03));
  color: var(--text);
  font-family: var(--font-mono);
  font-size: .68rem;
  font-weight: 500;
  letter-spacing: .7px;
  text-transform: uppercase;
}

.section-essentials span {
  color: var(--accent-light);
  border-color: rgba(255, 179, 92, .38);
  box-shadow: 0 0 24px rgba(255, 122, 26, .08);
}

.gallery-card {
  min-width: 310px;
  max-width: 310px;
}

.gallery-img-wrapper {
  height: 220px;
}

.fifty-timeline {
  gap: 18px;
}

.fifty-spotlight {
  display: grid;
  grid-template-columns: minmax(0, 1.22fr) minmax(260px, .78fr);
  gap: 18px;
  margin: -18px 0 28px;
}

.fifty-spotlight-card {
  min-height: 100%;
  border-color: rgba(255, 179, 92, .24);
  background:
    radial-gradient(circle at top right, rgba(255, 122, 26, .16), transparent 34%),
    linear-gradient(180deg, rgba(26, 30, 34, .92), rgba(9, 10, 12, .86));
}

.fifty-spotlight-main {
  grid-row: span 2;
}

.fifty-spotlight-main .fifty-img-wrapper {
  height: 360px;
}

.fifty-spotlight-card:not(.fifty-spotlight-main) {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr);
}

.fifty-spotlight-card:not(.fifty-spotlight-main) .fifty-img-wrapper {
  height: 100%;
  min-height: 220px;
}

.fifty-spotlight-card:not(.fifty-spotlight-main) .fifty-info {
  padding: 20px;
}

.fifty-spotlight-card:not(.fifty-spotlight-main) .fifty-name {
  font-size: 1.45rem;
}

.fifty-impact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 18px 0 2px;
}

.fifty-impact-grid span {
  min-width: 0;
  padding: 12px 10px;
  border: 1px solid rgba(255, 122, 26, .16);
  border-radius: 8px;
  background: rgba(255, 255, 255, .04);
  color: var(--text-secondary);
  font-size: .74rem;
  line-height: 1.25;
}

.fifty-impact-grid strong {
  display: block;
  color: var(--accent-light);
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1;
}

.fifty-quick-map {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 32px;
}

.fifty-quick-map span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 9px 10px;
  border: 1px solid rgba(255, 122, 26, .14);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .05), rgba(255, 255, 255, .02));
  color: var(--text-secondary);
  font-family: var(--font-mono);
  font-size: .65rem;
  letter-spacing: .6px;
  line-height: 1.35;
  text-align: center;
  text-transform: uppercase;
}

.chart-bars {
  padding: 22px;
  border: 1px solid rgba(255, 122, 26, .12);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(16, 19, 22, .68), rgba(7, 8, 10, .55));
}

.bar-track {
  background: rgba(255, 122, 26, .09);
}

.bar-fill {
  background: linear-gradient(90deg, #80220d, #ff6a18, #ffb35c);
  box-shadow: 0 0 22px rgba(255, 122, 26, .22);
}

.chart-speed .bar-fill {
  background: linear-gradient(90deg, #29485b, #5b7f93, #9ec8d9);
}

.fact-icon {
  filter: drop-shadow(0 0 14px rgba(255, 122, 26, .34));
}

.donate-btn {
  border-radius: 10px;
}

.modal-box,
.comment-textarea,
.comment-card,
.comment-login-prompt {
  background: linear-gradient(180deg, rgba(22, 26, 30, .94), rgba(10, 12, 14, .9));
  border-color: rgba(255, 122, 26, .16);
  border-radius: 10px;
}

.modal-input {
  background: #060708;
  border-color: rgba(255, 122, 26, .16);
  border-radius: 10px;
}

.modal-input:focus {
  border-color: var(--accent-light);
  box-shadow: 0 0 0 3px rgba(255, 122, 26, .10);
}

.modal-submit,
.comment-send {
  border-radius: 10px;
  background: linear-gradient(135deg, var(--accent), var(--accent-light));
  color: #170905;
  font-weight: 700;
}

.site-footer {
  background: #030405;
  border-top: 1px solid rgba(255, 122, 26, .16);
}

.footer-title {
  color: #fff6ec;
}

.garage-launch {
  position: fixed;
  left: 20px;
  bottom: 20px;
  z-index: 9994;
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  min-height: 42px;
  padding: 0 .9rem;
  border: 1px solid rgba(255, 122, 26, .28);
  border-radius: 10px;
  background: rgba(5, 6, 7, .78);
  color: var(--accent-light);
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 18px 45px rgba(0, 0, 0, .34), 0 0 26px rgba(255, 122, 26, .08);
  backdrop-filter: blur(14px);
}

.garage-launch::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 18px var(--accent);
}

.garage-launch:hover {
  color: #fff6ec;
  border-color: rgba(255, 179, 92, .52);
  background: rgba(22, 26, 30, .88);
}

.garage-overlay {
  position: fixed;
  inset: 0;
  z-index: 10003;
  box-sizing: border-box;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  overflow: hidden;
  background: rgba(0, 0, 0, .76);
  backdrop-filter: blur(14px);
}

.garage-overlay.open {
  display: flex;
}

.garage-panel {
  width: min(980px, 100%);
  max-width: calc(100vw - 48px);
  max-height: min(780px, 90vh);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255, 122, 26, .20);
  border-radius: 12px;
  background:
    radial-gradient(circle at top right, rgba(255, 122, 26, .13), transparent 26rem),
    radial-gradient(circle at bottom left, rgba(91, 127, 147, .12), transparent 24rem),
    linear-gradient(180deg, rgba(18, 21, 24, .98), rgba(5, 6, 7, .96));
  box-shadow: 0 32px 120px rgba(0, 0, 0, .6), inset 0 1px rgba(255, 255, 255, .06);
}

.garage-head {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding: 26px 28px 18px;
  border-bottom: 1px solid rgba(255, 122, 26, .14);
}

.garage-kicker {
  margin-bottom: 8px;
  color: var(--accent-light);
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .22em;
  text-transform: uppercase;
}

.garage-head h2 {
  color: #fff6ec;
  font-size: clamp(2rem, 5vw, 3.4rem);
}

.garage-close {
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255, 122, 26, .22);
  border-radius: 10px;
  background: rgba(5, 6, 7, .58);
  color: var(--text-secondary);
  font-size: 1.5rem;
  cursor: pointer;
}

.garage-close:hover {
  color: var(--accent-light);
  border-color: rgba(255, 179, 92, .45);
}

.garage-search-row {
  padding: 18px 28px 0;
}

.garage-search-input {
  width: 100%;
  padding: 15px 16px;
  border: 1px solid rgba(255, 122, 26, .18);
  border-radius: 10px;
  outline: none;
  background: rgba(5, 6, 7, .72);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 1rem;
}

.garage-search-input:focus {
  border-color: var(--accent-light);
  box-shadow: 0 0 0 3px rgba(255, 122, 26, .10);
}

.garage-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 14px 28px 0;
}

.garage-filters button {
  padding: 8px 12px;
  border: 1px solid rgba(255, 122, 26, .16);
  border-radius: 999px;
  background: rgba(255, 255, 255, .04);
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: .66rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
}

.garage-filters button.active,
.garage-filters button:hover {
  color: var(--accent-light);
  border-color: rgba(255, 122, 26, .34);
  background: rgba(255, 122, 26, .10);
}

.garage-meta {
  padding: 14px 28px 8px;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.garage-results {
  overflow: auto;
  padding: 0 28px 28px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 12px;
}

.garage-result {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-height: 92px;
  padding: 10px;
  border: 1px solid rgba(255, 122, 26, .14);
  border-radius: 10px;
  background: rgba(255, 255, 255, .035);
  color: inherit;
  cursor: pointer;
  text-align: left;
}

.garage-result:hover {
  border-color: rgba(255, 179, 92, .42);
  background: rgba(255, 122, 26, .08);
}

.garage-result img,
.garage-result-thumb {
  width: 74px;
  height: 72px;
  object-fit: cover;
  border-radius: 8px;
  background: linear-gradient(135deg, #24130a, #070809);
}

.garage-result-title {
  color: #fff6ec;
  font-family: var(--font-display);
  font-size: 1.25rem;
  line-height: 1;
}

.garage-result-meta {
  margin-top: 4px;
  color: var(--accent-light);
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.garage-result-desc {
  margin-top: 6px;
  color: var(--text-muted);
  font-size: .78rem;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.garage-empty {
  grid-column: 1 / -1;
  padding: 34px 18px;
  border: 1px dashed rgba(255, 122, 26, .18);
  border-radius: 10px;
  color: var(--text-muted);
  text-align: center;
}

@media (max-width: 768px) {
  .hero {
    min-height: 92svh;
  }

  .hero::before {
    background:
      linear-gradient(180deg, rgba(3, 4, 5, .30), rgba(3, 4, 5, .95) 62%, #050607 100%),
      url("/assets/hero-ignition.webp") 60% center / cover no-repeat;
  }

  .hero-content {
    bottom: 4.6rem;
    padding: 0 1.2rem;
  }

  .hero-title {
    font-size: clamp(3rem, 15vw, 5rem);
  }

  .hero-subtitle {
    max-width: 34rem;
    font-size: 1rem;
  }

  .hero-line {
    width: 72vw;
  }

  .scroll-indicator {
    right: 1.2rem;
  }

  .gallery-card {
    min-width: 270px;
    max-width: 270px;
  }

  .fifty-spotlight {
    grid-template-columns: 1fr;
  }

  .fifty-spotlight-main {
    grid-row: auto;
  }

  .fifty-spotlight-main .fifty-img-wrapper {
    height: 260px;
  }

  .fifty-spotlight-card:not(.fifty-spotlight-main) {
    grid-template-columns: 1fr;
  }

  .fifty-spotlight-card:not(.fifty-spotlight-main) .fifty-img-wrapper {
    height: 210px;
    min-height: 0;
  }

  .fifty-quick-map {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .nav-inner {
    height: 54px;
  }

  .garage-launch {
    left: 12px;
    bottom: 12px;
  }

  .garage-overlay {
    padding: 10px;
  }

  .garage-panel {
    max-width: calc(100vw - 20px);
    max-height: 92vh;
  }

  .garage-head,
  .garage-search-row,
  .garage-filters,
  .garage-meta {
    padding-left: 16px;
    padding-right: 16px;
  }

  .garage-results {
    grid-template-columns: 1fr;
    padding: 0 16px 16px;
  }
}

@media (max-width: 480px) {
  .hero::before {
    background-position: 66% center;
  }

  .hero-date {
    font-size: .62rem;
    letter-spacing: .14em;
  }

  .hero-title {
    font-size: 3.05rem;
  }

  .stats-grid {
    grid-template-columns: 1fr;
  }

  .section-title {
    font-size: 2.5rem;
  }

  .chart-bars {
    padding: 14px;
  }

  .fifty-impact-grid,
  .fifty-quick-map {
    grid-template-columns: 1fr;
  }

  .fifty-spotlight-main .fifty-img-wrapper,
  .fifty-spotlight-card:not(.fifty-spotlight-main) .fifty-img-wrapper {
    height: 180px;
  }

  .bar-track {
    position: relative;
  }

  .bar-value {
    position: absolute;
    left: 18px;
    top: 50%;
    max-width: calc(100% - 26px);
    overflow: hidden;
    text-align: left;
    text-overflow: ellipsis;
    transform: translateY(-50%);
  }

  .gallery-card {
    min-width: 240px;
    max-width: 240px;
  }
}
