/* TITLE: BLXCKHIPPY ENTERTAINMENT - SERVICES MASTER SHEET */

:root {
    --vp-orange: #ff9f2e;
    --vp-red: #ff4e00;
    --vp-black: #0a0a0a;
    --vp-glass: rgba(18, 18, 18, 0.45);
    --vp-glass-bright: rgba(25, 25, 25, 0.95);
    --vp-easing: cubic-bezier(0.16, 1, 0.22, 1); /* Adjusted easing for consistency */
}

#vs-services-canvas {
    color: #fff;
    padding-bottom: 100px;
    width: 100%;
}

/* The core class for active scroll physics */
.cinematic-card {
    will-change: transform, opacity;
    transform: translateY(var(--card-y, 100px)) scale(var(--card-scale, 0.9));
    opacity: var(--card-opacity, 0);
    transition: transform 0.1s linear, opacity 0.1s linear; 
}

/* II. ATMOSPHERE & PARALLAX */
.vs-atmosphere { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: -1; pointer-events: none; }
.vs-spotlight { position: absolute; width: 80vw; height: 80vw; filter: blur(150px); opacity: 0.12; will-change: transform; }
.vs-spotlight.orange { top: -20%; right: -10%; background: var(--vp-orange); }
.vs-spotlight.red { bottom: 20%; left: -20%; background: var(--vp-red); }
.vs-mesh { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: radial-gradient(circle at 2px 2px, rgba(255,159,46,0.06) 1.5px, transparent 0); background-size: 60px 60px; opacity: 0.5; }

/* III. HERO */
.vse-hero { padding: 180px 5% 100px 5%; text-align: center; display: flex; flex-direction: column; align-items: center;}
.vse-meta-label { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 2rem; background: rgba(255,255,255,0.05); padding: 8px 20px; border-radius: 100px; border: 1px solid rgba(255,159,46,0.3); }
.pulse-dot { width: 8px; height: 8px; background: var(--vp-orange); border-radius: 50%; animation: pulse 2s infinite; }
@keyframes pulse { 0% { transform: scale(0.9); opacity: 1; } 50% { transform: scale(1.5); opacity: 0.5; } 100% { transform: scale(0.9); opacity: 1; } }
.label-text { font-size: 0.75rem; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; }
.vse-title { font-size: clamp(3.5rem, 8vw, 6.5rem); font-weight: 900; letter-spacing: -3px; color: #fff; line-height: 1; margin: 0 0 1.5rem 0; }
.vse-liquid-text { background: linear-gradient(to right, #fff, var(--vp-orange), var(--vp-red), #fff); background-size: 300% auto; color: transparent; -webkit-background-clip: text; background-clip: text; animation: text-flow 8s linear infinite; }
@keyframes text-flow { 0% { background-position: 0% center; } 100% { background-position: 300% center; } }
.vse-tagline-lead { font-size: 1.25rem; color: rgba(255,255,255,0.7); max-width: 700px; margin: 0 auto; line-height: 1.7; }

.vse-scroll-prompt { margin-top: 40px; opacity: 0.5; }
.mouse-icon { width: 24px; height: 36px; border: 2px solid #fff; border-radius: 12px; margin: 0 auto 10px auto; position: relative; }
.mouse-wheel { width: 4px; height: 8px; background: #fff; border-radius: 2px; position: absolute; top: 6px; left: 50%; transform: translateX(-50%); animation: scrollWheel 2s infinite; }
@keyframes scrollWheel { 0% { top: 6px; opacity: 1; } 100% { top: 20px; opacity: 0; } }

/* IV. ARCHITECTURE STACK */
.vse-stack-wrapper { padding: 0 5%; max-width: 1400px; margin: 0 auto; }
.vse-service-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 60px;
    margin-bottom: 150px;
    background: var(--vp-glass);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 159, 46, 0.15);
    border-radius: 50px;
    padding: 60px;
    box-shadow: 0 30px 60px rgba(0,0,0,0.5);
}
.vse-service-card.card-reverse { flex-direction: row-reverse; }
.vse-card-text { flex: 1; max-width: 550px; }

.vse-service-number { font-size: 1.5rem; font-weight: 900; color: var(--vp-orange); margin-bottom: 15px; font-family: monospace; display: block; }
.vse-service-title { font-size: 3rem; font-weight: 900; letter-spacing: -2px; line-height: 1.1; margin-bottom: 1.5rem; color: #fff; }
.vse-service-body { font-size: 1.15rem; line-height: 1.8; color: rgba(255,255,255,0.7); margin-bottom: 2rem; }

.vse-feature-list { list-style: none; padding: 0; margin: 0 0 3rem 0; }
.vse-feature-list li { font-size: 1.05rem; font-weight: 700; color: #fff; padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.1); display: flex; align-items: center; gap: 15px; }
.vse-feature-list li::before { content: '✓'; color: var(--vp-orange); font-weight: 900; }

.vse-text-link { color: var(--vp-orange); font-size: 1.1rem; font-weight: 800; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; text-transform: uppercase; letter-spacing: 2px; }
.vse-arrow { transition: transform 0.3s; }
.vse-text-link:hover .vse-arrow { transform: translateX(5px); }

/* V. INTERACTIVE PHYSICS VISUALIZERS */
.vse-card-visualizer { flex: 1; width: 100%; height: 500px; position: relative; border-radius: 40px; padding: 1px; }
.vse-liquid-border {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 40px;
    background: linear-gradient(135deg, rgba(255,255,255,0.05), var(--vp-orange), rgba(255,255,255,0.05), var(--vp-red));
    background-size: 300% 300%; animation: card-liquid-anim 6s infinite linear; opacity: 0.4; z-index: 1; pointer-events: none;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude;
}
@keyframes card-liquid-anim { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }

.vse-interactive-zone {
    background: var(--vp-glass-bright);
    border-radius: 39px; width: 100%; height: 100%; position: relative; overflow: hidden; z-index: 2;
    display: flex; align-items: center; justify-content: center;
    perspective: 1000px; transform-style: preserve-3d;
    will-change: transform;
    transform: rotateX(var(--tilt-y, 0deg)) rotateY(var(--tilt-x, 0deg));
}

/* Zone 01: Lasers */
.viz-stage-floor { position: absolute; bottom: 0; width: 100%; height: 30%; background: linear-gradient(to top, rgba(255,159,46,0.1), transparent); border-top: 1px solid rgba(255,159,46,0.3); }
.viz-laser-grid { position: absolute; width: 200%; height: 200%; top: -50%; left: -50%; transform: perspective(600px) rotateX(60deg); animation: laserMove 10s linear infinite; }
.laser { position: absolute; bottom: 0; width: 3px; height: 100%; background: linear-gradient(to top, transparent, var(--vp-orange), #fff); box-shadow: 0 0 30px var(--vp-orange); transform-origin: bottom; }
.l1 { left: 30%; transform: rotate(-20deg); } .l2 { left: 50%; transform: rotate(0deg); } .l3 { left: 70%; transform: rotate(20deg); }
@keyframes laserMove { 0% { transform: perspective(600px) rotateX(60deg) translateY(0); } 100% { transform: perspective(600px) rotateX(60deg) translateY(100px); } }
.viz-ambient-orb { width: 150px; height: 150px; background: radial-gradient(circle, #ff4e00, transparent 70%); border-radius: 50%; filter: blur(40px); position: absolute; transform: translate(var(--mouse-x, 0px), var(--mouse-y, 0px)); }

/* Zone 02: EQ Bars */
.viz-eq-container { display: flex; gap: 8px; align-items: flex-end; height: 200px; padding-bottom: 20px;}
.eq-bar { width: 18px; background: var(--vp-orange); border-radius: 10px 10px 0 0; height: 30px; animation: eqBounce 1s infinite alternate ease-in-out; transition: height 0.2s cubic-bezier(0.16, 1, 0.3, 1);}
.eq-bar:nth-child(even) { animation-duration: 0.7s; animation-delay: 0.2s; }
.eq-bar:nth-child(3n) { animation-duration: 1.2s; animation-delay: 0.4s; }
@keyframes eqBounce { 0% { height: 30px; } 100% { height: 120px; } }

/* Zone 03: Code Grid */
.viz-data-grid { width: 150%; height: 150%; background-image: linear-gradient(rgba(255,159,46,0.15) 1px, transparent 1px), linear-gradient(90deg, rgba(255,159,46,0.15) 1px, transparent 1px); background-size: 40px 40px; transform: rotateX(var(--tilt-y, 0deg)) rotateY(var(--tilt-x, 0deg)); position: absolute; }
.viz-code-block { position: absolute; background: rgba(10,10,10,0.9); border: 1px solid rgba(255,255,255,0.1); padding: 30px; border-radius: 12px; font-family: monospace; color: #00ff66; width: 80%; transform: translateZ(50px) rotateX(var(--tilt-y, 0deg)) rotateY(var(--tilt-x, 0deg)); text-align: left; }
.blinking-cursor { animation: blinker 1s linear infinite; }
@keyframes blinker { 50% { opacity: 0; } }

/* Zone 04: Kinetic Rings */
.viz-kinetic-ring { position: absolute; width: 280px; height: 280px; border: 2px solid rgba(255,159,46,0.4); border-radius: 50%; }
.r1 { animation: spin1 8s linear infinite; transform: rotateX(var(--tilt-y, 60deg)) rotateY(var(--tilt-x, 0deg)); }
.r2 { border-color: #ff4e00; animation: spin1 12s linear reverse infinite; transform: rotateX(var(--tilt-x, 45deg)) rotateZ(var(--tilt-y, 45deg)); }
.r3 { animation: spin1 10s linear infinite; border-color: rgba(255,255,255,0.2); transform: rotateY(var(--tilt-y, 80deg)) rotateX(var(--tilt-x, 20deg));}
@keyframes spin1 { 100% { transform: rotate(360deg); } }
.viz-center-core { width: 40px; height: 40px; background: #fff; border-radius: 50%; box-shadow: 0 0 40px #fff; position: absolute; }

/* VI. FOOTER PANEL */
.vse-footer-cta { padding: 50px 5% 140px 5%; display: flex; justify-content: center; }
.vse-glass-panel { background: rgba(30, 30, 30, 0.5); backdrop-filter: blur(40px); -webkit-backdrop-filter: blur(40px); border-radius: 50px; padding: 6rem 3rem; text-align: center; width: 100%; max-width: 1100px; border: 1px solid rgba(255,159,46,0.2); position: relative; }
.vse-btn { padding: 1.6rem 4rem; border-radius: 100px; text-decoration: none; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; transition: 0.4s var(--vp-easing); display: inline-block; font-size: 1.1rem; }
.vse-btn-fill { background: var(--vp-orange); color: #000; box-shadow: 0 15px 35px rgba(255,159,46,0.3); border: 1px solid var(--vp-orange); }
.vse-btn-fill:hover { box-shadow: 0 25px 50px rgba(255,159,46,0.4); background: transparent; color: var(--vp-orange); }

/* VII. RESPONSIVE HARDENING */
@media (max-width: 1024px) {
    .vse-service-card, .vse-service-card.card-reverse { flex-direction: column; padding: 40px; gap: 40px; border-radius: 30px;}
    .vse-card-text { max-width: 100%; }
    .vse-card-visualizer { height: 400px; }
}
@media (max-width: 768px) {
    .vse-title { font-size: 3rem; }
    .vse-service-title { font-size: 2.5rem; }
    .vse-service-card { padding: 30px 20px; border-radius: 20px; }
    .vse-btn { width: 100%; box-sizing: border-box; }
}