.hero-fade { 
    opacity: 0; 
    transform: translateY(30px); 
    animation: fadeUp 1s ease-out forwards; 
}
.hero-fade.delay-1 { animation-delay: 0.5s; }
.hero-fade.delay-2 { animation-delay: 1s; }
.hero-fade.delay-3 { animation-delay: 1.5s; }
@keyframes fadeUp { to { opacity: 1; transform: translateY(0); } }
@keyframes marquee {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}
.track { display: flex; gap: 4rem; animation: marquee 25s linear infinite; }
.track:hover { animation-play-state: paused; }
.fade { position: absolute; top: 0; bottom: 0; width: 80px; pointer-events: none; }
.fade-left { left: 0; background: linear-gradient(to right, white, transparent); }
.fade-right { right: 0; background: linear-gradient(to left, white, transparent); }
.reveal { opacity: 0; transform: translateY(40px); transition: all 0.8s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.card {
    opacity: 0;
    transform: scale(0.9);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
    will-change: opacity, transform;
}
.card.visible {
    opacity: 1;
    transform: scale(1);
    box-shadow: 0 0 20px rgba(42,114,66,0.25);
}
.brand-green { color: #2a7242; }
.bg-brand-green { background-color: #2a7242; }
.bg-brand-green:hover { background-color: #1e4f2f; }
@keyframes spin { from { transform: rotate(0deg);} to { transform: rotate(360deg);} }
.spin-slow { animation: spin 5s linear infinite; }
:root { --brand:#2a7242; }
.navlink { transition: color .2s ease; color: inherit; }
.navlink:hover { color: var(--brand); }
#mobileMenu { display: none; }
#mobileMenu.active { display: block; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp { from { transform: translateY(40px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes slideDown { from { transform: translateY(-40px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes zoomIn { from { transform: scale(0.9); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.animate-fadeIn   { animation: fadeIn 0.4s ease forwards; }
.animate-slideUp  { animation: slideUp 0.6s ease forwards; }
.animate-slideDown{ animation: slideDown 0.6s ease forwards; }
.animate-zoomIn   { animation: zoomIn 0.6s ease forwards; }
.modal { position:fixed; inset:0; display:flex; align-items:center; justify-content:center; z-index:50; }
.modal-backdrop { position:absolute; inset:0; background:rgba(0,0,0,0.7); }
.modal-content { position:relative; background:#fff; border-radius:1rem; padding:3rem; max-width:64rem; width:90%; max-height:90vh; overflow-y:auto; box-shadow:0 20px 50px rgba(0,0,0,0.3); }
.modal-close { position:absolute; top:1rem; right:1rem; font-size:2rem; font-weight:bold; color:#444; background:none; border:none; cursor:pointer; }
.modal-close:hover { color:#2a7242; }
.modal-grid { display:grid; gap:2rem; grid-template-columns:1fr; }
@media(min-width:768px){ .modal-grid{ grid-template-columns:1fr 1fr; } }
.modal-footer { margin-top:2rem; text-align:center; }
.modal-footer a { background:#2a7242; color:#fff; padding:1rem 2rem; border-radius:0.75rem; font-weight:600; display:inline-block; transition:background 0.2s ease; }
.modal-footer a:hover { background:#215b35; }
.parallax {
  will-change: transform;
  backface-visibility: hidden;
  transform: translateZ(0);
}
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.track {
  display: flex;
  gap: 4rem;
  animation: marquee 110s linear infinite;
  width: max-content;
}
.logo-container {
  width: 180px;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.partner-logo {
  height: 100px;
  width: auto;
  object-fit: contain;
  display: block;
  opacity: 0.8;
  filter: grayscale(100%) brightness(0) invert(20%) sepia(100%) hue-rotate(110deg) saturate(500%) contrast(0.9);
  transition: opacity 0.3s ease, transform 0.3s ease;
  margin: 0 2rem;
}
.partner-logo:hover {
  opacity: 1;
  transform: scale(1.05);
}
.fade {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 80px;
  pointer-events: none;
  z-index: 10;
}
.fade-left {
  left: 0;
  background: linear-gradient(to right, #f8fafc, transparent);
}
.fade-right {
  right: 0;
  background: linear-gradient(to left, #f8fafc, transparent);
}
