/* ============================================
   ANIMATIONS.CSS — Contablue Orange Visual Effects
   Beams, glows, tilts, reveals, shimmer
   ============================================ */

/* --- Scroll Reveal --- */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-left { opacity: 0; transform: translateX(-50px); transition: opacity 0.8s ease-out, transform 0.8s ease-out; }
.reveal-left.visible { opacity: 1; transform: translateX(0); }
.reveal-right { opacity: 0; transform: translateX(50px); transition: opacity 0.8s ease-out, transform 0.8s ease-out; }
.reveal-right.visible { opacity: 1; transform: translateX(0); }

/* Stagger delays */
.stagger-1 { transition-delay: 0.05s; }
.stagger-2 { transition-delay: 0.12s; }
.stagger-3 { transition-delay: 0.19s; }
.stagger-4 { transition-delay: 0.26s; }
.stagger-5 { transition-delay: 0.33s; }
.stagger-6 { transition-delay: 0.4s; }

/* --- Hero Entrance --- */
.hero-content { animation: heroEntrance 1s cubic-bezier(0.16, 1, 0.3, 1) 0.2s both; }

@keyframes heroEntrance {
  from { opacity: 0; transform: translateY(40px); }
  to { opacity: 1; transform: translateY(0); }
}

/* --- Typing Text Fade --- */
.typing-fade-in { animation: typeFadeIn 0.4s ease forwards; }
.typing-fade-out { animation: typeFadeOut 0.4s ease forwards; }

@keyframes typeFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
@keyframes typeFadeOut { from { opacity: 1; transform: translateY(0); } to { opacity: 0; transform: translateY(-8px); } }

/* --- GRADIENT TEXT STATIC (no shimmer) --- */
.gradient-text-animated {
  background: linear-gradient(135deg, #F06427, #E8913A);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* --- HERO BEAMS REMOVED --- */
.hero-beam { display: none; }
.hero-beam-2 { display: none; }
.hero-beam-v { display: none; }

/* --- DECORATIVE EFFECTS REMOVED (mesh, grid, glow) --- */
.hero-mesh { display: none; }
.hero-grid-overlay { display: none; }
.hero-glow { display: none; }

/* --- 3D TILT ON HOVER --- */
.tilt-card {
  transform-style: preserve-3d;
  transition: transform var(--duration-fast) var(--ease-default);
  will-change: transform;
}

.tilt-card .tilt-glare {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at var(--glare-x, 50%) var(--glare-y, 50%), rgba(255,255,255,0.06), transparent 60%);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--duration-slow);
  z-index: 10;
}

.tilt-card:hover .tilt-glare {
  opacity: 1;
}

/* --- NEON BORDER REMOVED --- */
.neon-border { position: relative; }
.neon-border::before { display: none; }
.neon-border::after { display: none; }

/* --- BUTTON SHIMMER --- */
.btn-primary {
  position: relative;
  overflow: hidden;
}

.btn-primary::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
  transition: left 0.6s ease;
}

.btn-primary:hover::before {
  left: 100%;
}

/* --- LINK UNDERLINE ANIMATION --- */
.card-link {
  position: relative;
}

.card-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1.5px;
  background: var(--accent-gradient);
  transition: width 0.3s ease;
}

.card-link:hover::after {
  width: 100%;
}

/* --- STATS PROGRESS BARS --- */
.stat-bar {
  width: 80px;
  height: 3px;
  border-radius: 2px;
  background: rgba(255,255,255,0.06);
  margin: 12px auto 0;
  overflow: hidden;
}

.stat-bar-fill {
  height: 100%;
  border-radius: 2px;
  background: var(--accent-gradient);
  width: 0%;
  transition: width 1.5s var(--ease-in-out);
}

.stat-item.visible .stat-bar-fill {
  width: var(--bar-width, 75%);
}

/* --- WORD REVEAL --- */
.word-reveal span {
  display: inline-block;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.5s var(--ease-default), transform 0.5s var(--ease-out);
}

.word-reveal.visible span {
  opacity: 1;
  transform: translateY(0);
}

/* --- MARQUEE ANIMATIONS REMOVED (static layout) --- */

/* --- CURSOR BLINK --- */
@keyframes cursorBlink {
  0%, 50% { opacity: 1; }
  51%, 100% { opacity: 0; }
}

/* --- LIVE DOT PULSE --- */
@keyframes livePulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(34,197,94,0.4); }
  50% { opacity: 0.6; box-shadow: 0 0 0 6px rgba(34,197,94,0); }
}

/* --- WORKFLOW FLOW DOT --- */
@keyframes flowDot {
  0% { left: -6px; opacity: 0; }
  20% { opacity: 1; }
  80% { opacity: 1; }
  100% { left: calc(100% + 6px); opacity: 0; }
}

/* --- ANIMATION KEYFRAMES REMOVED (orbs, dashboard float) --- */

/* --- NAV SLIDE --- */
@keyframes navSlideDown {
  from { transform: translateY(-100%); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

/* --- ANNOUNCEMENT --- */
@keyframes announceSlide {
  from { transform: translateY(-100%); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
