/* =========================================================
   VAIO Premium Banners — production compact pass
   Fixes homepage dead-space by styling vx promo/event sections.
   ========================================================= */
:root{
    --vx-bg:#070414;
    --vx-bg-2:#0b0820;
    --vx-ink:#f5f3ff;
    --vx-ink-dim:#b9b3d6;
    --vx-violet:#a855f7;
    --vx-cyan:#22d3ee;
    --vx-rose:#fb7185;
    --vx-amber:#fbbf24;
    --vx-lime:#a3e635;
    --vx-pink:#f472b6;
    --vx-sky:#38bdf8;
    --vx-orange:#fb923c;
    --vx-radius:22px;
    --vx-radius-sm:16px;
    --vx-shadow:0 18px 50px -20px rgba(168,85,247,.45),0 8px 24px -12px rgba(34,211,238,.35);
}

.vx-section{
    position:relative;
    padding:clamp(22px,3.4vw,46px) 0;
    margin:0;
    overflow:hidden;
    isolation:isolate;
}
.vx-container{
    width:100%;
    max-width:1400px;
    margin:0 auto;
    padding:0 24px;
}
.vx-section-head{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:18px;
    margin:0 0 18px;
}
.vx-eyebrow{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:8px 12px;
    border:1px solid rgba(168,85,247,.30);
    border-radius:999px;
    background:rgba(124,58,237,.12);
    color:#d8b4fe;
    font-size:12px;
    font-weight:900;
    letter-spacing:.06em;
    text-transform:uppercase;
}
.vx-pulse{
    width:8px;
    height:8px;
    border-radius:999px;
    background:var(--vx-cyan);
    box-shadow:0 0 16px rgba(34,211,238,.9);
    animation:vxPulse 1.8s ease-in-out infinite;
}
.vx-section-title{
    margin:10px 0 0;
    color:#fff;
    font-size:clamp(24px,3.1vw,42px);
    line-height:1.05;
    font-weight:950;
    text-shadow:0 0 28px rgba(124,58,237,.45);
}
@keyframes vxPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.72);opacity:.55}}

/* Promo deal cards: compact visual bridge after live activity, not a dead zone. */
.vx-promo{
    background:linear-gradient(180deg,rgba(124,58,237,.035),transparent 80%);
}
.vx-deals{
    position:relative;
}
.vx-deals-track{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:16px;
}
.vx-deal{
    position:relative;
    min-width:0;
    min-height:340px;
    border-radius:24px;
    overflow:hidden;
    border:1px solid rgba(168,85,247,.22);
    background:linear-gradient(180deg,rgba(16,10,37,.92),rgba(7,4,20,.96));
    box-shadow:var(--vx-shadow);
    transform:translateZ(0);
}
.vx-deal-media{
    position:absolute;
    inset:0;
}
.vx-deal-media img{
    width:100%;
    height:100%;
    object-fit:cover;
    transform:scale(1.02);
    filter:saturate(1.1) contrast(1.05);
}
.vx-deal-scrim{
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,transparent 25%,rgba(3,7,18,.48) 58%,rgba(3,7,18,.96) 100%);
}
.vx-deal-badge{
    position:absolute;
    top:14px;
    inset-inline-start:14px;
    z-index:2;
    padding:7px 11px;
    border-radius:999px;
    background:linear-gradient(135deg,#fb7185,#a855f7);
    color:#fff;
    font-size:12px;
    font-weight:950;
    box-shadow:0 10px 28px rgba(236,72,153,.32);
}
.vx-deal-body{
    position:absolute;
    z-index:2;
    inset-inline:0;
    bottom:0;
    padding:18px;
}
.vx-deal-title{
    margin:0 0 6px;
    color:#fff;
    font-size:18px;
    font-weight:950;
}
.vx-deal-sub{
    margin:0 0 13px;
    color:rgba(255,255,255,.72);
    font-size:13px;
    line-height:1.5;
}
.vx-deal-cta{
    display:inline-flex;
    align-items:center;
    gap:8px;
    min-height:38px;
    padding:0 14px;
    border-radius:12px;
    background:linear-gradient(135deg,#7c3aed,#22d3ee);
    color:#fff;
    font-weight:900;
    box-shadow:0 10px 26px rgba(124,58,237,.35);
}
.vx-deal-cta svg{width:14px;height:14px}
.vx-deal-glow{
    position:absolute;
    inset:auto -20% -20% -20%;
    height:45%;
    background:radial-gradient(ellipse at center,rgba(168,85,247,.44),transparent 68%);
    filter:blur(20px);
}
.vx-deal-particles span{position:absolute;width:5px;height:5px;border-radius:50%;background:rgba(34,211,238,.85);box-shadow:0 0 14px rgba(34,211,238,.9)}
.vx-deal-particles span:nth-child(1){left:18%;top:28%}.vx-deal-particles span:nth-child(2){left:62%;top:20%}.vx-deal-particles span:nth-child(3){left:82%;top:44%}.vx-deal-particles span:nth-child(4){left:24%;top:72%}.vx-deal-particles span:nth-child(5){left:54%;top:62%}.vx-deal-particles span:nth-child(6){left:72%;top:78%}
.vx-deals-dots{
    display:flex;
    justify-content:center;
    gap:8px;
    margin-top:14px;
}
.vx-deals-dot{
    width:8px;
    height:8px;
    border-radius:999px;
    background:rgba(255,255,255,.18);
    border:0;
}
.vx-deals-dot.is-active{width:28px;background:linear-gradient(90deg,#7c3aed,#22d3ee)}

/* Event campaigns: compact connector after flash sale before product tabs. */
.vx-events{
    padding-top:clamp(20px,3vw,38px);
    padding-bottom:clamp(20px,3vw,38px);
}
.vx-events-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
}
.vx-event{
    position:relative;
    min-height:170px;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    gap:8px;
    padding:18px;
    overflow:hidden;
    border-radius:22px;
    border:1px solid rgba(255,255,255,.08);
    background:
      radial-gradient(circle at 80% 20%,rgba(34,211,238,.20),transparent 28%),
      radial-gradient(circle at 15% 0%,rgba(168,85,247,.28),transparent 36%),
      linear-gradient(145deg,rgba(17,24,39,.88),rgba(3,7,18,.96));
    color:#fff;
    text-decoration:none;
    box-shadow:0 14px 40px rgba(0,0,0,.28);
}
.vx-event-glow{position:absolute;inset:auto -20% -30% -20%;height:80%;background:radial-gradient(ellipse at center,rgba(124,58,237,.34),transparent 66%);filter:blur(24px)}
.vx-event-shape{position:absolute;top:18px;inset-inline-end:18px;width:54px;height:54px;border-radius:16px;border:1px solid rgba(34,211,238,.25);transform:rotate(12deg);background:linear-gradient(135deg,rgba(34,211,238,.18),rgba(124,58,237,.16))}
.vx-event-badge{position:relative;z-index:1;align-self:flex-start;padding:6px 9px;border-radius:999px;background:rgba(124,58,237,.18);border:1px solid rgba(168,85,247,.28);color:#d8b4fe;font-size:11px;font-weight:950;letter-spacing:.05em}
.vx-event-title{position:relative;z-index:1;margin:0;font-size:18px;color:#fff;font-weight:950}.vx-event-sub{position:relative;z-index:1;margin:0;color:rgba(255,255,255,.68);font-size:13px;line-height:1.45}.vx-event-cta{position:relative;z-index:1;display:inline-flex;align-items:center;gap:7px;color:#22d3ee;font-weight:900;font-size:13px}.vx-event:hover{transform:translateY(-3px);border-color:rgba(34,211,238,.35);box-shadow:0 18px 50px rgba(34,211,238,.10)}

@media (max-width:1100px){
    .vx-deals-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:4px}
    .vx-deal{flex:0 0 min(300px,74vw);scroll-snap-align:start;min-height:390px}
    .vx-events-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:640px){
    .vx-section{padding:18px 0}
    .vx-container{padding:0 12px}
    .vx-section-head{margin-bottom:12px}
    .vx-section-title{font-size:24px}
    .vx-eyebrow{font-size:10px;padding:6px 10px}
    .vx-deal{flex-basis:70vw;min-height:300px;border-radius:18px}
    .vx-deal-body{padding:14px}
    .vx-deal-title{font-size:15px}.vx-deal-sub{font-size:12px}
    .vx-events-grid{grid-template-columns:1fr 1fr;gap:10px}
    .vx-event{min-height:128px;padding:12px;border-radius:17px}
    .vx-event-title{font-size:14px}.vx-event-sub{display:none}.vx-event-shape{width:38px;height:38px}
}
@media (prefers-reduced-motion:reduce){.vx-pulse{animation:none}.vx-deal,.vx-event{transition:none!important}}
