*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#000000;--bg-2:#0a0a0a;--bg-3:#141414;
  --ink:#ffffff;--muted:#8c8c8c;--line:#1f1f1f;
}
html,body{background:var(--bg);color:var(--ink);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body{min-height:100vh}
a{color:inherit;text-decoration:none}
::selection{background:#fff;color:#000}
i{font-style:normal}

/* lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

/* cursor */
.cursor{position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;background:#fff;pointer-events:none;mix-blend-mode:difference;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s}
.cursor.lg{width:70px;height:70px}

/* grain */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.05;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}

.progress{position:fixed;top:0;left:0;height:2px;width:0;background:#fff;z-index:9999}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:22px 44px;background:linear-gradient(180deg,rgba(0,0,0,.85),transparent);transition:background .35s,backdrop-filter .35s,border-color .35s}
nav.scrolled{background:rgba(0,0,0,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
nav .logo{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:.06em;color:#fff}
nav .logo b{color:var(--muted);font-weight:400}
nav ul{display:flex;gap:34px;list-style:none}
nav ul a{font-size:13px;letter-spacing:.05em;color:#e5e5e5;font-weight:500;transition:color .25s,opacity .25s}
nav ul a:hover{opacity:.5}
nav .cta{padding:10px 24px;border-radius:2px;font-size:13px;font-weight:600;letter-spacing:.05em;color:#000;background:#fff;transition:.3s}
nav .cta:hover{background:#ccc}

/* hero */
.hero{position:relative;height:100vh;width:100%;overflow:hidden;perspective:1400px}
.hero canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero .glow{position:absolute;width:80vw;height:80vw;border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,255,255,.07),transparent 60%);filter:blur(80px);z-index:0}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,#000 100%);z-index:3;pointer-events:none}
.hero-stage{position:relative;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;transform-style:preserve-3d;z-index:2}
.hero h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(80px,16vw,260px);line-height:.86;letter-spacing:-.01em;text-align:center;color:#fff}
.hero h1 .row{display:block;overflow:hidden}
.hero h1 .row span{display:inline-block;will-change:transform}
.hero h1 .row.outline span{color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.6)}
.hero h1 .row.small{font-size:clamp(24px,4vw,54px);letter-spacing:.4em;margin-top:14px;color:var(--muted)}
.hero p.kicker{margin-top:28px;font-size:12px;letter-spacing:.45em;text-transform:uppercase;color:#888;text-align:center;font-weight:500}

.disc{position:absolute;width:680px;height:680px;border-radius:50%;border:1px solid rgba(255,255,255,.14);left:50%;top:50%;transform:translate(-50%,-50%);z-index:1;pointer-events:none}
.disc::before,.disc::after{content:"";position:absolute;inset:60px;border-radius:50%;border:1px solid rgba(255,255,255,.1)}
.disc::after{inset:140px;border-color:rgba(255,255,255,.22)}
.disc-core{position:absolute;width:120px;height:120px;border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,#111,#000);box-shadow:inset 0 0 40px rgba(255,255,255,.25),0 0 80px rgba(255,255,255,.2)}

.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:5;display:flex;flex-direction:column;align-items:center;gap:10px;color:#888;font-size:10px;letter-spacing:.4em;text-transform:uppercase}
.scroll-hint .line{width:1px;height:46px;background:linear-gradient(#fff,transparent);animation:slide 2s infinite}
@keyframes slide{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* about */
.about{padding:150px 8vw;background:#000;border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.about::before{content:"ABOUT";position:absolute;right:-4vw;top:30px;font-family:'Bebas Neue',sans-serif;font-size:22vw;line-height:1;color:rgba(255,255,255,.025);letter-spacing:.02em;pointer-events:none}
.about-inner{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center;position:relative;z-index:2}
.about-copy h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(54px,8vw,118px);line-height:.92;letter-spacing:-.005em;margin-bottom:34px}
.about-copy h2 i{color:transparent;-webkit-text-stroke:1.4px #fff}
.about-copy p:not(.label){color:#aaa;font-size:16px;line-height:1.85;max-width:620px;margin-top:18px}
.about-panel{border:1px solid var(--line);background:linear-gradient(160deg,#101010,#050505);padding:10px}
.panel-row{display:flex;justify-content:space-between;gap:24px;padding:26px 24px;border-bottom:1px solid var(--line);align-items:center}
.panel-row:last-child{border-bottom:0}
.panel-row span{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#777;font-weight:600}
.panel-row b{font-family:'Bebas Neue',sans-serif;font-size:28px;font-weight:400;letter-spacing:.04em;text-align:right;color:#fff}

/* marquee */
.marquee{padding:50px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:#0a0a0a}
.marquee-track{display:flex;gap:80px;white-space:nowrap;font-family:'Bebas Neue',sans-serif;font-size:100px;line-height:1;color:transparent;-webkit-text-stroke:1.5px #fff}
.marquee-track span{display:inline-flex;align-items:center;gap:80px}
.marquee-track span::after{content:"●";color:#fff;-webkit-text-stroke:0;font-size:40px;transform:translateY(-12px)}

/* partners */
.partners{padding:80px 8vw;background:linear-gradient(180deg,#000 0%,#070707 50%,#000 100%);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.partners-inner{position:relative;z-index:2;max-width:1300px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:44px}
.partners-label{font-size:11px;letter-spacing:.5em;text-transform:uppercase;color:#666;font-weight:600;display:inline-flex;align-items:center;gap:14px}
.partners-label::before,.partners-label::after{content:"";width:40px;height:1px;background:linear-gradient(90deg,transparent,#fff,transparent)}
.partners-label b{color:#fff;font-weight:700}
.partners-grid{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:26px 70px;width:100%}
.partner{display:flex;align-items:center;gap:14px;color:#555;transition:color .35s,transform .35s;cursor:pointer;will-change:transform}
.partner svg{width:34px;height:34px;flex-shrink:0}
.partner b{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:26px;letter-spacing:.08em;white-space:nowrap}
.partner:hover{color:#fff;transform:translateY(-4px)}

/* numbers */
.numbers{padding:140px 8vw;background:#000}
.numbers .header,.contact .label{position:relative}
.numbers .header{text-align:center;margin-bottom:90px}
.label{font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:#888;margin-bottom:18px;font-weight:600}
.numbers h3,.contact h3{font-family:'Bebas Neue',sans-serif;font-size:clamp(60px,9vw,140px);line-height:.9}
.numbers h3 i,.contact h3 i{color:transparent;-webkit-text-stroke:1.5px #fff}
.num-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);max-width:1300px;margin:0 auto}
.num-card{background:#000;padding:60px 30px;text-align:center;transition:background .35s}
.num-card:hover{background:var(--bg-3)}
.num-card b{display:block;font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(50px,6vw,90px);line-height:1;color:#fff}
.num-card small{display:block;margin-top:12px;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);font-weight:500}

/* services */
.services{padding:150px 8vw;background:#000;border-top:1px solid var(--line)}
.services-head{text-align:center;max-width:760px;margin:0 auto 76px}
.services-head h3{font-family:'Bebas Neue',sans-serif;font-size:clamp(58px,8vw,126px);line-height:.9;letter-spacing:.01em;margin-bottom:20px}
.services-head > p:not(.label){color:#999;font-size:16px;line-height:1.7}
.service-grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:#000;border:1px solid var(--line)}
.service-card{background:#000;padding:42px 34px;min-height:290px;display:flex;flex-direction:column;transition:transform .35s,border-color .35s;border-right:1px solid var(--line)}
.service-card:last-child{border-right:0}
.service-card:hover{transform:translateY(-4px);border-color:#333}
.service-card span{font-family:'Bebas Neue',sans-serif;font-size:58px;line-height:1;color:rgba(255,255,255,.12);margin-bottom:42px}
.service-card h4{font-family:'Bebas Neue',sans-serif;font-size:34px;font-weight:400;letter-spacing:.03em;margin-bottom:14px}
.service-card p{color:#999;font-size:14px;line-height:1.75}

/* top artists */
.top-artists{padding:145px 8vw;background:#000;border-top:1px solid var(--line);position:relative;overflow:hidden}
.top-artists-head{text-align:center;max-width:760px;margin:0 auto 70px}
.top-artists-head h3{font-family:'Bebas Neue',sans-serif;font-size:clamp(58px,8vw,126px);line-height:.9;letter-spacing:.01em;margin-bottom:20px}
.top-artists-head > p:not(.label){color:#999;font-size:16px;line-height:1.7}
.artist-embeds{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
.artist-embeds iframe{border:0;border-radius:12px;background:transparent;filter:grayscale(1);transition:filter .35s,transform .35s;display:block;overflow:hidden}
.artist-embeds iframe:hover{filter:grayscale(.35);transform:translateY(-4px)}

/* reel */
.reel{position:relative;height:200vh;background:#000}
.reel-stage{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.reel-row{display:flex;gap:24px;will-change:transform}
.reel-row .frame{flex:0 0 320px;height:440px;border-radius:4px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.7);position:relative;display:flex;align-items:flex-end;padding:24px;border:1px solid rgba(255,255,255,.1);background:#050505}
.reel-row .frame::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 35%,rgba(255,255,255,.12),transparent 42%),linear-gradient(180deg,transparent 40%,rgba(0,0,0,.9));z-index:1}
.reel-row .frame span{font-family:'Bebas Neue',sans-serif;font-size:34px;color:rgba(255,255,255,.45);letter-spacing:.1em;position:relative;z-index:3}
.visual{position:absolute;inset:0;z-index:0;opacity:.85}
.vinyl::before{content:"";position:absolute;width:240px;height:240px;border-radius:50%;left:50%;top:38%;transform:translate(-50%,-50%);background:repeating-radial-gradient(circle,#111 0 8px,#222 9px 10px),radial-gradient(circle,#777 0 12px,#111 13px 50px,#000 51px)}
.vinyl::after{content:"";position:absolute;left:50%;top:38%;width:64px;height:64px;border-radius:50%;transform:translate(-50%,-50%);background:#e6e6e6;box-shadow:0 0 0 16px #111}
.bars{display:flex;align-items:center;justify-content:center;gap:10px;padding:90px 70px 120px}
.bars::before{content:"";width:100%;height:220px;background:linear-gradient(90deg,rgba(255,255,255,.1) 0 8%,transparent 8% 14%,rgba(255,255,255,.28) 14% 25%,transparent 25% 32%,rgba(255,255,255,.14) 32% 44%,transparent 44% 51%,rgba(255,255,255,.35) 51% 64%,transparent 64% 72%,rgba(255,255,255,.18) 72% 82%,transparent 82% 90%,rgba(255,255,255,.08) 90%);clip-path:polygon(0 65%,8% 65%,8% 25%,14% 25%,14% 46%,25% 46%,25% 12%,32% 12%,32% 78%,44% 78%,44% 32%,51% 32%,51% 5%,64% 5%,64% 58%,72% 58%,72% 18%,82% 18%,82% 72%,90% 72%,90% 40%,100% 40%,100% 100%,0 100%)}
.notes::before{content:"♪ ♫ ♬";position:absolute;left:44px;right:44px;top:105px;font-family:'Bebas Neue',sans-serif;font-size:82px;letter-spacing:.18em;color:rgba(255,255,255,.22)}
.notes::after{content:"";position:absolute;left:42px;right:42px;top:220px;height:80px;background:repeating-linear-gradient(0deg,transparent 0 15px,rgba(255,255,255,.12) 16px 17px)}
.mic::before{content:"";position:absolute;left:50%;top:34%;width:86px;height:150px;border-radius:46px;background:linear-gradient(90deg,#111,#e5e5e5 48%,#111);transform:translateX(-50%);box-shadow:0 0 0 1px rgba(255,255,255,.2)}
.mic::after{content:"";position:absolute;left:50%;top:68%;width:150px;height:90px;border:8px solid rgba(255,255,255,.25);border-top:0;border-radius:0 0 80px 80px;transform:translateX(-50%)}
.wave::before{content:"";position:absolute;left:30px;right:30px;top:170px;height:120px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.28) 0 4px,transparent 4px 13px);clip-path:polygon(0 50%,5% 30%,10% 64%,15% 18%,20% 72%,25% 38%,30% 60%,35% 22%,40% 78%,45% 34%,50% 52%,55% 24%,60% 74%,65% 42%,70% 58%,75% 18%,80% 82%,85% 36%,90% 66%,95% 28%,100% 50%,100% 100%,0 100%)}
.decks::before{content:"";position:absolute;width:118px;height:118px;border-radius:50%;left:46px;top:120px;background:repeating-radial-gradient(circle,#111 0 8px,#333 9px 10px);box-shadow:150px 0 0 #111,150px 0 0 1px rgba(255,255,255,.2),0 0 0 1px rgba(255,255,255,.2)}
.decks::after{content:"";position:absolute;left:50px;right:50px;top:280px;height:34px;background:linear-gradient(90deg,rgba(255,255,255,.18),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.1)}
.reel-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;z-index:4;pointer-events:none;background:radial-gradient(ellipse at center,transparent 25%,rgba(0,0,0,.88) 75%)}
.reel-overlay h3{font-family:'Bebas Neue',sans-serif;font-size:clamp(70px,11vw,190px);line-height:.9}
.reel-overlay h3 b{color:transparent;-webkit-text-stroke:1.5px #fff;font-weight:400}

/* contact */
.contact{padding:180px 8vw;background:#000;text-align:center;position:relative;overflow:hidden;border-top:1px solid var(--line)}
.contact::before{content:"";position:absolute;left:50%;top:50%;width:900px;height:420px;transform:translate(-50%,-50%);background:radial-gradient(ellipse,rgba(255,255,255,.06),transparent 70%);filter:blur(80px);pointer-events:none}
.contact .sub{margin-top:22px;color:#999;font-size:15px}
.contact .mail{display:inline-block;margin-top:46px;font-family:'Bebas Neue',sans-serif;font-size:clamp(26px,4.5vw,60px);letter-spacing:.04em;color:#fff;border-bottom:2px solid #fff;padding-bottom:8px;transition:color .3s,border-color .3s}
.contact .mail:hover{color:var(--muted);border-color:var(--muted)}
.contact .socials{display:flex;justify-content:center;gap:18px;margin-top:56px;position:relative;z-index:2}
.contact .socials a{width:54px;height:54px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:#888;transition:color .3s,border-color .3s,transform .3s,background .3s}
.contact .socials a svg{width:22px;height:22px}
.contact .socials a:hover{color:#000;background:#fff;border-color:#fff;transform:translateY(-4px)}

/* footer */
footer{padding:44px;border-top:1px solid var(--line);background:#000}
.foot-inner{max-width:1300px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#666}
.foot-inner .brand{font-family:'Bebas Neue',sans-serif;font-size:24px;color:#fff;letter-spacing:.06em}
.foot-inner .brand b{color:var(--muted);font-weight:400}

@media(max-width:900px){
  nav{padding:18px 20px}
  nav ul{display:none}
  .cursor{display:none}
  .disc{width:340px;height:340px}
  .about-inner{grid-template-columns:1fr;gap:42px}
  .num-grid{grid-template-columns:1fr 1fr}
  .service-grid{grid-template-columns:1fr 1fr}
  .service-card:nth-child(2n){border-right:0}
  .artist-embeds{grid-template-columns:1fr}
  .reel-row .frame{flex:0 0 220px;height:300px}
  .marquee-track{font-size:60px}
}
