/**
 * Premium cinematic reels showcase — no Instagram embed chrome.
 */

.reel-showcase-section {
    position: relative;
    overflow: clip;
    padding-block: clamp(3.5rem, 8vw, 5.5rem);
    background:
        radial-gradient(ellipse 90% 60% at 50% -10%, rgba(var(--rgb-teal-bright), 0.09), transparent 55%),
        radial-gradient(ellipse 70% 50% at 100% 80%, rgba(var(--rgb-green), 0.06), transparent 50%),
        linear-gradient(180deg, var(--neutral-mist) 0%, rgba(255, 255, 255, 0.96) 45%, var(--neutral-soft) 100%);
}

.reel-showcase-section::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    opacity: 0.45;
    background-image:
        linear-gradient(rgba(var(--rgb-teal-deep), 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(var(--rgb-teal-deep), 0.04) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse 75% 70% at 50% 45%, #000 20%, transparent 72%);
}

.reel-showcase-section__particles {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.reel-showcase-section__particles span {
    position: absolute;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: rgba(var(--rgb-teal-bright), 0.35);
    box-shadow: 0 0 12px rgba(var(--rgb-teal-bright), 0.25);
    animation: reel-particle-drift 18s ease-in-out infinite;
}

.reel-showcase-section__particles span:nth-child(1) {
    left: 8%;
    top: 22%;
    animation-delay: 0s;
    animation-duration: 22s;
}

.reel-showcase-section__particles span:nth-child(2) {
    left: 18%;
    top: 68%;
    animation-delay: -3s;
    animation-duration: 19s;
    opacity: 0.7;
}

.reel-showcase-section__particles span:nth-child(3) {
    left: 42%;
    top: 12%;
    animation-delay: -7s;
    width: 2px;
    height: 2px;
}

.reel-showcase-section__particles span:nth-child(4) {
    left: 58%;
    top: 78%;
    animation-delay: -2s;
    animation-duration: 24s;
}

.reel-showcase-section__particles span:nth-child(5) {
    left: 72%;
    top: 28%;
    animation-delay: -11s;
    opacity: 0.55;
}

.reel-showcase-section__particles span:nth-child(6) {
    left: 88%;
    top: 55%;
    animation-delay: -5s;
    animation-duration: 20s;
}

@keyframes reel-particle-drift {
    0%,
    100% {
        transform: translate3d(0, 0, 0);
        opacity: 0.35;
    }
    25% {
        transform: translate3d(12px, -18px, 0);
        opacity: 0.65;
    }
    50% {
        transform: translate3d(-8px, -32px, 0);
        opacity: 0.4;
    }
    75% {
        transform: translate3d(-14px, 8px, 0);
        opacity: 0.55;
    }
}

.reel-showcase-inner {
    position: relative;
    z-index: 1;
}

.reel-showcase__header .section__title {
    color: var(--text-heading);
}

.reel-showcase__intro {
    max-width: 38rem;
    margin-inline: auto;
    color: rgba(var(--rgb-brand-ink), 0.65);
    line-height: 1.65;
}

.reel-showcase-slider-shell {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    grid-template-areas:
        "view view"
        "prev next";
    gap: 1rem 0.75rem;
    align-items: center;
    max-width: min(88rem, 100%);
    margin-inline: auto;
    margin-top: clamp(1.5rem, 3.5vw, 2.5rem);
}

.reel-showcase-slider__viewport {
    grid-area: view;
    min-width: 0;
    padding-block: 0.5rem;
}

.reel-showcase-slider__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    padding: 0;
    border-radius: 50%;
    border: 1px solid rgba(var(--rgb-text-dark), 0.1);
    background: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(10px);
    color: var(--footer-navy);
    cursor: pointer;
    box-shadow:
        0 4px 18px rgba(var(--rgb-teal-deep), 0.1),
        0 1px 0 rgba(255, 255, 255, 0.9) inset;
    transition:
        background 0.3s cubic-bezier(0.22, 1, 0.36, 1),
        color 0.3s ease,
        border-color 0.3s ease,
        box-shadow 0.3s ease,
        transform 0.25s ease;
}

.reel-showcase-slider__btn:hover {
    background: var(--btn-primary-bg);
    color: #fff;
    border-color: var(--btn-primary-bg);
    box-shadow: 0 8px 28px rgba(var(--rgb-teal-deep), 0.28);
    transform: scale(1.05);
}

.reel-showcase-slider__btn:focus-visible {
    outline: 2px solid var(--footer-blue);
    outline-offset: 3px;
}

.reel-showcase-slider__btn--prev {
    grid-area: prev;
    justify-self: end;
}

.reel-showcase-slider__btn--next {
    grid-area: next;
    justify-self: start;
}

@media (min-width: 768px) {
    .reel-showcase-slider-shell {
        grid-template-columns: auto minmax(0, 1fr) auto;
        grid-template-rows: auto;
        grid-template-areas: "prev view next";
        gap: 0 1rem;
    }

    .reel-showcase-slider__btn--prev,
    .reel-showcase-slider__btn--next {
        justify-self: center;
    }
}

.reel-showcase-swiper {
    overflow: visible;
}

.reel-showcase-swiper .swiper-wrapper {
    transition-timing-function: cubic-bezier(0.33, 1, 0.68, 1);
}

.reel-showcase-swiper .swiper-slide {
    height: auto;
    display: flex;
    justify-content: center;
    align-items: stretch;
    box-sizing: border-box;
}

/* —— Card —— */
.reel-showcase-card {
    --reel-stagger: 0s;
    position: relative;
    width: 100%;
    max-width: 17.5rem;
    margin-inline: auto;
    perspective: 1100px;
    transform-style: preserve-3d;
    opacity: 0;
    transform: translate3d(0, 18px, 0);
    animation: reel-card-enter 0.85s cubic-bezier(0.22, 1, 0.36, 1) var(--reel-stagger) forwards;
}

@keyframes reel-card-enter {
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

.reel-showcase-card__float {
    animation: reel-card-idle-float 7s ease-in-out infinite;
    animation-delay: calc(var(--reel-stagger) + 0.4s);
}

@keyframes reel-card-idle-float {
    0%,
    100% {
        transform: translate3d(0, 0, 0);
    }
    50% {
        transform: translate3d(0, -5px, 0);
    }
}

.reel-showcase-card__frame {
    position: relative;
    padding: 2px;
    border-radius: clamp(16px, 2.2vw, 20px);
    background: linear-gradient(
        125deg,
        #0f7c8a,
        #1fa2c1,
        #4caf50,
        #2196f3,
        #26c6da,
        #0f7c8a
    );
    background-size: 320% 320%;
    animation: reel-border-flow 7s ease infinite;
    box-shadow:
        0 16px 48px rgba(var(--rgb-teal-deep), 0.14),
        0 4px 16px rgba(var(--rgb-brand-ink), 0.08);
    transition:
        box-shadow 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        filter 0.45s ease,
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes reel-border-flow {
    0%,
    100% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
}

.reel-showcase-card__hit {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    border: 0;
    cursor: pointer;
    border-radius: calc(clamp(16px, 2.2vw, 20px) - 2px);
    background: transparent;
    text-align: left;
    transform-style: preserve-3d;
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.reel-showcase-card__hit:focus-visible {
    outline: 2px solid var(--footer-blue);
    outline-offset: 4px;
}

.reel-showcase-card__glass {
    position: relative;
    border-radius: calc(clamp(16px, 2.2vw, 20px) - 2px);
    overflow: hidden;
    aspect-ratio: 9 / 16;
    background:
        linear-gradient(165deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.04) 100%),
        rgba(6, 24, 28, 0.35);
    backdrop-filter: blur(14px);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.reel-showcase-card__media {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    background: #0a1214;
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

@media (hover: hover) and (pointer: fine) {
    .reel-showcase-card:hover .reel-showcase-card__media {
        transform: scale(1.03);
    }
}

.reel-showcase-card__scrim {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(var(--rgb-brand-ink), 0.45) 100%);
    pointer-events: none;
    opacity: 0.85;
    transition: opacity 0.35s ease;
}

.reel-showcase-card__hit:hover .reel-showcase-card__scrim {
    opacity: 1;
}

.reel-showcase-card__play {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.35);
    backdrop-filter: blur(12px);
    color: #fff;
    box-shadow:
        0 8px 32px rgba(0, 0, 0, 0.25),
        0 0 0 1px rgba(255, 255, 255, 0.08) inset;
    transition:
        transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.35s ease,
        background 0.35s ease;
    animation: reel-play-pulse 2.8s ease-in-out infinite;
    pointer-events: none;
}

.reel-showcase-card__play svg {
    margin-left: 3px;
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));
}

@keyframes reel-play-pulse {
    0%,
    100% {
        box-shadow:
            0 8px 32px rgba(0, 0, 0, 0.25),
            0 0 0 0 rgba(var(--rgb-teal-bright), 0.35),
            0 0 0 1px rgba(255, 255, 255, 0.08) inset;
    }
    50% {
        box-shadow:
            0 8px 32px rgba(0, 0, 0, 0.28),
            0 0 0 12px rgba(var(--rgb-teal-bright), 0),
            0 0 0 1px rgba(255, 255, 255, 0.12) inset;
    }
}

@media (hover: hover) and (pointer: fine) {
    .reel-showcase-card:hover .reel-showcase-card__frame {
        box-shadow:
            0 28px 64px rgba(var(--rgb-teal-deep), 0.22),
            0 12px 28px rgba(var(--rgb-teal-bright), 0.12),
            0 0 40px rgba(var(--rgb-teal-bright), 0.15);
        filter: brightness(1.06) saturate(1.05);
        animation-duration: 4.5s;
    }

    .reel-showcase-card:hover .reel-showcase-card__hit {
        transform: scale(1.06) rotateX(2deg) rotateY(-3.5deg) translateZ(12px);
    }

    .reel-showcase-card:hover .reel-showcase-card__play {
        transform: translate(-50%, -50%) scale(1.08);
        background: rgba(255, 255, 255, 0.24);
        box-shadow:
            0 12px 40px rgba(0, 0, 0, 0.35),
            0 0 28px rgba(var(--rgb-teal-bright), 0.35),
            0 0 0 1px rgba(255, 255, 255, 0.2) inset;
    }
}

.reel-showcase-slider__pagination {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.4rem;
    min-height: 1.4rem;
    margin-top: clamp(1.25rem, 2.8vw, 1.75rem);
}

.reel-showcase-slider__pagination .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    margin: 0 3px !important;
    background: var(--brand-teal-deep);
    opacity: 0.28;
    transition:
        opacity 0.3s ease,
        transform 0.3s ease,
        background 0.3s ease;
}

.reel-showcase-slider__pagination .swiper-pagination-bullet-active {
    opacity: 1;
    transform: scale(1.15);
    background: var(--brand-teal-bright);
}

.reel-showcase__empty {
    max-width: 36rem;
    margin: clamp(1.25rem, 3vw, 2rem) auto 0;
    color: rgba(var(--rgb-brand-ink), 0.65);
    line-height: 1.65;
}

.reel-showcase__cta {
    margin-top: clamp(2rem, 3.5vw, 2.75rem);
}

.reel-showcase__follow-btn {
    margin-inline: auto;
}

.reel-showcase__handle {
    margin: 0.85rem 0 0;
    font-family: var(--font-display);
    font-size: 0.9375rem;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.reel-showcase__handle a {
    color: var(--brand-teal-deep);
    text-decoration: none;
    transition: color 0.2s ease;
}

.reel-showcase__handle a:hover {
    color: var(--brand-teal-bright);
    text-decoration: underline;
}

/* —— Modal —— */
/* Closed = display:none so nothing paints (visibility:hidden still left a flex layer + video chrome visible in some browsers). */
/* Open: flex layout. Do not animate opacity on the modal root — it flattens <video>. Fade only the backdrop. */
.reel-showcase-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 99990;
    align-items: center;
    justify-content: center;
    padding: clamp(1rem, 4vw, 2rem);
}

.reel-showcase-modal.is-open {
    display: flex;
}

.reel-showcase-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(var(--rgb-brand-ink), 0.82);
    opacity: 0;
    transition: opacity 0.38s cubic-bezier(0.22, 1, 0.36, 1);
}

.reel-showcase-modal.is-open .reel-showcase-modal__backdrop {
    opacity: 1;
}

.reel-showcase-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(22rem, 100%);
    padding-top: 0.25rem;
    max-height: min(90vh, 52rem);
    opacity: 1;
    transform: none;
}

.reel-showcase-modal__close {
    position: absolute;
    top: 0.65rem;
    right: 0.65rem;
    z-index: 5;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.25);
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition:
        background 0.25s ease,
        transform 0.25s ease;
}

.reel-showcase-modal__close:hover {
    background: rgba(255, 255, 255, 0.22);
    transform: scale(1.06);
}

.reel-showcase-modal__close:focus-visible {
    outline: 2px solid var(--footer-blue);
    outline-offset: 2px;
}

.reel-showcase-modal__stage {
    position: relative;
    border-radius: clamp(14px, 2vw, 18px);
    overflow: hidden;
    aspect-ratio: 9 / 16;
    background: #050a0c;
    isolation: isolate;
    box-shadow:
        0 24px 80px rgba(0, 0, 0, 0.55),
        0 0 0 1px rgba(255, 255, 255, 0.08);
    transform: translateZ(0);
}

.reel-showcase-modal__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    min-width: 100%;
    min-height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    z-index: 3;
    opacity: 1;
    background: #000;
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
}

.reel-showcase-modal__embed {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: none;
    background: #000;
}

.reel-showcase-modal__embed.is-visible {
    display: block;
    z-index: 4;
}

.reel-showcase-modal__iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

.reel-showcase-modal__fallback {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.25rem;
    padding: 1.5rem;
    text-align: center;
    background: linear-gradient(160deg, rgba(var(--rgb-teal-deep), 0.2), rgba(var(--rgb-brand-ink), 0.5));
    color: rgba(255, 255, 255, 0.92);
}

.reel-showcase-modal__fallback.is-visible {
    display: flex;
    z-index: 4;
}

.reel-showcase-modal__fallback:not(.is-visible) {
    pointer-events: none;
}

.reel-showcase-modal__fallback p {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.78);
}

.reel-showcase-modal__fallback .btn {
    margin-top: 0.25rem;
}

body.reel-showcase-modal-open {
    overflow: hidden;
}

@media (prefers-reduced-motion: reduce) {
    .reel-showcase-section__particles span,
    .reel-showcase-card__float,
    .reel-showcase-card__frame,
    .reel-showcase-card__play {
        animation: none;
    }

    .reel-showcase-card {
        opacity: 1;
        transform: none;
        animation: none;
    }

    .reel-showcase-swiper .swiper-wrapper {
        transition-duration: 0.01ms !important;
    }

    @media (hover: hover) {
        .reel-showcase-card:hover .reel-showcase-card__hit {
            transform: none;
        }
    }
}
