@keyframes spin-slow {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}


#full-coverage-slider {
  width: 100%;
  aspect-ratio: 1558 / 550; /* keeps design ratio */
  height: auto;
  background-color: #020617;
}

  @media (max-width: 1024px) {
    #full-coverage-slider {
      height: auto;
    }
  }

  @media (max-width: 768px) {
    #full-coverage-slider {
      height: auto;
    }
  }

  @media (max-width: 480px) {
    #full-coverage-slider {
      height: auto;
    }
}


/* Extra aggressive hiding for mobile/tablet */
@media (max-width: 1023px) {

    #pageTitle,
    #pageSubtitle,
    #sidebarToggle+div,
    #sidebarToggle+.min-w-0 {
        display: none !important;
    }
}


@keyframes spin-medium {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(-360deg);
    }
}

@keyframes spin-fast {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes pulse-slow {

    0%,
    100% {
        opacity: 0.6;
        transform: scale(1);
    }

    50% {
        opacity: 0.9;
        transform: scale(1.1);
    }
}

@keyframes pulse-scale {

    0%,
    100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.05);
    }
}

@keyframes orbit {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes orbit-reverse {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(-360deg);
    }
}

.animate-spin-slow {
    animation: spin-slow 40s linear infinite;
}

.animate-spin-medium {
    animation: spin-medium 30s linear infinite;
}

.animate-spin-fast {
    animation: spin-fast 20s linear infinite;
}

.animate-pulse-slow {
    animation: pulse-slow 8s ease-in-out infinite;
}

.animate-pulse-scale {
    animation: pulse-scale 4s ease-in-out infinite;
}

.animate-orbit {
    animation: orbit 25s linear infinite;
}

.animate-orbit-reverse {
    animation: orbit-reverse 35s linear infinite;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-fade-in-up {
    animation: fadeInUp 0.8s ease-out forwards;
}

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(50px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes iconPulse {

    0%,
    100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.1);
    }
}

@keyframes borderGlow {
    0% {
        box-shadow: 0 0 0 0 rgba(22, 180, 213, 0.4), inset 0 0 0 1px rgba(22, 180, 213, 0.1);
    }

    50% {
        box-shadow: 0 0 20px 0 rgba(22, 180, 213, 0.2), inset 0 0 0 1px rgba(22, 180, 213, 0.3);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(22, 180, 213, 0), inset 0 0 0 1px rgba(22, 180, 213, 0.1);
    }
}

.animate-slide-in-1 {
    animation: slideInRight 0.6s ease-out forwards 0.1s;
}

.animate-slide-in-2 {
    animation: slideInRight 0.6s ease-out forwards 0.2s;
}

.animate-slide-in-3 {
    animation: slideInRight 0.6s ease-out forwards 0.3s;
}

.group:hover .animate-icon-pulse {
    animation: iconPulse 0.6s ease-in-out;
}

@keyframes fadeInUpDelay {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideInLeft {
    from {
        opacity: 0;
        transform: translateX(-50px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes scaleIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

.animate-fade-in-delay-1 {
    animation: fadeInUpDelay 0.6s ease-out forwards 0.1s;
    opacity: 0;
}

.animate-fade-in-delay-2 {
    animation: fadeInUpDelay 0.6s ease-out forwards 0.2s;
    opacity: 0;
}

.animate-fade-in-delay-3 {
    animation: fadeInUpDelay 0.6s ease-out forwards 0.3s;
    opacity: 0;
}

.animate-fade-in-delay-4 {
    animation: fadeInUpDelay 0.6s ease-out forwards 0.4s;
    opacity: 0;
}

.animate-slide-in-left {
    animation: slideInLeft 0.8s ease-out forwards;
}

.animate-slide-in-right {
    animation: slideInRight 0.8s ease-out forwards;
}

.animate-scale-in {
    animation: scaleIn 0.6s ease-out forwards;
}


/* Theme toggle colors are now handled in oris-landingpage.css */
#theme-toggle,
#theme-toggle-mobile {
    color: #fff;
}

@keyframes chatGlowMove {
    from {
        transform: translateX(-10%);
    }

    to {
        transform: translateX(10%);
    }
}

.chat-box {
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, background-color 0.3s ease;
}

.group:hover .chat-box {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 12px 40px rgba(6, 182, 212, 0.25);
    border-color: rgba(6, 182, 212, 0.4);
}

.chat-glow {
    animation: chatGlowMove 5s ease-in-out infinite alternate;
}

.chat-icon-btn {
    transition: transform 0.2s ease, background-color 0.2s ease;
}

.chat-icon-btn:hover {
    transform: scale(1.08);
}

.group:hover .chat-icon-btn {
    transform: translateY(-1px);
}
