/* ==============================
   Rishvin Labs v3 Animations
   Theme: Premium Light Luxury
   ============================== */

/* ─────────────────────────────────────────
   LOADER
───────────────────────────────────────── */
#loader {
  position: fixed;
  inset: 0;
  background: var(--bg-primary);
  z-index: var(--z-loader);
  display: flex;
  justify-content: center;
  align-items: center;
  transition: opacity 0.8s ease, visibility 0.8s;
}

#loader::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-hero);
  pointer-events: none;
}

#loader.hidden {
  opacity: 0;
  visibility: hidden;
}

.loader-content {
  text-align: center;
  position: relative;
  z-index: 1;
}

.typewriter {
  --blue: #5C86FF;
  --blue-dark: #275EFE;
  --key: #fff;
  --paper: #EEF0FD;
  --text: #D3D4EC;
  --tool: #FBC56C;
  --duration: 3s;
  position: relative;
  -webkit-animation: bounce05 var(--duration) linear infinite;
  animation: bounce05 var(--duration) linear infinite;
}

.typewriter .slide {
  width: 92px;
  height: 20px;
  border-radius: 3px;
  margin-left: 14px;
  transform: translateX(14px);
  background: linear-gradient(var(--blue), var(--blue-dark));
  -webkit-animation: slide05 var(--duration) ease infinite;
  animation: slide05 var(--duration) ease infinite;
}

.typewriter .slide:before, .typewriter .slide:after,
.typewriter .slide i:before {
  content: "";
  position: absolute;
  background: var(--tool);
}

.typewriter .slide:before {
  width: 2px;
  height: 8px;
  top: 6px;
  left: 100%;
}

.typewriter .slide:after {
  left: 94px;
  top: 3px;
  height: 14px;
  width: 6px;
  border-radius: 3px;
}

.typewriter .slide i {
  display: block;
  position: absolute;
  right: 100%;
  width: 6px;
  height: 4px;
  top: 4px;
  background: var(--tool);
}

.typewriter .slide i:before {
  right: 100%;
  top: -2px;
  width: 4px;
  border-radius: 2px;
  height: 14px;
}

.typewriter .paper {
  position: absolute;
  left: 24px;
  top: -26px;
  width: 40px;
  height: 46px;
  border-radius: 5px;
  background: var(--paper);
  transform: translateY(46px);
  -webkit-animation: paper05 var(--duration) linear infinite;
  animation: paper05 var(--duration) linear infinite;
}

.typewriter .paper:before {
  content: "";
  position: absolute;
  left: 6px;
  right: 6px;
  top: 7px;
  border-radius: 2px;
  height: 4px;
  transform: scaleY(0.8);
  background: var(--text);
  box-shadow: 0 12px 0 var(--text), 0 24px 0 var(--text), 0 36px 0 var(--text);
}

.typewriter .keyboard {
  width: 120px;
  height: 56px;
  margin-top: -10px;
  z-index: 1;
  position: relative;
}

.typewriter .keyboard:before, .typewriter .keyboard:after {
  content: "";
  position: absolute;
}

.typewriter .keyboard:before {
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 7px;
  background: linear-gradient(135deg, var(--blue), var(--blue-dark));
  transform: perspective(10px) rotateX(2deg);
  transform-origin: 50% 100%;
}

.typewriter .keyboard:after {
  left: 28px;
  top: 25px;
  width: 11px;
  height: 4px;
  border-radius: 2px;
  box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  -webkit-animation: keyboard05 var(--duration) linear infinite;
  animation: keyboard05 var(--duration) linear infinite;
}

@keyframes bounce05 {
  85%, 92%, 100% {
    transform: translateY(0);
  }
  89% {
    transform: translateY(-4px);
  }
  95% {
    transform: translateY(2px);
  }
}

@keyframes slide05 {
  5% {
    transform: translateX(14px);
  }
  15%, 30% {
    transform: translateX(-13px);
  }
  40%, 55% {
    transform: translateX(0);
  }
  65%, 80% {
    transform: translateX(14px);
  }
}

@keyframes paper05 {
  5% {
    transform: translateY(46px);
  }
  20%, 30% {
    transform: translateY(34px);
  }
  40%, 55% {
    transform: translateY(22px);
  }
  65%, 80% {
    transform: translateY(10px);
  }
  90%, 100% {
    transform: translateY(0);
  }
}

@keyframes keyboard05 {
  5%, 12%, 21%, 30%, 39%, 48%, 57%, 66%, 75%, 84% {
    box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
  9% {
    box-shadow: 15px 2px 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
  18% {
    box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 2px 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
  27% {
    box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
  36% {
    box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
  45% {
    box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
  54% {
    box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
  63% {
    box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
  72% {
    box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
  81% {
    box-shadow: 15px 0 0 var(--key), 30px 0 0 var(--key), 45px 0 0 var(--key), 60px 0 0 var(--key), 15px 10px 0 var(--key), 30px 10px 0 var(--key), 45px 10px 0 var(--key), 60px 10px 0 var(--key), -11px 10px 0 var(--key), 15px 20px 0 var(--key), 30px 20px 0 var(--key), 45px 20px 0 var(--key), 60px 20px 0 var(--key), 75px 20px 0 var(--key), -11px 20px 0 var(--key), 4px 20px 0 var(--key), 8px 30px 0 var(--key), 23px 30px 0 var(--key), 38px 30px 0 var(--key), 53px 30px 0 var(--key), 68px 30px 0 var(--key), 83px 30px 0 var(--key);
  }
}

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

/* ─────────────────────────────────────────
   REVEAL / SCROLL ANIMATIONS
───────────────────────────────────────── */

.reveal {
  opacity: 0;
  transform: translateY(30px) scale(0.98);
  filter: blur(10px);
  transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.reveal.active {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

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

.reveal-left {
  opacity: 0;
  transform: translateX(-28px);
  transition: opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-left.active {
  opacity: 1;
  transform: translateX(0);
}

.reveal-right {
  opacity: 0;
  transform: translateX(28px);
  transition: opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-right.active {
  opacity: 1;
  transform: translateX(0);
}

/* ─────────────────────────────────────────
   ENTRANCE ANIMATIONS
───────────────────────────────────────── */
.animate-slide-up {
  animation: slideUpFade 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 0;
}

.animate-fade-in {
  animation: fadeIn 1s ease forwards;
  opacity: 0;
}

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

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ─────────────────────────────────────────
   STAGGER DELAYS
───────────────────────────────────────── */
.delay-0   { animation-delay: 0ms;   transition-delay: 0ms; }
.delay-100 { animation-delay: 100ms; transition-delay: 100ms; }
.delay-200 { animation-delay: 200ms; transition-delay: 200ms; }
.delay-300 { animation-delay: 300ms; transition-delay: 300ms; }
.delay-400 { animation-delay: 400ms; transition-delay: 400ms; }
.delay-500 { animation-delay: 500ms; transition-delay: 500ms; }
.delay-600 { animation-delay: 600ms; transition-delay: 600ms; }
.delay-700 { animation-delay: 700ms; transition-delay: 700ms; }

/* ─────────────────────────────────────────
   FLOAT
───────────────────────────────────────── */
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-10px); }
}
.float-anim { animation: float 6s ease-in-out infinite; }

/* ─────────────────────────────────────────
   SPINNING RINGS
───────────────────────────────────────── */
@keyframes spin-cw  { to { transform: rotate(360deg); } }
@keyframes spin-ccw { to { transform: rotate(-360deg); } }

/* ─────────────────────────────────────────
   GLOW PULSE
───────────────────────────────────────── */
@keyframes glow-pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(5, 150, 105, 0.5); }
  50%       { opacity: 0.8; box-shadow: 0 0 0 6px rgba(5, 150, 105, 0); }
}

@keyframes avail-pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(5, 150, 105, 0.45); }
  50%       { opacity: 0.7; box-shadow: 0 0 0 5px rgba(5, 150, 105, 0); }
}

/* ─────────────────────────────────────────
   SHIMMER
───────────────────────────────────────── */
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}

/* ─────────────────────────────────────────
   MARQUEE
───────────────────────────────────────── */
@keyframes scroll-marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ─────────────────────────────────────────
   HOVER UNDERLINE
───────────────────────────────────────── */
.hover-underline {
  position: relative;
  display: inline-block;
}
.hover-underline::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 1.5px;
  bottom: -2px;
  left: 0;
  background: var(--gradient-primary);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.4s cubic-bezier(0.86, 0, 0.07, 1);
}
.hover-underline:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

/* ─────────────────────────────────────────
   PAGE TRANSITIONS
───────────────────────────────────────── */
body {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.35s ease-out, transform 0.35s ease-out;
}
body.page-loaded  { opacity: 1; transform: translateY(0); }
body.page-exiting { opacity: 0; transform: translateY(-10px); }

/* ─────────────────────────────────────────
   GENERIC PULSE
───────────────────────────────────────── */
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.35; }
}
