@charset "UTF-8";

:root {
  --ff-bg: #161616;
  --ff-bg-elevated: #1b1b1b;
  --ff-surface: #111111;
  --ff-text: #c8c8c8;
  --ff-text-strong: #ffffff;
  --ff-text-soft: #9e9e9e;
  --ff-accent: #f02200;
  --ff-accent-soft: rgba(240, 34, 0, 0.56);
  --ff-accent-stroke: #a10000;
  --ff-fire-orange: #ff6a00;
  --ff-fire-glow: rgba(255, 64, 22, 0.9);
  --ff-fire-glow-soft: rgba(255, 106, 0, 0.45);
  --ff-text-shadow-core: rgba(86, 0, 0, 0.58);
  --ff-text-shadow-soft: rgba(166, 30, 30, 0.28);
  --ff-text-glow-red: rgba(220, 54, 54, 0.42);
  --ff-text-glow-red-strong: rgba(255, 86, 86, 0.62);
  --ff-text-glow-blue: rgba(88, 132, 255, 0.5);
  --ff-shadow-card: 0 10px 22px rgba(0, 0, 0, 0.55);
  --ff-shadow-nav: 0 14px 30px rgba(0, 0, 0, 0.62);
  --ff-toolbar-red: rgba(138, 0, 0, 0.95);
  --ff-toolbar-red-strong: rgba(208, 22, 0, 0.96);
  --ff-toolbar-red-soft: rgba(162, 0, 0, 0.7);
  --ff-panel-bg: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.015));
  --ff-panel-border: rgba(255, 255, 255, 0.1);
  --ff-panel-glow: 0 14px 30px rgba(0, 0, 0, 0.56);
  --ff-wrapper-max: 1240px;
  --ff-wrapper-gutter: clamp(1rem, 3vw, 2.5rem);
  --ff-section-padding-y: clamp(3rem, 6vw, 5rem);
  --ff-card-ratio: 16 / 10;
}

/* ------------------------------------GLOBAL PARAMETERS--------------------------------- */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  /* font-weight: 300; */
  font-family: "Poppins", sans-serif;
  overflow-x: hidden;
  color: var(--ff-text);
  margin: 0;
  background:
    radial-gradient(960px 340px at 8% -6%, rgba(190, 26, 26, 0.18), transparent 62%),
    radial-gradient(880px 320px at 90% -8%, rgba(38, 102, 230, 0.12), transparent 64%),
    var(--ff-bg-elevated);
  line-height: 1.5;
}

/* Zentrierter Wrapper */
.width-wrapper {
  width: min(100%, var(--ff-wrapper-max));
  margin: 0 auto;
  padding-inline: var(--ff-wrapper-gutter);
}

@media screen and (max-width: 500px) {
  .width-wrapper {
    padding-inline: 1rem;
  }
}

/* ------------------------------------NAVBAR--------------------------------- */

.navbar {
  padding: 0.38rem 0.75rem;
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

#mainNav {
  border-bottom: 1px solid rgba(255, 168, 168, 0.34);
}

.navbar.bg-transparent {
  background: linear-gradient(90deg, rgba(132, 16, 22, 0.96) 0%, rgba(182, 29, 35, 0.96) 55%, rgba(206, 38, 43, 0.96) 100%) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(5px);
}

.ff-topbar-inner {
  align-items: center;
  gap: 0.75rem;
}

.navbar-brand {
  color: var(--ff-text-strong) !important;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 1px;
  margin-right: 1rem;
  transition: color 0.2s;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.74), 0 0 10px var(--ff-text-glow-red);
}

.ff-brand {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  min-width: 250px;
  text-decoration: none;
}

.ff-brand-logo {
  width: 38px;
  height: 38px;
  object-fit: contain;
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.45));
}

.ff-brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.02;
  text-transform: uppercase;
}

.ff-brand-text small {
  font-size: 0.56rem;
  font-weight: 600;
  letter-spacing: 0.13em;
  color: rgba(255, 232, 232, 0.95);
}

.ff-brand-text strong {
  font-size: 1.08rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: #ffffff;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.58);
}

.bg-dark {
  background: linear-gradient(90deg, rgba(132, 16, 22, 0.98) 0%, rgba(182, 29, 35, 0.98) 55%, rgba(206, 38, 43, 0.98) 100%) !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.5);
}

.navbar-brand:hover {
  color: var(--ff-accent) !important;
}

.ff-nav-toggler {
  border-color: rgba(255, 255, 255, 0.45);
}

.ff-nav-toggler:focus {
  box-shadow: 0 0 0 0.18rem rgba(255, 220, 220, 0.2);
}

/* Navbar-Links */
.navbar-dark .navbar-nav .nav-link {
  color: rgba(255, 246, 246, 0.96) !important;
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 0.2rem;
  padding: 0.48rem 0.92rem;
  border-radius: 999px;
  transition: color 0.2s, background-color 0.2s, box-shadow 0.2s;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.48);
}

.navbar-dark .navbar-nav .nav-link:hover {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.14);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.2);
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.25);
}

.navbar-dark .navbar-nav .nav-link.active,
.navbar-dark .navbar-nav .nav-link[aria-current="page"] {
  color: #ffffff !important;
  position: relative;
  background: rgba(255, 255, 255, 0.22);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.3), 0 6px 14px rgba(75, 0, 0, 0.38);
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.32);
}

.navbar-dark .navbar-nav .nav-link.active::after,
.navbar-dark .navbar-nav .nav-link[aria-current="page"]::after {
  display: none;
}

.ff-nav-list {
  gap: 0.2rem;
}

@media screen and (max-width: 991px) {
  .navbar {
    padding: 0.45rem 0.6rem;
  }

  .ff-brand {
    min-width: 0;
    margin-right: 0.5rem;
  }

  .ff-brand-logo {
    width: 34px;
    height: 34px;
  }

  .ff-brand-text small {
    display: none;
  }

  .ff-brand-text strong {
    font-size: 0.92rem;
    letter-spacing: 0.06em;
  }

  .ff-nav-list {
    padding-top: 0.6rem;
  }

  .navbar-dark .navbar-nav .nav-link {
    display: inline-block;
    margin-bottom: 0.35rem;
  }
}

/* ------------------------------------FRONT PAGE / HERO--------------------------------- */
.front-page {
  min-height: 100vh;
  width: 100%;
  background:
    linear-gradient(90deg, rgba(120, 16, 24, 0.26) 0%, rgba(0, 0, 0, 0.58) 42%, rgba(18, 56, 130, 0.26) 100%),
    radial-gradient(rgba(0, 0, 0, 0.84), rgba(0, 0, 0, 0.66)),
    url("../img/bg-1.jpg") no-repeat center center;
  background-size: cover;
  position: relative;
}

#hero-logo-container {
  width: 100%;
  padding-inline: var(--ff-wrapper-gutter);
  overflow: visible;
}

#hero-logo-container #logo {
  width: min(70vw, 860px);
  filter: none;
  overflow: visible;
}

.hero-scroll-link {
  bottom: 5%;
}

/* Wolke */
/* .front-page img {
  height: 100vh;
  transform: translate(30%, -30%);
  opacity: 0.3;
  animation: cloudAnimation 15s infinite alternate ease-in-out;
}
@keyframes cloudAnimation {
  0% {
    transform: translate(30%, -30%);
  }
  100% {
    transform: translate(10%, -10%);
  }
} */

/* Pfeil nach unten */
#down-arrow {
  animation: arrowAnimation 2s infinite alternate ease-in-out;
}
@keyframes arrowAnimation {
  0% {
    transform: translate(-50%, -120%);
  }
  100% {
    transform: translate(-50%, -50%);
  }
}

/* SVG-Text-Klassen */
.cls-1 {
  font-size: 120px;
  fill: rgba(60, 0, 0, 0.22);
  stroke: #ff0f2a;
  stroke-width: 2.8;
  paint-order: stroke fill;
  font-family: Arial Black, sans-serif;
  font-style: italic;
  font-weight: 800;
  filter: drop-shadow(0 0 8px rgba(255, 14, 42, 0.95))
    drop-shadow(0 0 22px rgba(255, 14, 42, 0.86))
    drop-shadow(0 0 38px rgba(190, 0, 26, 0.72))
    drop-shadow(0 0 58px rgba(104, 0, 18, 0.46));
}
.cls-2 {
  font-size: 24px;
  fill: rgba(255, 255, 255, 0.92);
  stroke: rgba(255, 255, 255, 0.18);
  stroke-width: 0.4;
  font-family: Arial Black, sans-serif;
  font-weight: 800;
  filter: drop-shadow(0 0 7px rgba(255, 255, 255, 0.9))
    drop-shadow(0 0 16px rgba(255, 42, 42, 0.52));
}
.cls-3 {
  letter-spacing: -0.03em;
}
.cls-4 {
  letter-spacing: -0.02em;
}
.cls-5 {
  font-size: 48px;
  fill: rgba(0, 56, 212, 0.22);
  stroke: rgba(20, 102, 255, 0.98);
  stroke-width: 1.9;
  paint-order: stroke fill;
  font-family: Arial Black, sans-serif;
  font-weight: 800;
  filter: drop-shadow(0 0 7px rgba(42, 120, 255, 0.96))
    drop-shadow(0 0 18px rgba(42, 120, 255, 0.8))
    drop-shadow(0 0 34px rgba(18, 84, 230, 0.6))
    drop-shadow(0 0 52px rgba(8, 52, 162, 0.38));
}

.hero-emergency-btn {
  right: clamp(1rem, 2.4vw, 2.2rem);
  bottom: clamp(1rem, 2.4vw, 2rem);
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  border-radius: 999px;
  padding: 0.68rem 1.2rem;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 0.78rem;
  font-weight: 800;
  color: #ffffff;
  background: linear-gradient(90deg, rgba(168, 8, 26, 0.96), rgba(236, 30, 46, 0.96));
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.48), 0 0 12px rgba(255, 20, 20, 0.42);
  border: 1px solid rgba(255, 174, 174, 0.44);
}

.hero-emergency-btn svg {
  width: 14px;
  height: 14px;
}

.hero-emergency-btn:hover {
  color: #ffffff;
  transform: translateY(-1px);
}

@media screen and (max-width: 991px) {
  .front-page {
    min-height: 92vh;
    background-position: 58% center;
  }

  #hero-logo-container #logo {
    width: min(88vw, 700px);
    overflow: visible;
  }

  .hero-scroll-link {
    bottom: 2.75rem;
  }
}

@media screen and (max-width: 575px) {
  #hero-logo-container {
    padding-inline: 0.75rem;
  }

  #hero-logo-container #logo {
    width: min(94vw, 520px);
    overflow: visible;
  }

  .hero-scroll-link {
    bottom: 2rem;
  }

  #down-arrow {
    width: 64px;
    height: auto;
  }
}

/* ------------------------------------CONTENT--------------------------------- */
.content {
  background:
    radial-gradient(980px 360px at 10% -6%, rgba(205, 28, 28, 0.16), transparent 58%),
    radial-gradient(860px 320px at 92% -8%, rgba(28, 94, 225, 0.12), transparent 62%),
    linear-gradient(180deg, #1a1a1a 0%, #161616 100%);
  padding-top: var(--ff-section-padding-y);
  padding-bottom: var(--ff-section-padding-y);
  width: 100%;
  /* min-height: 100vh; */
  height: auto;
  position: relative;
  overflow: hidden;
}

.content::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
  background-size: 28px 28px;
  opacity: 0.08;
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent 55%);
}

.content-section,
.events {
  background: var(--ff-panel-bg);
  border: 1px solid var(--ff-panel-border);
  box-shadow: var(--ff-panel-glow);
  padding: clamp(1rem, 2.2vw, 1.75rem);
  margin-bottom: clamp(1.25rem, 2.8vw, 2rem);
  position: relative;
  z-index: 1;
}

.content-section::before,
.events::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 2px;
  background: linear-gradient(90deg, rgba(255, 70, 70, 0.9), rgba(255, 70, 70, 0.28) 45%, rgba(70, 128, 255, 0.55));
}

.content-section:last-child,
.events:last-child {
  margin-bottom: 0;
}

.main-header {
  padding: 0 0 1.35rem;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  justify-content: flex-start;
  flex-wrap: wrap;
}

.main-header h3 {
  margin: 0;
  font-size: clamp(1.55rem, 2.5vw, 2rem);
  color: var(--ff-text-strong);
  letter-spacing: 0.02em;
  text-shadow: 0 3px 10px rgba(0, 0, 0, 0.78), 0 0 12px var(--ff-text-glow-red);
}

.main-header svg {
  height: 1.5rem;
  margin: 0;
  min-width: 120px;
}

.section-divider {
  flex: 1;
  max-width: 300px;
  filter: none;
  animation: none;
}

.section-divider line {
  stroke: #ff4a32 !important;
  stroke-width: 1.2;
  stroke-linecap: round;
  stroke-opacity: 0.92;
}

/* ------------------------------------NEWS SECTION--------------------------------- */

/* Bootstrap-Cards statt n-box */
.card {
  background: linear-gradient(180deg, rgba(20, 20, 20, 0.95), rgba(14, 14, 14, 0.98));
  box-shadow: var(--ff-shadow-card);
  border: 1px solid var(--ff-panel-border);
  transition: all 0.2s ease-in-out;
  border-radius: 0;
}

.card-body {
  padding: 1rem 1rem 0.85rem;
}

.card-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.01);
}

.card-img-top {
  width: 100%;
  aspect-ratio: var(--ff-card-ratio);
  height: auto;
  object-fit: cover;
  border-radius: 0;
}

/* ------------------------------------NEWS MODAL--------------------------------- */
.news-modal-img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

@media screen and (min-width: 768px) {
  .news-modal-img {
    width: 30%;
    flex-shrink: 0;
    align-self: flex-start;
  }
}

/* ------------------------------------VEHICLE CARDS--------------------------------- */
.vehicle-card,
.news-card {
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.vehicle-card:hover,
.vehicle-card:focus-visible,
.news-card:hover,
.news-card:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.6);
  outline: 2px solid var(--ff-accent);
  outline-offset: 2px;
}

.vehicle-modal-content {
  background-color: var(--ff-bg-elevated);
  border: none;
  border-radius: 0;
}

.vehicle-modal-header {
  background-color: var(--ff-surface);
  border-bottom: 1px solid #333;
  color: var(--ff-text);
}

.vehicle-modal-header .modal-title {
  color: var(--ff-text);
}

.card-text,
.card-title,
.card-footer a,
.card-footer small {
  color: var(--ff-text) !important;
}

.card-footer a:hover {
  color: var(--ff-accent);
}

.card-title,
.event-info h4,
.contact-title,
.contact-value,
.read-more h5 a,
.team-subheader h3 {
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.74), 0 0 9px var(--ff-text-shadow-soft);
}

.read-more {
  padding: 2.25rem 0 0.25rem;
  display: flex;
  justify-content: flex-end;
}

.read-more h5 {
  margin: 0 3rem 0 0;
}

.read-more h5 svg:hover {
  width: 180px;
}

.read-more h5 a {
  color: var(--ff-text);
  transition: color 0.2s;
  text-decoration-line: none;
}

.read-more h5 a:hover {
  color: var(--ff-accent);
}

/* ------------------------------------PAGINATION--------------------------------- */
.pagination {
  --bs-pagination-bg: rgba(20, 20, 20, 0.95);
  --bs-pagination-border-color: var(--ff-panel-border);
  --bs-pagination-color: var(--ff-text);
  --bs-pagination-hover-bg: rgba(255, 255, 255, 0.08);
  --bs-pagination-hover-border-color: var(--ff-panel-border);
  --bs-pagination-hover-color: var(--ff-text-strong);
  --bs-pagination-active-bg: var(--ff-accent);
  --bs-pagination-active-border-color: var(--ff-accent-stroke);
  --bs-pagination-active-color: #ffffff;
  --bs-pagination-disabled-bg: rgba(20, 20, 20, 0.6);
  --bs-pagination-disabled-border-color: var(--ff-panel-border);
  --bs-pagination-disabled-color: var(--ff-text-soft);
  border-radius: 0;
}

.page-link {
  border-radius: 0 !important;
}

/* ------------------------------------EVENTS--------------------------------- */
.news-boxes {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  width: 100%;
}

.event-item {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  width: min(100%, 920px);
  padding: 0.9rem 1rem;
  background: linear-gradient(180deg, rgba(22, 22, 22, 0.94), rgba(16, 16, 16, 0.98));
  border: 1px solid var(--ff-panel-border);
  box-shadow: var(--ff-shadow-card);
}

.event-item svg {
  flex: 0 0 auto;
  margin-top: 0.15rem;
  color: #ff7b6c;
}

.event-info {
  width: 100%;
}

.event-info h4 {
  margin: 0;
  color: var(--ff-text-strong);
  font-size: 0.98rem;
  line-height: 1.35;
}

.event-info p {
  line-height: 1.4;
  margin: 0;
}
.event-info p strong {
  font-weight: 400;
}

/* ------------------------------------FOOTER--------------------------------- */
footer {
  padding: 0.75rem 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

footer h6 {
  margin: 0 !important;
}

footer .nav-link {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  font-weight: 500 !important;
  color: var(--ff-text) !important;
}

footer .nav-link:hover {
  color: var(--ff-accent) !important;
}

.footer-links {
  padding-left: 0 !important;
  margin-top: 0.75rem;
  gap: 0.25rem 0.75rem;
  justify-content: center;
}

@media screen and (min-width: 768px) {
  .footer-links {
    margin-top: 0;
    margin-left: 1.75rem;
  }
}

/* ------------------------------------KONTAKT--------------------------------- */
.contact-map-container {
  min-height: 320px;
  height: 100%;
  border: 1px solid var(--ff-panel-border);
  background: linear-gradient(180deg, rgba(22, 22, 22, 0.94), rgba(16, 16, 16, 0.98));
  box-shadow: var(--ff-panel-glow);
}

.contact-map-container iframe {
  display: block;
}

@media screen and (max-width: 767px) {
  .contact-details {
    padding: 1rem;
  }

  .contact-title {
    font-size: 1.15rem;
  }

  .contact-address {
    margin-bottom: 1.2rem;
  }

  .contact-section {
    margin-bottom: 0.9rem;
  }

  .contact-label {
    font-size: 0.72rem;
  }

  .contact-map-container {
    min-height: 260px;
    height: 260px;
  }
}

.content a {
  color: var(--ff-text);
  transition: color 0.2s;
}

.content a:hover {
  color: var(--ff-accent);
}

.contact-details {
  background: var(--ff-panel-bg);
  border: 1px solid var(--ff-panel-border);
  box-shadow: var(--ff-panel-glow);
  padding: 1.25rem;
}

.contact-title {
  margin-bottom: 0.4rem;
  color: var(--ff-text-strong);
}

.contact-address {
  color: var(--ff-text);
  margin-bottom: 1.5rem;
}

.contact-section {
  margin-bottom: 1rem;
}

.contact-label {
  margin-bottom: 0.2rem;
  color: var(--ff-text-soft);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: 0.8rem;
}

.contact-value {
  margin-bottom: 0.15rem;
  color: var(--ff-text-strong);
  font-weight: 500;
}

.contact-meta {
  margin-bottom: 0;
}

.contact-meta a {
  text-decoration: none;
}

.contact-meta a:hover {
  text-decoration: underline;
}

.content-panel {
  background: var(--ff-panel-bg);
  border: 1px solid var(--ff-panel-border);
  box-shadow: var(--ff-panel-glow);
  padding: 1.25rem;
}

.imprint-panel h5 {
  color: var(--ff-text-strong);
  font-size: 0.98rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 0.45rem;
}

.imprint-panel p {
  margin-bottom: 1rem;
}

.imprint-panel p:last-child {
  margin-bottom: 0;
}

.team-subheader {
  padding: 1.1rem 0 0.7rem;
}

.team-subheader h3 {
  font-size: clamp(1.02rem, 1.7vw, 1.28rem);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ff-text-strong);
}

.team-subheader .section-divider {
  max-width: 220px;
}

.card-img-top-dgrd {
  width: 100%;
  height: auto;
  max-height: 200px;
  object-fit: contain;
  margin: 0 auto;
  border-radius: 0px;
  transform: translate(+15%, 0%) !important;
}

.card-img-top-avatar {
  position: absolute;
  width: 100%;
  height: auto;
  max-height: 200px;
  object-fit: contain;
  transform: translate(-10%, 0%) !important;
}

.custom-hover {
  padding: 8px;
}

@media screen and (min-width: 768px) {
  .custom-hover {
    padding: 15px;
  }
}

@media screen and (min-width: 1200px) {
  .custom-hover {
    padding: 20px;
  }
}

.custom-hover .card {
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none;
  position: relative;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .content {
    background-size: auto;
  }

  .content-section,
  .events {
    padding: 0.9rem;
  }

  .main-header {
    gap: 0.8rem;
  }

  .section-divider {
    max-width: 180px;
  }
}

.custom-hover img {
  filter: contrast(30%) !important;
}

.custom-hover:hover img {
  filter: contrast(100%) !important;
  transition-duration: 0.5s;
}

.card-img-overlay {
  text-align: end;
  overflow-wrap: anywhere !important;
  padding: 0.5rem;
}

.card-img-overlay h5 {
  font-size: clamp(0.65rem, 1.2vw, 0.9rem);
  text-shadow: 2px 2px 5px rgb(0, 0, 0);
  font-weight: 500;
  color: white !important;
  margin-bottom: 0.15rem;
}

.card-img-overlay p {
  font-size: clamp(0.6rem, 1vw, 0.85rem);
  text-shadow: 2px 2px 5px rgb(0, 0, 0);
  font-weight: 500;
  color: white !important;
  margin-bottom: 0;
}

.custom-hover:hover .card-img-overlay h5 {
  color: white !important;
  transform: translate(+15%, 0%) !important;
  transition-duration: 0.3s;
}

.custom-hover:hover .card-img-overlay p {
  color: white !important;
  transform: translate(+15%, 0%) !important;
  transition-duration: 0.3s;
}

/* Mobile: larger text in cards since only 2 columns */
@media screen and (max-width: 575px) {
  .card-img-overlay h5 {
    font-size: 0.75rem;
  }
  .card-img-overlay p {
    font-size: 0.7rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  #down-arrow {
    animation: none !important;
  }
}
