/* ═══════════════════════════════════════════════════
   vCuestore Testimonials – Framer-Style CSS
   ═══════════════════════════════════════════════════ */

/* ── Framer Spring Animations ── */
@keyframes vcuetFadeUp { from{opacity:0;transform:translateY(32px)} to{opacity:1;transform:translateY(0)} }
@keyframes vcuetFadeIn { from{opacity:0} to{opacity:1} }
@keyframes vcuetScaleIn { from{opacity:0;transform:scale(0.92)} to{opacity:1;transform:scale(1)} }
@keyframes vcuetSlideUp { from{opacity:0;transform:translateY(60px) scale(0.96)} to{opacity:1;transform:translateY(0) scale(1)} }
@keyframes vcuetShimmer { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
@keyframes vcuetPulse { 0%,100%{box-shadow:0 0 0 0 var(--vcuet-accent-glow)} 50%{box-shadow:0 0 0 12px transparent} }
@keyframes vcuetMarquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
@keyframes vcuetFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }

/* Scroll-triggered animation classes */
[data-vcuet-anim] { opacity:0; }
[data-vcuet-anim="fade-up"] { transform:translateY(32px); }
[data-vcuet-anim="scale-in"] { transform:scale(0.92); }
[data-vcuet-anim="slide-up"] { transform:translateY(60px) scale(0.96); }
[data-vcuet-anim="fade-in"] { transform:none; }

[data-vcuet-anim].vcuet-visible {
    opacity:1 !important; transform:none !important;
    transition: opacity 0.75s cubic-bezier(0.16,1,0.3,1) var(--anim-delay,0s),
                transform 0.75s cubic-bezier(0.16,1,0.3,1) var(--anim-delay,0s);
}

/* ── Base Wrapper ── */
.vcuet-wrap { background:var(--vcuet-bg); color:var(--vcuet-text); font-family:var(--vcuet-bfont); padding:48px 0; overflow:hidden; position:relative; }
.vcuet-wrap *,.vcuet-wrap *::before,.vcuet-wrap *::after { box-sizing:border-box; margin:0; padding:0; }

/* ── Stats Bar ── */
.vcuet-stats-bar { display:flex; align-items:center; justify-content:center; gap:18px; padding:12px 24px; flex-wrap:wrap; margin-bottom:28px; }
.vcuet-rating-chip { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--vcuet-muted); font-family:var(--vcuet-bfont); }
.vcuet-stars-sm { display:flex; gap:1px; color:var(--vcuet-accent); }
.vcuet-val { font-weight:700; color:var(--vcuet-accent); font-family:var(--vcuet-hfont); }
.vcuet-dot-sep { width:4px; height:4px; border-radius:50%; background:var(--vcuet-muted); }

/* ── Header ── */
.vcuet-header { text-align:center; max-width:640px; margin:0 auto 36px; padding:0 20px; }
.vcuet-eyebrow { text-transform:uppercase; font-size:11px; letter-spacing:3px; color:var(--vcuet-accent); font-weight:600; margin-bottom:10px; font-family:var(--vcuet-bfont); }
.vcuet-header h2 { font-family:var(--vcuet-hfont); font-size:clamp(28px,4vw,44px); font-weight:800; line-height:1.15; margin-bottom:12px; background:linear-gradient(135deg, var(--vcuet-text) 0%, var(--vcuet-accent) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.vcuet-header p { color:var(--vcuet-muted); font-size:15px; line-height:1.6; }

/* ── Shared Components ── */
.vcuet-stars-lg { display:flex; gap:2px; color:var(--vcuet-accent); margin-bottom:10px; }
.vcuet-stars-lg svg { width:16px; height:16px; filter:drop-shadow(0 0 4px var(--vcuet-accent-glow)); }
.vcuet-quote { font-style:italic; font-size:15px; line-height:1.65; color:var(--vcuet-text); opacity:0.88; margin-bottom:16px; font-weight:300; }
.vcuet-accent-line { width:36px; height:2px; background:linear-gradient(90deg,var(--vcuet-accent),transparent); margin-bottom:14px; border-radius:2px; }
.vcuet-author-row { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.vcuet-avatar { width:40px; height:40px; border-radius:50%; background:linear-gradient(135deg,var(--vcuet-accent),var(--vcuet-accent2)); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:16px; color:#fff; flex-shrink:0; }
.vcuet-avatar-img { width:40px; height:40px; border-radius:50%; object-fit:cover; border:2px solid var(--vcuet-accent-dim); flex-shrink:0; }
.vcuet-name { font-weight:600; font-size:14px; font-family:var(--vcuet-hfont); }
.vcuet-biz-loc { font-size:12px; color:var(--vcuet-muted); margin-top:2px; }
.vcuet-biz-type { font-size:11px; padding:4px 10px; border-radius:20px; background:var(--vcuet-accent-dim); color:var(--vcuet-accent); font-weight:500; }
.vcuet-result-badge { font-size:11px; padding:4px 10px; border-radius:20px; background:rgba(34,197,94,0.12); color:#22c55e; font-weight:600; }
.vcuet-stat-row { display:flex; gap:16px; flex-wrap:wrap; }
.vcuet-stat { display:flex; flex-direction:column; font-size:11px; color:var(--vcuet-muted); }
.vcuet-stat strong { font-size:18px; font-weight:800; font-family:var(--vcuet-hfont); color:var(--vcuet-accent); line-height:1.2; }
.vcuet-meta-top { display:flex; gap:8px; align-items:center; margin-bottom:10px; flex-wrap:wrap; }

/* ── Nav / Dots / Arrows ── */
.vcuet-nav { display:flex; align-items:center; justify-content:space-between; padding:16px 24px 0; }
.vcuet-nav-left { display:flex; align-items:center; gap:14px; }
.vcuet-dots { display:flex; gap:6px; }
.vcuet-dot { width:8px; height:8px; border-radius:50%; border:none; background:var(--vcuet-muted); cursor:pointer; padding:0; transition:all 0.4s cubic-bezier(0.16,1,0.3,1); }
.vcuet-dot-active { background:var(--vcuet-accent); width:24px; border-radius:4px; box-shadow:0 0 8px var(--vcuet-accent-glow); }
.vcuet-counter { font-size:12px; color:var(--vcuet-muted); font-variant-numeric:tabular-nums; }
.vcuet-arrows { display:flex; gap:8px; }
.vcuet-arrow { width:36px; height:36px; border-radius:50%; border:1px solid rgba(255,255,255,0.1); background:rgba(255,255,255,0.04); color:var(--vcuet-text); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.3s cubic-bezier(0.16,1,0.3,1); backdrop-filter:blur(8px); }
.vcuet-arrow:hover { background:var(--vcuet-accent); border-color:var(--vcuet-accent); color:#fff; transform:scale(1.1); }
.vcuet-progress-bar { height:2px; background:rgba(255,255,255,0.06); margin:16px 24px 0; border-radius:2px; overflow:hidden; }
.vcuet-progress-fill { height:100%; background:linear-gradient(90deg,var(--vcuet-accent),var(--vcuet-accent2)); border-radius:2px; transition:width 0.7s cubic-bezier(0.16,1,0.3,1); }

/* ── Play Button ── */
.vcuet-play-wrap { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.vcuet-play-ring { width:56px; height:56px; border-radius:50%; background:rgba(0,0,0,0.5); backdrop-filter:blur(12px); border:2px solid rgba(255,255,255,0.25); display:flex; align-items:center; justify-content:center; padding-left:3px; transition:all 0.4s cubic-bezier(0.16,1,0.3,1); animation:vcuetPulse 2.5s ease infinite; }
.vcuet-play-ring:hover { transform:scale(1.12); background:var(--vcuet-accent); border-color:var(--vcuet-accent); }
.vcuet-yt-tag { position:absolute; top:12px; right:12px; display:flex; align-items:center; gap:5px; font-size:11px; padding:5px 10px; border-radius:6px; background:rgba(0,0,0,0.6); backdrop-filter:blur(8px); color:#fff; }
.vcuet-thumb-meta { position:absolute; bottom:0; left:0; right:0; padding:10px 14px; display:flex; justify-content:space-between; font-size:11px; color:rgba(255,255,255,0.7); background:linear-gradient(transparent,rgba(0,0,0,0.6)); }
.vcuet-no-video { display:flex; align-items:center; justify-content:center; height:100%; background:rgba(255,255,255,0.03); color:var(--vcuet-muted); font-size:13px; }

/* ── Modal ── */
.vcuet-modal { display:none; position:fixed; inset:0; z-index:999999; background:rgba(0,0,0,0.85); backdrop-filter:blur(16px); align-items:center; justify-content:center; }
.vcuet-modal-open { display:flex; animation:vcuetFadeIn 0.3s ease; }
.vcuet-modal-inner { width:90%; max-width:900px; position:relative; }
.vcuet-modal-close { position:absolute; top:-40px; right:0; background:none; border:none; color:#fff; font-size:22px; cursor:pointer; width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center; transition:all 0.3s; }
.vcuet-modal-close:hover { background:rgba(255,255,255,0.2); transform:scale(1.1); }
.vcuet-modal-video { position:relative; padding-top:56.25%; border-radius:12px; overflow:hidden; box-shadow:0 24px 80px rgba(0,0,0,0.5); }
.vcuet-modal-video iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }

/* ════════════════════════════════════════════════════
   STYLE 1: CINEMATIC SPLIT
   ════════════════════════════════════════════════════ */
.vcuet-style-cinematic .vcuet-slider-wrap { padding:0 24px; max-width:1200px; margin:0 auto; }
.vcuet-style-cinematic .vcuet-slider-track { overflow:hidden; border-radius:16px; }
.vcuet-style-cinematic .vcuet-slides { display:flex; transition:transform 0.7s cubic-bezier(0.16,1,0.3,1); }
.vcuet-style-cinematic .vcuet-slide { min-width:100%; display:grid; grid-template-columns:1fr 1fr; gap:0; background:rgba(255,255,255,0.02); border:1px solid rgba(255,255,255,0.06); border-radius:16px; overflow:hidden; }
.vcuet-style-cinematic .vcuet-video-side { position:relative; aspect-ratio:16/10; overflow:hidden; }
.vcuet-style-cinematic .vcuet-thumb { width:100%; height:100%; object-fit:cover; transition:transform 0.6s cubic-bezier(0.16,1,0.3,1); }
.vcuet-style-cinematic .vcuet-video-side:hover .vcuet-thumb { transform:scale(1.05); }
.vcuet-style-cinematic .vcuet-info-side { padding:32px 28px; display:flex; flex-direction:column; justify-content:center; background:linear-gradient(135deg, rgba(255,255,255,0.03) 0%, rgba(255,255,255,0.01) 100%); backdrop-filter:blur(20px); }
@media(max-width:768px){
    .vcuet-style-cinematic .vcuet-slide { grid-template-columns:1fr; }
    .vcuet-style-cinematic .vcuet-video-side { aspect-ratio:16/9; }
    .vcuet-style-cinematic .vcuet-info-side { padding:20px; }
}

/* ════════════════════════════════════════════════════
   STYLE 2: CARD CAROUSEL
   ════════════════════════════════════════════════════ */
.vcuet-style-carousel .vcuet-carousel-wrap { max-width:1200px; margin:0 auto; padding:0 24px; }
.vcuet-style-carousel .vcuet-carousel-track { display:flex; gap:20px; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; padding:20px 0; -webkit-overflow-scrolling:touch; }
.vcuet-style-carousel .vcuet-carousel-track::-webkit-scrollbar { display:none; }
.vcuet-style-carousel .vcuet-carousel-card { min-width:320px; max-width:360px; flex-shrink:0; scroll-snap-align:center; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:16px; overflow:hidden; transition:transform 0.5s cubic-bezier(0.16,1,0.3,1), box-shadow 0.5s ease; will-change:transform; }
.vcuet-style-carousel .vcuet-carousel-card:hover { box-shadow:0 20px 60px rgba(0,0,0,0.3), 0 0 0 1px var(--vcuet-accent-dim); }
.vcuet-style-carousel .vcuet-cc-video { position:relative; aspect-ratio:16/9; overflow:hidden; }
.vcuet-style-carousel .vcuet-cc-video img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s cubic-bezier(0.16,1,0.3,1); }
.vcuet-style-carousel .vcuet-carousel-card:hover .vcuet-cc-video img { transform:scale(1.06); }
.vcuet-style-carousel .vcuet-cc-body { padding:20px; }
.vcuet-style-carousel .vcuet-carousel-nav { display:flex; align-items:center; justify-content:center; gap:16px; padding:20px 0; }

/* ════════════════════════════════════════════════════
   STYLE 3: STACKED CARDS
   ════════════════════════════════════════════════════ */
.vcuet-style-stack .vcuet-stack-wrap { max-width:700px; margin:0 auto; padding:0 24px; position:relative; min-height:400px; }
.vcuet-style-stack .vcuet-stack-card { position:absolute; top:0; left:24px; right:24px; transition:all 0.65s cubic-bezier(0.16,1,0.3,1); pointer-events:none; }
.vcuet-style-stack .vcuet-stack-card.vcuet-stack-active { pointer-events:auto; }
.vcuet-style-stack .vcuet-stack-inner { background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:20px; overflow:hidden; display:grid; grid-template-columns:1fr 1fr; }
.vcuet-style-stack .vcuet-stack-video { position:relative; aspect-ratio:1; overflow:hidden; }
.vcuet-style-stack .vcuet-stack-video img { width:100%; height:100%; object-fit:cover; }
.vcuet-style-stack .vcuet-stack-content { padding:28px; display:flex; flex-direction:column; justify-content:center; }
.vcuet-style-stack .vcuet-stack-nav { position:relative; display:flex; align-items:center; justify-content:center; gap:20px; margin-top:420px; padding:20px 0; }
@media(max-width:640px){
    .vcuet-style-stack .vcuet-stack-inner { grid-template-columns:1fr; }
    .vcuet-style-stack .vcuet-stack-video { aspect-ratio:16/9; }
    .vcuet-style-stack .vcuet-stack-nav { margin-top:520px; }
}

/* ════════════════════════════════════════════════════
   STYLE 4: INFINITE MARQUEE
   ════════════════════════════════════════════════════ */
.vcuet-style-marquee .vcuet-marquee-wrap { overflow:hidden; padding:20px 0; position:relative; }
.vcuet-style-marquee .vcuet-marquee-wrap::before,
.vcuet-style-marquee .vcuet-marquee-wrap::after { content:''; position:absolute; top:0; bottom:0; width:80px; z-index:2; pointer-events:none; }
.vcuet-style-marquee .vcuet-marquee-wrap::before { left:0; background:linear-gradient(90deg,var(--vcuet-bg),transparent); }
.vcuet-style-marquee .vcuet-marquee-wrap::after { right:0; background:linear-gradient(-90deg,var(--vcuet-bg),transparent); }
.vcuet-style-marquee .vcuet-marquee-track { display:flex; gap:20px; width:max-content; will-change:transform; }
.vcuet-style-marquee .vcuet-marquee-card { width:320px; flex-shrink:0; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:16px; padding:24px; transition:all 0.4s cubic-bezier(0.16,1,0.3,1); }
.vcuet-style-marquee .vcuet-marquee-card:hover { background:rgba(255,255,255,0.07); border-color:var(--vcuet-accent-dim); transform:translateY(-4px); box-shadow:0 16px 48px rgba(0,0,0,0.2); }
.vcuet-style-marquee .vcuet-mc-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.vcuet-style-marquee .vcuet-mc-play { display:flex; align-items:center; gap:6px; padding:8px 16px; border-radius:8px; border:1px solid var(--vcuet-accent-dim); background:transparent; color:var(--vcuet-accent); font-size:12px; font-weight:500; cursor:pointer; margin-top:12px; transition:all 0.3s cubic-bezier(0.16,1,0.3,1); font-family:var(--vcuet-bfont); }
.vcuet-style-marquee .vcuet-mc-play:hover { background:var(--vcuet-accent); color:#fff; }

/* ════════════════════════════════════════════════════
   STYLE 5: SPOTLIGHT GRID
   ════════════════════════════════════════════════════ */
.vcuet-style-spotlight .vcuet-spotlight-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:20px; max-width:1200px; margin:0 auto; padding:0 24px; }
.vcuet-style-spotlight .vcuet-spotlight-card { background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06); border-radius:16px; overflow:hidden; transition:all 0.5s cubic-bezier(0.16,1,0.3,1); position:relative; }
.vcuet-style-spotlight .vcuet-spotlight-card:hover { border-color:var(--vcuet-accent-dim); box-shadow:0 20px 60px rgba(0,0,0,0.25), 0 0 0 1px var(--vcuet-accent-dim); transform:translateY(-4px); z-index:2; }
.vcuet-style-spotlight .vcuet-sg-thumb { position:relative; aspect-ratio:16/9; overflow:hidden; }
.vcuet-style-spotlight .vcuet-sg-thumb img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s cubic-bezier(0.16,1,0.3,1); }
.vcuet-style-spotlight .vcuet-spotlight-card:hover .vcuet-sg-thumb img { transform:scale(1.08); }
.vcuet-style-spotlight .vcuet-sg-thumb .vcuet-biz-type { position:absolute; top:12px; left:12px; }
.vcuet-style-spotlight .vcuet-sg-body { padding:20px; }
.vcuet-style-spotlight .vcuet-sg-expand { max-height:0; overflow:hidden; padding:0 20px; transition:all 0.5s cubic-bezier(0.16,1,0.3,1); }
.vcuet-style-spotlight .vcuet-spotlight-card.vcuet-spotlight-hover .vcuet-sg-expand { max-height:200px; padding:0 20px 20px; }
.vcuet-style-spotlight .vcuet-quote-full { font-style:italic; font-size:13px; line-height:1.6; color:var(--vcuet-text); opacity:0.8; margin-bottom:12px; }

/* ════════════════════════════════════════════════════
   STYLE 6: MINIMAL FADE
   ════════════════════════════════════════════════════ */
.vcuet-style-minimal .vcuet-minimal-wrap { max-width:700px; margin:0 auto; padding:0 24px; position:relative; min-height:280px; }
.vcuet-style-minimal .vcuet-minimal-slide { position:absolute; inset:0; opacity:0; transform:translateY(16px); pointer-events:none; transition:opacity 0.7s cubic-bezier(0.16,1,0.3,1), transform 0.7s cubic-bezier(0.16,1,0.3,1); padding:0 24px; }
.vcuet-style-minimal .vcuet-minimal-slide.vcuet-minimal-active { opacity:1; transform:translateY(0); pointer-events:auto; position:relative; }
.vcuet-style-minimal .vcuet-minimal-inner { text-align:center; padding:40px; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06); border-radius:20px; backdrop-filter:blur(16px); }
.vcuet-style-minimal .vcuet-minimal-quote-mark { font-size:64px; font-family:var(--vcuet-hfont); color:var(--vcuet-accent); opacity:0.3; line-height:1; margin-bottom:-10px; }
.vcuet-style-minimal .vcuet-minimal-text { font-size:18px; line-height:1.7; font-weight:300; font-style:italic; color:var(--vcuet-text); margin-bottom:20px; }
.vcuet-style-minimal .vcuet-minimal-divider { width:40px; height:2px; background:var(--vcuet-accent); margin:0 auto 20px; border-radius:2px; }
.vcuet-style-minimal .vcuet-minimal-author { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; }
.vcuet-style-minimal .vcuet-minimal-author .vcuet-stars-lg { margin-bottom:0; margin-left:auto; }
.vcuet-style-minimal .vcuet-minimal-play { display:inline-flex; align-items:center; gap:8px; padding:10px 20px; border-radius:10px; border:1px solid var(--vcuet-accent-dim); background:transparent; color:var(--vcuet-accent); font-size:13px; cursor:pointer; margin-top:20px; transition:all 0.3s cubic-bezier(0.16,1,0.3,1); font-family:var(--vcuet-bfont); }
.vcuet-style-minimal .vcuet-minimal-play:hover { background:var(--vcuet-accent); color:#fff; transform:scale(1.05); }
.vcuet-style-minimal .vcuet-minimal-nav { position:relative; display:flex; align-items:center; justify-content:center; gap:16px; padding:20px 0; margin-top:20px; }

/* ── Responsive ── */
@media(max-width:480px){
    .vcuet-wrap { padding:28px 0; }
    .vcuet-header h2 { font-size:24px; }
    .vcuet-style-carousel .vcuet-carousel-card { min-width:280px; }
    .vcuet-style-minimal .vcuet-minimal-inner { padding:24px; }
    .vcuet-style-minimal .vcuet-minimal-text { font-size:15px; }
}
