/* ===================================
   MATIXO - Animasyonlar
   =================================== */

/* Temel Keyframe'ler */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-20px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInLeft {
  from { opacity: 0; transform: translateX(-30px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes fadeInRight {
  from { opacity: 0; transform: translateX(30px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes zoomIn {
  from { opacity: 0; transform: scale(0.92); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.05); }
}
@keyframes shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}
@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes drawBorder {
  from { width: 0; }
  to   { width: 60px; }
}

/* ===================================
   Scroll Reveal Sınıfları
   =================================== */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-left {
  opacity: 0;
  transform: translateX(-30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal-left.visible {
  opacity: 1;
  transform: translateX(0);
}
.reveal-right {
  opacity: 0;
  transform: translateX(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal-right.visible {
  opacity: 1;
  transform: translateX(0);
}
.reveal-zoom {
  opacity: 0;
  transform: scale(0.94);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal-zoom.visible {
  opacity: 1;
  transform: scale(1);
}

/* Gecikme yardımcıları */
.delay-1 { transition-delay: 0.1s !important; }
.delay-2 { transition-delay: 0.2s !important; }
.delay-3 { transition-delay: 0.3s !important; }
.delay-4 { transition-delay: 0.4s !important; }
.delay-5 { transition-delay: 0.5s !important; }
.delay-6 { transition-delay: 0.6s !important; }

/* ===================================
   Hero Animasyonları
   =================================== */
.hero-animate-1 {
  animation: fadeInDown 0.7s ease 0.2s both;
}
.hero-animate-2 {
  animation: fadeInUp 0.7s ease 0.4s both;
}
.hero-animate-3 {
  animation: fadeInUp 0.7s ease 0.55s both;
}
.hero-animate-4 {
  animation: fadeInUp 0.7s ease 0.7s both;
}

/* ===================================
   Parıldama Efekti (Skeletons/Loading)
   =================================== */
.shimmer {
  background: linear-gradient(90deg,
    rgba(247,243,235,0) 0%,
    rgba(247,243,235,0.8) 50%,
    rgba(247,243,235,0) 100%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
}

/* ===================================
   Hover Efektleri
   =================================== */
.hover-lift {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.hover-lift:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(32, 80, 107, 0.15);
}
.hover-glow:hover {
  box-shadow: 0 0 0 4px rgba(65, 183, 168, 0.25);
}
.hover-scale {
  transition: transform 0.3s ease;
}
.hover-scale:hover { transform: scale(1.03); }

/* ===================================
   İkon Float Animasyonu
   =================================== */
.icon-float {
  animation: float 3s ease-in-out infinite;
}
.icon-float-delay {
  animation: float 3s ease-in-out 1s infinite;
}

/* ===================================
   Sayaç (Counter) Animasyon
   =================================== */
.counter-value {
  display: inline-block;
  animation: zoomIn 0.5s ease both;
}

/* ===================================
   Başlık Alt Çizgisi Animasyonu
   =================================== */
.animated-underline {
  position: relative;
  display: inline-block;
}
.animated-underline::after {
  content: '';
  position: absolute;
  bottom: -6px;
  left: 0;
  width: 0;
  height: 3px;
  background: var(--turquoise);
  border-radius: 2px;
  transition: width 0.5s ease;
}
.animated-underline.visible::after {
  width: 100%;
}

/* ===================================
   Carousel Geçiş Animasyonları
   =================================== */
.carousel-fade .carousel-item {
  transition: opacity 0.8s ease;
}

/* ===================================
   Pulse Animasyonu (CTA butonları)
   =================================== */
.pulse-btn {
  animation: pulse 2s ease-in-out infinite;
}

/* ===================================
   Sayfa Yükleme Çubuğu
   =================================== */
.page-loader {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 3px;
  background: linear-gradient(90deg, var(--turquoise), var(--orange));
  z-index: 99999;
  transform-origin: left;
  animation: loadBar 1.2s ease forwards;
}
@keyframes loadBar {
  0%   { transform: scaleX(0); }
  80%  { transform: scaleX(0.9); }
  100% { transform: scaleX(1); opacity: 0; }
}
