/* Redwave home — Taste Skill + Impeccable motion (transform/opacity only) */

.redwave-home {
    --rw-bg: #0a0a0a;
    --rw-surface: #111111;
    --rw-accent: #ff4545;
    --rw-accent-soft: rgba(255, 69, 69, 0.22);
    --rw-accent-glow: rgba(255, 69, 69, 0.45);
    --rw-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --rw-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

.redwave-home {
    font-family: "Outfit", "Public Sans", system-ui, sans-serif;
    background: var(--rw-bg) !important;
}

/* Film grain — fixed layer, no scroll repaint */
.redwave-home .rw-home-grain {
    position: fixed;
    inset: 0;
    z-index: 9998;
    pointer-events: none;
    opacity: 0.035;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Hero ambient orbs */
.redwave-home .home-banner-area {
    position: relative;
    isolation: isolate;
}

.redwave-home .rw-hero-ambient {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}

.redwave-home .rw-hero-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.55;
    will-change: transform, opacity;
}

.redwave-home .rw-hero-orb--1 {
    width: min(55vw, 520px);
    height: min(55vw, 520px);
    top: -18%;
    left: -8%;
    background: radial-gradient(circle, var(--rw-accent-glow) 0%, transparent 70%);
    animation: rw-orb-drift-1 14s var(--rw-ease-out) infinite alternate;
}

.redwave-home .rw-hero-orb--2 {
    width: min(40vw, 380px);
    height: min(40vw, 380px);
    bottom: -12%;
    right: -6%;
    background: radial-gradient(circle, rgba(255, 69, 69, 0.28) 0%, transparent 72%);
    animation: rw-orb-drift-2 18s var(--rw-ease-out) infinite alternate;
}

.redwave-home .rw-hero-scanline {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(
        180deg,
        transparent 0%,
        rgba(255, 69, 69, 0.04) 48%,
        transparent 100%
    );
    background-size: 100% 220%;
    animation: rw-scanline 8s linear infinite;
    opacity: 0.6;
}

@keyframes rw-orb-drift-1 {
    0% { transform: translate(0, 0) scale(1); }
    100% { transform: translate(4%, 6%) scale(1.08); }
}

@keyframes rw-orb-drift-2 {
    0% { transform: translate(0, 0) scale(1); }
    100% { transform: translate(-5%, -4%) scale(1.06); }
}

@keyframes rw-scanline {
    0% { background-position: 0 -100%; }
    100% { background-position: 0 200%; }
}

/* Hot categories — ambient mesh + orbs */
.redwave-home .rw-hot-cat-mesh {
    animation: rw-hot-cat-mesh-spin 28s linear infinite;
}

.redwave-home .rw-hot-cat-orb--1 {
    animation: rw-hot-cat-orb-1 16s var(--rw-ease-out) infinite alternate;
}

.redwave-home .rw-hot-cat-orb--2 {
    animation: rw-hot-cat-orb-2 20s var(--rw-ease-out) infinite alternate;
}

.redwave-home .rw-hot-cat-orb--3 {
    animation: rw-hot-cat-orb-3 13s var(--rw-ease-out) infinite alternate;
}

.redwave-home .rw-hot-cat-shine {
    animation: rw-hot-cat-shine-pulse 6s ease-in-out infinite;
}

.redwave-home .rw-hot-cat-title {
    animation: rw-hot-cat-title-glow 4.5s ease-in-out infinite;
}

.redwave-home .rw-hot-cat-title::after {
    animation: rw-hot-cat-title-line 4.5s ease-in-out infinite;
}

@keyframes rw-hot-cat-title-glow {
    0%, 100% {
        text-shadow:
            0 0 12px rgba(255, 69, 69, 0.4),
            0 0 28px rgba(255, 69, 69, 0.2),
            0 2px 6px rgba(0, 0, 0, 0.4);
    }
    50% {
        text-shadow:
            0 0 20px rgba(255, 69, 69, 0.65),
            0 0 46px rgba(255, 69, 69, 0.38),
            0 2px 6px rgba(0, 0, 0, 0.4);
    }
}

@keyframes rw-hot-cat-title-line {
    0%, 100% {
        opacity: 0.75;
        transform: scaleX(0.85);
    }
    50% {
        opacity: 1;
        transform: scaleX(1.1);
    }
}

@keyframes rw-hot-cat-mesh-spin {
    0% { transform: translate(-50%, -50%) rotate(0deg) scale(1); }
    100% { transform: translate(-50%, -50%) rotate(360deg) scale(1.05); }
}

@keyframes rw-hot-cat-orb-1 {
    0% { transform: translate(0, 0) scale(1); opacity: 0.45; }
    100% { transform: translate(6%, 8%) scale(1.1); opacity: 0.58; }
}

@keyframes rw-hot-cat-orb-2 {
    0% { transform: translate(0, 0) scale(1); opacity: 0.38; }
    100% { transform: translate(-7%, -5%) scale(1.08); opacity: 0.52; }
}

@keyframes rw-hot-cat-orb-3 {
    0% { transform: translate(0, 0) scale(1); opacity: 0.28; }
    100% { transform: translate(-4%, 6%) scale(1.12); opacity: 0.42; }
}

@keyframes rw-hot-cat-shine-pulse {
    0%, 100% { opacity: 0.65; }
    50% { opacity: 1; }
}

@keyframes rw-hot-cat-card-glow {
    0%, 100% {
        opacity: 0.5;
        transform: translateX(-50%) scale(1);
    }
    50% {
        opacity: 0.72;
        transform: translateX(-50%) scale(1.05);
    }
}

@keyframes rw-hot-cat-label-glow {
    0%, 100% {
        text-shadow:
            0 0 10px rgba(255, 69, 69, 0.35),
            0 0 20px rgba(255, 69, 69, 0.18),
            0 1px 2px rgba(0, 0, 0, 0.45);
    }
    50% {
        text-shadow:
            0 0 14px rgba(255, 69, 69, 0.48),
            0 0 26px rgba(255, 69, 69, 0.24),
            0 1px 2px rgba(0, 0, 0, 0.45);
    }
}

.redwave-home .rw-hot-cat-card::before,
.redwave-listing-page .rw-hot-cat-card::before {
    animation: rw-hot-cat-card-glow 4.5s ease-in-out infinite;
}

.redwave-home .rw-hot-cat-label,
.redwave-listing-page .rw-hot-cat-label {
    animation: rw-hot-cat-label-glow 5s ease-in-out infinite;
}

.redwave-home a.rw-hot-cat-card:hover .rw-hot-cat-label,
.redwave-home a.rw-hot-cat-card:focus-visible .rw-hot-cat-label,
.redwave-listing-page a.rw-hot-cat-card:hover .rw-hot-cat-label,
.redwave-listing-page a.rw-hot-cat-card:focus-visible .rw-hot-cat-label {
    animation: none;
}

/* Scroll progress indicator */
.rw-scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    z-index: 9999;
    pointer-events: none;
    background: rgba(255, 255, 255, 0.05);
}

.rw-scroll-progress__fill {
    display: block;
    height: 100%;
    width: 100%;
    transform: scaleX(0);
    transform-origin: 0 50%;
    background: linear-gradient(
        90deg,
        var(--rw-accent),
        var(--rw-accent-glow)
    );
    box-shadow: 0 0 12px var(--rw-accent-glow);
    will-change: transform;
}

/* Masked word-by-word title reveal */
.redwave-home .rw-word-mask {
    display: inline-block;
    overflow: hidden;
    vertical-align: top;
    padding-bottom: 0.12em;
    margin-bottom: -0.12em;
}

.redwave-home .rw-word {
    display: inline-block;
    will-change: transform;
}

/* Scroll reveal */
.redwave-home .rw-reveal {
    opacity: 0;
    transform: translateY(28px);
    transition:
        opacity 0.65s var(--rw-ease-out),
        transform 0.65s var(--rw-ease-out);
}

.redwave-home .rw-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* When GSAP drives the motion it owns opacity/transform directly, so the
 * CSS transitions on the reveal elements must step aside to avoid double
 * animation. The title underline (::after) keeps its own transition. */
.redwave-home.rw-gsap .rw-reveal,
.redwave-home.rw-gsap .rw-reveal-stagger > .rw-reveal-item {
    transition: none;
}

.redwave-home .rw-reveal-stagger > .rw-reveal-item {
    opacity: 0;
    transform: translateY(22px);
    transition:
        opacity 0.55s var(--rw-ease-out),
        transform 0.55s var(--rw-ease-out);
    transition-delay: calc(var(--rw-i, 0) * 90ms);
}

.redwave-home .rw-reveal-stagger.is-visible > .rw-reveal-item {
    opacity: 1;
    transform: translateY(0);
}

/* Section title accent line */
.redwave-home .redwave-modern-title-wrap {
    position: relative;
    display: inline-block;
}

.redwave-home .redwave-modern-title-wrap::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -6px;
    height: 2px;
    width: 0;
    background: linear-gradient(90deg, var(--rw-accent), transparent);
    transition: width 0.8s var(--rw-ease-out);
    pointer-events: none;
}

.redwave-home .rw-reveal.is-visible .redwave-modern-title-wrap::after {
    width: 100%;
}

/* Kicker pulse dot */
.redwave-home .redwave-section-kicker {
    gap: 0.5rem;
}

.redwave-home .redwave-section-kicker::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--rw-accent);
    box-shadow: 0 0 12px var(--rw-accent-glow);
    animation: rw-pulse-dot 2.2s var(--rw-ease-out) infinite;
}

@keyframes rw-pulse-dot {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.35); opacity: 0.75; }
}

/* Product cards — static on homepage (no lift / shimmer) */
.redwave-home .redwave-product-card,
.redwave-home .redwave-product-card:hover,
.redwave-home .redwave-product-card:active {
    transform: none !important;
    transition: none !important;
    filter: none !important;
}

.redwave-home .redwave-product-media::before {
    display: none !important;
}

/* Banner promo tiles */
.redwave-home .rw-promo-tile {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    transition:
        transform 0.4s var(--rw-ease-out),
        border-color 0.3s ease,
        box-shadow 0.4s var(--rw-ease-out);
}

.redwave-home .rw-promo-tile:hover {
    transform: translateY(-4px) scale(1.01);
    border-color: rgba(255, 69, 69, 0.35);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.4);
}

.redwave-home .rw-promo-tile:active {
    transform: translateY(-2px) scale(0.995);
}

/* View link CTA */
.redwave-home .redwave-view-link {
    position: relative;
    overflow: hidden;
    transition:
        color 0.25s ease,
        border-color 0.25s ease,
        background 0.25s ease,
        transform 0.25s var(--rw-ease-spring);
}

.redwave-home .redwave-view-link:hover {
    border-color: var(--rw-accent) !important;
    background: var(--rw-accent-soft) !important;
    transform: translateY(-1px);
}

.redwave-home .redwave-view-link:active {
    transform: scale(0.98);
}

/* Flash deal accent */
.redwave-home #flash_deal .flash-deal-icon path {
    fill: var(--rw-accent) !important;
}

/* Dark sections override */
.redwave-home #section_home_categories,
.redwave-home #section_featured {
    background: var(--rw-bg) !important;
}

.redwave-home .redwave-modern-section {
    padding: clamp(2.5rem, 6vw, 0.5rem) 0;
}

.redwave-home .redwave-modern-section.rw-home-curated-section {
    padding: 0.5rem 0;
}

.redwave-home .rw-home-curated-section .redwave-modern-title-wrap::after {
    width: 100%;
}

.redwave-home .rw-home-curated-section .redwave-modern-section-head {
    padding-bottom: 6px;
    overflow: visible;
}

.redwave-home #section_best_selling.redwave-modern-section.rw-home-curated-section {
    padding-top: 1rem;
}

@media (max-width: 767.98px) {
    .redwave-home a.rw-hot-cat-card:hover .rw-hot-cat-circle,
    .redwave-home a.rw-hot-cat-card:active .rw-hot-cat-circle {
        transform: none !important;
        box-shadow:
            0 10px 32px rgba(0, 0, 0, 0.55),
            inset 0 1px 0 rgba(255, 255, 255, 0.08),
            0 0 0 1px rgba(255, 255, 255, 0.06) !important;
    }

    .redwave-home .rw-hot-cat-media img,
    .redwave-home a.rw-hot-cat-card:hover .rw-hot-cat-media img {
        transform: none !important;
        transition: none !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .redwave-home .rw-reveal,
    .redwave-home .rw-reveal-stagger > .rw-reveal-item {
        opacity: 1;
        transform: none;
        transition: none;
    }

    .redwave-home .rw-hero-orb,
    .redwave-home .rw-hero-scanline,
    .redwave-home .rw-hot-cat-mesh,
    .redwave-home .rw-hot-cat-orb,
    .redwave-home .rw-hot-cat-shine,
    .redwave-home .rw-hot-cat-card::before,
    .redwave-home .rw-hot-cat-label,
    .redwave-home .rw-hot-cat-title,
    .redwave-home .rw-hot-cat-title::after,
    .redwave-home .redwave-section-kicker::before {
        animation: none !important;
    }

    .redwave-home .redwave-product-media::before {
        display: none;
    }

    .rw-scroll-progress {
        display: none;
    }

    .redwave-home .rw-word {
        transform: none !important;
        opacity: 1 !important;
    }

    .redwave-home .rw-word-mask {
        overflow: visible;
    }
}
