/**
 * Belle Maison v4 — Componentes portados de 21st.dev
 * Fuente: https://github.com/serafimcloud/21st
 * Adaptados de React/Tailwind a CSS/JS vanilla para WordPress
 *
 * Componentes incluidos:
 * - ShimmerButton        → .bm-btn-shimmer
 * - HeroPill             → .bm-hero-pill
 * - TextShimmer          → .bm-text-shimmer
 * - AuroraBackground     → .bm-aurora-bg
 * - HeroVideoDialog      → .bm-video-dialog
 * - LoadingSpinner       → .bm-spinner
 * - Badge                → .bm-badge-21
 */

/* ============================================================
   SHIMMER BUTTON — 21st.dev ShimmerButton portado a CSS
   ============================================================ */
.bm-btn-shimmer {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 36px;
    font-family: var(--bm-font-body);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--bm-white);
    background: var(--bm-charcoal);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 4px;
    overflow: hidden;
    cursor: pointer;
    white-space: nowrap;
    z-index: 0;
    transition: transform 0.3s ease;
}
.bm-btn-shimmer:active { transform: translateY(1px); }

/* Shimmer rotating conic gradient */
.bm-btn-shimmer::before {
    content: '';
    position: absolute;
    inset: -100%;
    background: conic-gradient(
        from 270deg,
        transparent 0deg,
        var(--bm-gold) 90deg,
        transparent 90deg
    );
    animation: bm-shimmer-spin 3s linear infinite;
    z-index: -2;
    filter: blur(2px);
}
/* Inner backdrop to clip the shimmer */
.bm-btn-shimmer::after {
    content: '';
    position: absolute;
    inset: 1.5px;
    background: var(--bm-charcoal);
    border-radius: 3px;
    z-index: -1;
    box-shadow: inset 0 -8px 10px rgba(255,255,255,0.08);
    transition: box-shadow 0.3s ease;
}
.bm-btn-shimmer:hover::after {
    box-shadow: inset 0 -6px 10px rgba(255,255,255,0.18);
}
@keyframes bm-shimmer-spin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* Gold variant */
.bm-btn-shimmer-gold {
    background: linear-gradient(135deg, var(--bm-gold-dark), #8a6020);
    border-color: rgba(201,169,110,0.3);
}
.bm-btn-shimmer-gold::before {
    background: conic-gradient(
        from 270deg,
        transparent 0deg,
        rgba(255,255,255,0.9) 90deg,
        transparent 90deg
    );
}
.bm-btn-shimmer-gold::after {
    background: linear-gradient(135deg, var(--bm-gold-dark), #8a6020);
}

/* ============================================================
   HERO PILL — 21st.dev HeroPill portado
   ============================================================ */
.bm-hero-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 6px 16px;
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(1px);
    -webkit-backdrop-filter: blur(1px);
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.15);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: var(--bm-white);
    white-space: nowrap;
    cursor: default;
    transition: background 0.2s ease;
    animation: bm-slide-up-fade 0.6s ease-out both;
}
.bm-hero-pill:hover {
    background: rgba(255,255,255,0.18);
}
.bm-hero-pill-icon {
    display: inline-flex;
    align-items: center;
    border-right: 1px solid rgba(255,255,255,0.2);
    padding-right: 8px;
    margin-right: 0;
}
.bm-hero-pill-icon svg { width: 12px; height: 12px; fill: var(--bm-gold); }

/* Gold pill variant */
.bm-hero-pill-gold {
    background: rgba(201,169,110,0.15);
    border-color: rgba(201,169,110,0.35);
    color: var(--bm-gold-light);
}
.bm-hero-pill-gold:hover { background: rgba(201,169,110,0.25); }

@keyframes bm-slide-up-fade {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   TEXT SHIMMER — 21st.dev TextShimmer portado a CSS puro
   ============================================================ */
.bm-text-shimmer {
    display: inline-block;
    background-size: 250% 100%, auto;
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    background-image:
        linear-gradient(
            90deg,
            transparent calc(50% - var(--bm-shimmer-spread, 80px)),
            var(--bm-gold-light) 50%,
            transparent calc(50% + var(--bm-shimmer-spread, 80px))
        ),
        linear-gradient(var(--bm-gold), var(--bm-gold));
    background-repeat: no-repeat, padding-box;
    animation: bm-text-shimmer-slide 3s linear infinite;
}
@keyframes bm-text-shimmer-slide {
    from { background-position: 100% center; }
    to   { background-position: -100% center; }
}

/* White variant (para fondo oscuro) */
.bm-text-shimmer-white {
    background-image:
        linear-gradient(
            90deg,
            transparent calc(50% - 80px),
            rgba(255,255,255,0.9) 50%,
            transparent calc(50% + 80px)
        ),
        linear-gradient(rgba(255,255,255,0.5), rgba(255,255,255,0.5));
}

/* ============================================================
   AURORA BACKGROUND — 21st.dev AuroraBackground portado
   ============================================================ */
.bm-aurora-bg {
    position: relative;
    overflow: hidden;
    background: var(--bm-charcoal);
}
.bm-aurora-bg::before,
.bm-aurora-bg::after {
    content: '';
    position: absolute;
    inset: -10px;
    background-image:
        repeating-linear-gradient(
            100deg,
            transparent 0%,
            transparent 7%,
            transparent 10%,
            transparent 12%,
            transparent 16%
        ),
        repeating-linear-gradient(
            100deg,
            rgba(201,169,110,0.15) 10%,
            rgba(180,140,70,0.1)   20%,
            rgba(220,190,120,0.12) 35%,
            rgba(201,169,110,0.08) 50%,
            rgba(160,110,50,0.1)   65%,
            rgba(201,169,110,0.15) 80%
        );
    background-size: 300% 300%, 200% 200%;
    background-position: 50% 50%, 50% 50%;
    filter: blur(12px);
    opacity: 0.5;
    animation: bm-aurora-move 12s ease-in-out infinite alternate;
    pointer-events: none;
    will-change: background-position;
}
.bm-aurora-bg::after {
    background-size: 200% 200%, 100% 100%;
    animation-duration: 18s;
    animation-direction: alternate-reverse;
    mix-blend-mode: screen;
    opacity: 0.3;
}
@keyframes bm-aurora-move {
    0%   { background-position: 0% 50%, 0% 50%; }
    50%  { background-position: 100% 50%, 100% 50%; }
    100% { background-position: 0% 50%, 0% 50%; }
}

/* Radial mask para el efecto de esquina */
.bm-aurora-mask::before {
    mask-image: radial-gradient(ellipse at 100% 0%, black 10%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at 100% 0%, black 10%, transparent 70%);
}

/* ============================================================
   HERO VIDEO DIALOG — 21st.dev HeroVideoDialog portado
   ============================================================ */
.bm-video-dialog-trigger {
    position: relative;
    cursor: pointer;
    border-radius: var(--bm-radius-lg);
    overflow: hidden;
    display: block;
}
.bm-video-dialog-trigger img {
    width: 100%;
    transition: filter 0.25s ease;
}
.bm-video-dialog-trigger:hover img {
    filter: brightness(0.78);
}
.bm-video-play-btn {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.bm-video-play-ring {
    width: 80px;
    height: 80px;
    background: rgba(201,169,110,0.15);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.25s ease;
}
.bm-video-dialog-trigger:hover .bm-video-play-ring {
    transform: scale(1.1);
}
.bm-video-play-icon {
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, rgba(201,169,110,0.4), var(--bm-gold));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 20px rgba(0,0,0,0.25);
    transition: transform 0.25s ease;
}
.bm-video-dialog-trigger:hover .bm-video-play-icon {
    transform: scale(1.15);
}
.bm-video-play-icon svg {
    width: 22px; height: 22px;
    fill: white;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
    margin-left: 3px; /* optical centering for play triangle */
}

/* Modal overlay */
.bm-video-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9000;
    background: rgba(0,0,0,0.82);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    align-items: center;
    justify-content: center;
    padding: 24px;
}
.bm-video-modal.open {
    display: flex;
    animation: bm-modal-fade-in 0.3s ease;
}
.bm-video-modal-inner {
    position: relative;
    width: 100%;
    max-width: 900px;
    aspect-ratio: 16/9;
    border-radius: var(--bm-radius-lg);
    overflow: hidden;
    border: 2px solid rgba(255,255,255,0.15);
    box-shadow: 0 32px 80px rgba(0,0,0,0.6);
    animation: bm-modal-scale-in 0.35s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
}
.bm-video-modal-close {
    position: absolute;
    top: -48px;
    right: 0;
    width: 36px; height: 36px;
    background: rgba(255,255,255,0.12);
    backdrop-filter: blur(8px);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border: 1px solid rgba(255,255,255,0.2);
    color: white;
    font-size: 1.1rem;
    transition: background 0.2s ease;
}
.bm-video-modal-close:hover { background: rgba(255,255,255,0.25); }
.bm-video-modal-inner iframe,
.bm-video-modal-inner video {
    width: 100%;
    height: 100%;
    border: none;
    border-radius: var(--bm-radius-lg);
}
@keyframes bm-modal-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes bm-modal-scale-in {
    from { opacity: 0; transform: scale(0.85); }
    to   { opacity: 1; transform: scale(1); }
}

/* ============================================================
   LOADING SPINNER — 21st.dev LoadingSpinner portado
   ============================================================ */
.bm-spinner {
    display: inline-block;
    width: 20px; height: 20px;
    border: 2px solid rgba(201,169,110,0.25);
    border-top-color: var(--bm-gold);
    border-radius: 50%;
    animation: bm-spin 0.7s linear infinite;
}
.bm-spinner-sm { width: 14px; height: 14px; border-width: 1.5px; }
.bm-spinner-lg { width: 32px; height: 32px; border-width: 3px; }
.bm-spinner-white {
    border-color: rgba(255,255,255,0.25);
    border-top-color: rgba(255,255,255,0.9);
}
@keyframes bm-spin {
    to { transform: rotate(360deg); }
}

/* ============================================================
   BADGE 21st — pill badge elegante
   ============================================================ */
.bm-badge-21 {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border: 1px solid;
}
.bm-badge-21-gold {
    background: rgba(201,169,110,0.12);
    border-color: rgba(201,169,110,0.4);
    color: var(--bm-gold-dark);
}
.bm-badge-21-dark {
    background: var(--bm-charcoal);
    border-color: rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.7);
}
.bm-badge-21-white {
    background: rgba(255,255,255,0.1);
    border-color: rgba(255,255,255,0.25);
    color: rgba(255,255,255,0.85);
}

/* ============================================================
   REDUCED MOTION — desactivar todas las animaciones 21st
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
    .bm-btn-shimmer::before,
    .bm-text-shimmer,
    .bm-aurora-bg::before,
    .bm-aurora-bg::after,
    .bm-hero-pill { animation: none !important; }
}
