/* 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%; }
}

/* 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);
}

.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);
}

.redwave-home .rw-reveal.is-visible .redwave-modern-title-wrap::after,
.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 — tactile + shimmer on hover */
.redwave-home .redwave-product-card {
    transition:
        transform 0.35s var(--rw-ease-out),
        filter 0.35s var(--rw-ease-out);
}

.redwave-home .redwave-product-card:hover {
    transform: translateY(-8px);
    filter: drop-shadow(0 12px 28px rgba(255, 69, 69, 0.12));
}

.redwave-home .redwave-product-card:active {
    transform: translateY(-4px) scale(0.99);
}

.redwave-home .redwave-product-media::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 4;
    pointer-events: none;
    background: linear-gradient(
        105deg,
        transparent 40%,
        rgba(255, 255, 255, 0.06) 50%,
        transparent 60%
    );
    transform: translateX(-120%);
    transition: transform 0.6s var(--rw-ease-out);
}

.redwave-home .redwave-product-card:hover .redwave-product-media::before {
    transform: translateX(120%);
}

/* Hot categories — hover ring only (no float) */
.redwave-home .rw-hot-cat-circle {
    border: 2px solid transparent;
    transition:
        transform 0.4s var(--rw-ease-out),
        box-shadow 0.4s var(--rw-ease-out),
        border-color 0.3s ease;
}

.redwave-home .rw-hot-cat-circle:hover {
    border-color: rgba(255, 69, 69, 0.55);
    box-shadow:
        0 14px 40px rgba(0, 0, 0, 0.55),
        0 0 0 1px rgba(255, 69, 69, 0.2),
        0 0 32px var(--rw-accent-soft);
}

/* 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);
}

/* Carousel arrows — micro-interaction */
.redwave-home .rw-home-slider-carousel .slick-arrow {
    transition:
        transform 0.25s var(--rw-ease-spring),
        background 0.2s ease,
        box-shadow 0.25s ease !important;
}

.redwave-home .rw-home-slider-carousel .slick-arrow:hover {
    transform: scale(1.08) !important;
    box-shadow: 0 0 20px var(--rw-accent-soft) !important;
}

.redwave-home .rw-home-slider-carousel .slick-arrow:active {
    transform: scale(0.96) !important;
}

/* 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, 4rem) 0;
}

@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 .redwave-section-kicker::before {
        animation: none !important;
    }

    .redwave-home .redwave-product-media::before {
        display: none;
    }
}
