/* =========================================================
   PULSE theme — adapted for Vibe Media (Dubai events / media / digital)
   Theme palette & motion from the provided "PULSE" template.
   ========================================================= */
:root{
  --bg:#0d0b14; --bg2:#15121f; --surface:#1c1828;
  --primary:#ff2d76; --accent:#9b4dff; --accent2:#00e0ff;
  --text:#f4f2f8; --muted:#9590a8; --line:rgba(255,255,255,.08);
  --grad:linear-gradient(120deg,#ff2d76,#9b4dff 55%,#00e0ff);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6}
::selection{background:var(--primary);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3{font-weight:800;letter-spacing:-.02em;line-height:1.1}
.container{max-width:1200px;margin:0 auto;padding:0 28px}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.muted{color:var(--muted)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid var(--accent2);outline-offset:3px}

.orbs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.35;animation:float 16s ease-in-out infinite}
.orb1{width:500px;height:500px;background:var(--primary);top:-120px;left:-100px}
.orb2{width:420px;height:420px;background:var(--accent);top:40%;right:-120px;animation-delay:-5s}
.orb3{width:380px;height:380px;background:var(--accent2);bottom:-120px;left:30%;animation-delay:-9s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-50px) scale(1.1)}66%{transform:translate(-30px,40px) scale(.95)}}

header{position:fixed;top:0;width:100%;z-index:100;transition:.4s;padding:22px 0}
header.scrolled{background:rgba(13,11,20,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:14px 0;border-bottom:1px solid var(--line)}
nav{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800}
.logo .wave{display:flex;align-items:center;gap:3px;height:26px}
.logo .wave span{width:3px;border-radius:3px;background:var(--grad);animation:eq 1s ease-in-out infinite}
.logo .wave span:nth-child(1){height:10px}.logo .wave span:nth-child(2){height:22px;animation-delay:.2s}
.logo .wave span:nth-child(3){height:14px;animation-delay:.4s}.logo .wave span:nth-child(4){height:26px;animation-delay:.1s}.logo .wave span:nth-child(5){height:8px;animation-delay:.3s}
@keyframes eq{0%,100%{transform:scaleY(.4)}50%{transform:scaleY(1)}}
.nav-links{display:flex;gap:34px;list-style:none}
.nav-links a{font-size:15px;color:var(--muted);font-weight:500;position:relative;transition:.3s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--grad);transition:.3s}
.nav-links a:hover{color:var(--text)}.nav-links a:hover::after{width:100%}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 30px;border-radius:40px;font-weight:600;font-size:15px;cursor:pointer;border:none;transition:.35s;position:relative;overflow:hidden}
.btn-primary{background:var(--grad);color:#fff;background-size:200% auto}
.btn-primary:hover{background-position:right center;transform:translateY(-3px);box-shadow:0 12px 30px rgba(255,45,118,.4)}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--primary);background:rgba(255,45,118,.08)}

.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px}
.burger span{width:26px;height:2px;background:var(--text);transition:.3s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.hero{position:relative;z-index:2;min-height:100vh;display:flex;align-items:center;padding-top:80px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.hero .tag{display:inline-block;padding:7px 18px;border:1px solid var(--line);border-radius:30px;font-size:13px;color:var(--accent2);margin-bottom:26px;background:rgba(0,224,255,.06)}
.hero h1{font-size:clamp(44px,6vw,78px);margin-bottom:24px}
.hero p{color:var(--muted);font-size:18px;max-width:480px;margin-bottom:36px}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.play-circle{display:inline-flex;align-items:center;gap:14px;cursor:pointer;background:none;border:none;color:var(--text);font-weight:600}
.play-icon{width:54px;height:54px;border-radius:50%;background:var(--grad);display:grid;place-items:center;position:relative}
.play-icon::before{content:'';position:absolute;inset:0;border-radius:50%;border:2px solid var(--primary);animation:pulse 2s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:1}100%{transform:scale(1.7);opacity:0}}
.play-icon svg{margin-left:3px}

.disc-wrap{position:relative;display:grid;place-items:center}
.disc{width:340px;height:340px;border-radius:50%;background:conic-gradient(from 0deg,var(--primary),var(--accent),var(--accent2),var(--primary));display:grid;place-items:center;animation:spin 8s linear infinite;box-shadow:0 0 80px rgba(155,77,255,.4)}
.disc::after{content:'';position:absolute;width:180px;height:180px;border-radius:50%;background:var(--bg2);border:2px solid var(--line)}
.disc-center{width:40px;height:40px;border-radius:50%;background:var(--grad);z-index:2;position:relative}
@keyframes spin{to{transform:rotate(360deg)}}
.ring{position:absolute;border:1px solid var(--line);border-radius:50%}
.ring1{width:400px;height:400px;animation:spin 20s linear infinite reverse}
.ring2{width:470px;height:470px;border-style:dashed;animation:spin 30s linear infinite}

section{position:relative;z-index:2;padding:110px 0}
.sec-head{text-align:center;max-width:640px;margin:0 auto 64px}
.sec-head .label{color:var(--primary);font-weight:700;letter-spacing:3px;text-transform:uppercase;font-size:13px}
.sec-head h2{font-size:clamp(32px,4vw,50px);margin:14px 0 16px}
.sec-head p{color:var(--muted)}
.reveal{opacity:0;transform:translateY(50px);transition:.8s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}

.events{display:grid;gap:18px}
.event-card{display:grid;grid-template-columns:auto 1fr auto;gap:30px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:26px 32px;transition:.4s}
.event-card:hover{transform:translateX(10px);border-color:var(--primary);box-shadow:-10px 0 0 0 var(--primary)}
.event-date{text-align:center;min-width:70px}.event-date .d{font-size:34px;font-weight:800}
.event-date .m{color:var(--muted);text-transform:uppercase;font-size:13px;letter-spacing:2px}
.event-info h3{font-size:22px;margin-bottom:4px}.event-info span{color:var(--muted);font-size:14px}
.event-card .btn{white-space:nowrap}

.artists{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.artist{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:3/4}
.artist .av{position:absolute;inset:0;width:100%;height:100%;background-size:cover;background-position:center;transition:.5s}
.artist::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(13,11,20,.96),rgba(13,11,20,.25) 60%);z-index:1}
.artist:hover .av{transform:scale(1.1)}
.artist-meta{position:absolute;bottom:0;left:0;padding:24px;z-index:2;transform:translateY(8px);transition:.4s}
.artist:hover .artist-meta{transform:translateY(0)}
.artist-meta h3{font-size:21px}.artist-meta span{color:var(--accent2);font-size:14px}
.artist-meta .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;opacity:0;transition:.4s}
.artist:hover .tags{opacity:1}
.artist-meta .tags span{color:var(--text);background:rgba(255,255,255,.12);padding:4px 10px;border-radius:30px;font-size:12px}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat{padding:34px 20px;border:1px solid var(--line);border-radius:18px;background:var(--surface)}
.stat .num{font-size:46px;font-weight:800;font-variant-numeric:tabular-nums}.stat .lbl{color:var(--muted);margin-top:6px;font-size:14px;letter-spacing:1px}

.player{background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:24px 30px;display:grid;grid-template-columns:auto 1fr auto;gap:26px;align-items:center}
.player .pp{width:58px;height:58px;border-radius:50%;background:var(--grad);border:none;cursor:pointer;display:grid;place-items:center}
.track h4{font-size:17px}.track span{color:var(--muted);font-size:13px}
.viz{display:flex;align-items:flex-end;gap:4px;height:46px;margin-top:12px}
.viz span{flex:1;background:var(--grad);border-radius:3px;animation:viz 1.2s ease-in-out infinite;min-height:4px}
@keyframes viz{0%,100%{height:18%}50%{height:100%}}

.cta-box{text-align:center;background:var(--grad);border-radius:28px;padding:70px 40px;position:relative;overflow:hidden}
.cta-box h2{font-size:clamp(30px,4vw,46px);color:#fff;margin-bottom:16px}
.cta-box p{color:rgba(255,255,255,.85);margin-bottom:32px;font-size:18px}
.cta-box .btn{background:#fff;color:var(--primary)}
.cta-box .btn:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.3)}

footer{position:relative;z-index:2;border-top:1px solid var(--line);padding:60px 0 30px;margin-top:40px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:40px}
.foot-grid p{color:var(--muted);margin-top:16px;max-width:280px;font-size:14px}
.foot-col h4{margin-bottom:18px;font-size:16px}
.foot-col a{display:block;color:var(--muted);margin-bottom:10px;font-size:14px;transition:.3s}
.foot-col a:hover{color:var(--primary);padding-left:5px}
.foot-bottom{text-align:center;color:var(--muted);font-size:14px;padding-top:30px;border-top:1px solid var(--line)}

/* ---- Real Vibe Media photography behind the service cards ---- */
.av-events{background-image:url("/assets/img/events.jpg")}
.av-exhibitions{background-image:url("/assets/img/exhibitions.jpg")}
.av-video{background-image:url("/assets/img/video.jpg")}
.av-digital{background-image:url("/assets/img/digital.jpg")}

@media(max-width:900px){
  .nav-links{position:fixed;inset:72px 0 auto 0;flex-direction:column;gap:0;background:rgba(13,11,20,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:10px 28px 24px;transform:translateY(-12px);opacity:0;pointer-events:none;transition:.25s}
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a{display:block;padding:14px 0;border-bottom:1px solid var(--line);font-size:16px}
  .nav-links a::after{display:none}
  .hero .disc-wrap{display:none}
  .burger{display:flex}
  .hero-grid{grid-template-columns:1fr}
  .artists{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .event-card{grid-template-columns:auto 1fr;gap:18px}
  .event-card .btn{grid-column:1/-1}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
