html {
    scroll-behavior: smooth;
}

.hero-overlay {
    background: linear-gradient(to right, rgba(46, 62, 75, 0.9), rgba(46, 62, 75, 0.7));
}

.text-brand-dark {
    color: #2E3E4B;
}

.bg-brand-dark {
    background-color: #2E3E4B;
}

.text-brand-green {
    color: #22C16B;
}

.bg-brand-green {
    background-color: #22C16B;
}

.hover\:bg-brand-green-dark:hover {
    background-color: #1eab5f;
}

.border-brand-green {
    border-color: #22C16B;
}

.focus\:ring-brand-green:focus {
    --tw-ring-color: #22C16B;
}

/* Ticker Animation - Seamless Loop */
@keyframes ticker {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

.ticker-container {
    overflow: hidden;
    white-space: nowrap;
    width: 100%;
}

.ticker-content {
    display: inline-flex;
    animation: ticker 60s linear infinite;
    font-size: 0.95rem;
}

.ticker-item {
    display: inline-flex;
    align-items: center;
    padding: 0 4rem;
    font-weight: 600;
}

/* Entrance Animations */
@keyframes reveal-up {
    0% {
        transform: translateY(40px);
        opacity: 0;
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes reveal-left {
    0% {
        transform: translateX(-40px);
        opacity: 0;
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes reveal-right {
    0% {
        transform: translateX(40px);
        opacity: 0;
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

.reveal, .reveal-left, .reveal-right {
    opacity: 0;
    will-change: transform, opacity;
}

.reveal.active {
    animation: reveal-up 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.reveal-left.active {
    animation: reveal-left 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.reveal-right.active {
    animation: reveal-right 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Stagger delays */
.delay-100 {
    animation-delay: 100ms;
}

.delay-200 {
    animation-delay: 200ms;
}

.delay-300 {
    animation-delay: 300ms;
}

.delay-400 {
    animation-delay: 400ms;
}

/* Dropdown styles moved to Tailwind utilities in header.php */

/* Custom Pulsing Ripple Animation */
@keyframes ripple-1 {
    0% {
        transform: scale(1);
        opacity: 0.8;
    }
    100% {
        transform: scale(1.8);
        opacity: 0;
    }
}

@keyframes ripple-2 {
    0% {
        transform: scale(1);
        opacity: 0.6;
    }
    100% {
        transform: scale(2.4);
        opacity: 0;
    }
}

.ripple-bg-1 {
    animation: ripple-1 2.5s cubic-bezier(0.1, 0.8, 0.3, 1) infinite;
}

.ripple-bg-2 {
    animation: ripple-2 2.5s cubic-bezier(0.1, 0.8, 0.3, 1) infinite;
    animation-delay: 0.8s;
}

/* Gentle heartbeat/blinking animation for the button */
@keyframes gentle-pulse {
    0%, 100% {
        transform: scale(1);
        box-shadow: 0 4px 14px 0 rgba(34, 193, 107, 0.4);
    }
    50% {
        transform: scale(1.03);
        box-shadow: 0 6px 20px 0 rgba(34, 193, 107, 0.6);
        background-color: #1eab5f; /* subtle blink/shade transition */
    }
}

.gentle-pulse-btn {
    animation: gentle-pulse 2s infinite ease-in-out;
}

.gentle-pulse-btn:hover {
    animation: none; /* Let hover classes take over smoothly */
}

/* Premium Hover Transitions & Motion Effects */
.group {
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.group:hover {
    transform: translateY(-4px);
}

/* Smooth Image Scale inside Cards */
.overflow-hidden img {
    transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

/* Smooth Slider Motion */
#testimonial-track {
    transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1) !important;
}