/* Groomr - Shared Styles */

body {
    font-family: 'Plus Jakarta Sans', sans-serif;
}

/* Team photo hover swap */
.team-member-group .photo-pro {
    opacity: 1;
    transition: opacity 0.4s ease;
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    object-fit: cover;
}
.team-member-group .photo-goofy {
    opacity: 0;
    transition: opacity 0.4s ease;
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    object-fit: cover;
}
.team-member-group:hover .photo-pro { opacity: 0; }
.team-member-group:hover .photo-goofy { opacity: 1; }

/* Spring hover */
.spring-hover {
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.spring-hover:hover {
    transform: scale(1.05);
}

/* Hover scale spring */
.hover-scale-spring {
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.3s ease;
}
.hover-scale-spring:hover {
    transform: scale(1.05);
    box-shadow: 0 24px 48px rgba(19, 124, 236, 0.15);
}

/* Animations */
@keyframes bounceUp {
    0%   { transform: translateY(100px); opacity: 0; }
    60%  { transform: translateY(-15px); opacity: 1; }
    80%  { transform: translateY(10px); }
    100% { transform: translateY(0); opacity: 1; }
}
.animate-bounce-up {
    animation: bounceUp 1s cubic-bezier(0.28, 0.84, 0.42, 1) forwards;
    opacity: 0;
}

@keyframes fadeUp {
    from { opacity: 0; transform: translateY(30px); }
    to   { opacity: 1; transform: translateY(0); }
}
.animate-fade-up {
    animation: fadeUp 0.6s ease-out forwards;
    opacity: 0;
}
.delay-100 { animation-delay: 100ms; }
.delay-300 { animation-delay: 300ms; }
.delay-500 { animation-delay: 500ms; }

/* Blob shapes */
.blob-1 { border-radius: 40% 60% 70% 30% / 40% 50% 60% 50%; }
.blob-2 { border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%; }

/* Mobile menu */
#mobile-menu {
    transition: max-height 0.3s ease, opacity 0.3s ease;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
}
#mobile-menu.open {
    max-height: 400px;
    opacity: 1;
}

/* FAQ accordion */
.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease, opacity 0.35s ease;
    opacity: 0;
}
.faq-answer.open {
    max-height: 300px;
    opacity: 1;
}
.faq-icon {
    transition: transform 0.3s ease;
}
.faq-item.open .faq-icon {
    transform: rotate(45deg);
}

/* Pricing toggle */
.toggle-slider {
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: #f1f1f1; }
::-webkit-scrollbar-thumb { background: #137cec; border-radius: 3px; }

/* Smooth scroll */
html { scroll-behavior: smooth; }

/* Nav active underline */
.nav-active {
    color: #137cec;
    position: relative;
}
.nav-active::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    right: 0;
    height: 2px;
    background: #137cec;
    border-radius: 9999px;
}

/* Feature mockup styles */
.mockup-browser {
    background: #fff;
    border-radius: 1rem;
    box-shadow: 0 20px 60px rgba(0,0,0,0.12);
    overflow: hidden;
}
.mockup-bar {
    background: #f0f0f0;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.mockup-dot {
    width: 10px; height: 10px;
    border-radius: 50%;
}
.mockup-url {
    flex: 1;
    background: #fff;
    border-radius: 6px;
    height: 20px;
    margin-left: 8px;
}
