:root{
  --qblack:#050505;
  --qplatinum:#E5E4E2;
  --qgray:#A9A9A9;
  --qgold:#D4AF37;
  --qdarkgray:#1a1a1a;
}

body{
  background-color: var(--qblack);
  color: var(--qplatinum);
  overflow-x: hidden;
}

/* Three background */
#canvas-container{
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.65;
  pointer-events: none;
}

.glass-panel{
  background: rgba(20,20,20,0.62);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.06);
}

.text-gold-gradient{
  background: linear-gradient(to right, var(--qgold), #F7E7CE, var(--qgold));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-size: 200% auto;
  animation: shine 5s linear infinite;
}
@keyframes shine{ to{ background-position: 200% center; } }

.tech-line{
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--qgold), transparent);
  width: 100%;
  opacity: 0.35;
  margin: 3rem 0;
}

/* Responsive media embeds */
.video-container{
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border-radius: 0.75rem;
  border: 1px solid rgba(212,175,55,0.22);
  background: rgba(0,0,0,0.25);
}
.video-container iframe{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* Buttons */
.btn-primary{
  background: var(--qgold);
  color: #000;
  transition: transform .15s ease, box-shadow .15s ease, background-color .2s ease;
  box-shadow: 0 10px 30px rgba(212,175,55,0.18);
}
.btn-primary:hover{ transform: translateY(-2px); background: #ffffff; }

.btn-ghost{
  border: 1px solid rgba(229,228,226,0.28);
  color: var(--qplatinum);
  transition: transform .15s ease, border-color .2s ease, color .2s ease, box-shadow .2s ease;
}
.btn-ghost:hover{
  transform: translateY(-2px);
  border-color: rgba(212,175,55,0.75);
  color: var(--qgold);
  box-shadow: 0 0 18px rgba(212,175,55,0.22);
}

/* Mobile menu panel */
#mobileMenuPanel{
  transform: translateY(-10px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}
#mobileMenuPanel[data-open="true"]{
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.hero-logo{
  filter: drop-shadow(0 10px 30px rgba(212,175,55,0.20));
}

.hero-photo{
  filter: saturate(1.05) contrast(1.05);
}

/* Focus rings */
input:focus, textarea:focus{
  outline: none;
  border-color: rgba(212,175,55,0.9) !important;
  box-shadow: 0 0 0 2px rgba(212,175,55,0.18);
}

/* Hero visual (cutout + glow) */
.hero-visual-bg{
  position:absolute;
  inset: 10px;
  border-radius: 0.75rem;
  background:
    radial-gradient(600px 420px at 70% 30%, rgba(212,175,55,0.22), transparent 60%),
    radial-gradient(520px 380px at 30% 80%, rgba(229,228,226,0.10), transparent 65%),
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(0,0,0,0.10));
  filter: blur(0px);
  pointer-events:none;
  z-index: 0;
}
.hero-cutout{
  position: relative;
  z-index: 1;
  padding: 0.75rem;
  filter: drop-shadow(0 28px 60px rgba(0,0,0,0.55)) drop-shadow(0 0 40px rgba(212,175,55,0.12));
}
.hero-logo{
  will-change: transform, opacity;
}


/* ---- Hero Art + UI primitives ---- */
.hero-logo { filter: drop-shadow(0 0 30px rgba(212,175,55,0.18)); }
.hero-spotlight{
  position:absolute;
  inset:-20% -10% -20% -10%;
  background: radial-gradient(circle at 60% 40%, rgba(212,175,55,0.18), transparent 55%);
  filter: blur(0px);
  z-index:0;
  pointer-events:none;
}
.hero-ring{
  position:absolute;
  width:min(520px, 72vw);
  aspect-ratio:1/1;
  border-radius:9999px;
  border: 1px solid rgba(212,175,55,0.25);
  box-shadow: 0 0 80px rgba(212,175,55,0.08);
  right: 10%;
  top: 5%;
  z-index:0;
  pointer-events:none;
  animation: ringSpin 18s linear infinite;
}
@keyframes ringSpin { to { transform: rotate(360deg); } }

.hero-cutout{
  width: min(560px, 92vw);
  max-height: 78vh;
  object-fit: contain;
  z-index: 1;
  filter: drop-shadow(0 18px 55px rgba(0,0,0,0.55));
  animation: floaty 7s ease-in-out infinite;
  transform-origin: 50% 60%;
}
@keyframes floaty {
  0%,100% { transform: translateY(0px) scale(1); }
  50% { transform: translateY(-10px) scale(1.01); }
}

.chip{
  display:inline-flex;
  align-items:center;
  padding: 0.4rem 0.7rem;
  border-radius: 9999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  color: #E5E4E2;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.chip-strong{
  background: rgba(212,175,55,0.10);
  border-color: rgba(212,175,55,0.22);
}

.btn-primary{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  padding: 1rem 1.5rem;
  background: #D4AF37;
  color: #050505;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 0.25rem;
  box-shadow: 0 0 28px rgba(212,175,55,0.18);
  transition: transform .25s ease, background-color .25s ease, box-shadow .25s ease;
}
.btn-primary:hover{
  background:#ffffff;
  transform: translateY(-2px);
  box-shadow: 0 0 40px rgba(212,175,55,0.28);
}
.btn-ghost{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  padding: 1rem 1.5rem;
  border: 1px solid rgba(229,228,226,0.30);
  color: #E5E4E2;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 0.25rem;
  background: rgba(20,20,20,0.35);
  backdrop-filter: blur(10px);
  transition: transform .25s ease, border-color .25s ease, color .25s ease;
}
.btn-ghost:hover{
  border-color: rgba(212,175,55,0.65);
  color:#D4AF37;
  transform: translateY(-2px);
}


/* =========================
   HERO (Art + Cutout)
   ========================= */
.btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1rem 2rem;
  background:#D4AF37;
  color:#050505;
  font-family:'Montserrat', sans-serif;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  border:1px solid rgba(212,175,55,.55);
  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease;
}
.btn-primary:hover{ transform: translateY(-2px); box-shadow:0 0 24px rgba(212,175,55,.25); background:#ffffff;}
.btn-primary:active{ transform: translateY(0); box-shadow:0 0 12px rgba(212,175,55,.18);}

.btn-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1rem 2rem;
  color:#E5E4E2;
  font-family:'Montserrat', sans-serif;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  border:1px solid rgba(229,228,226,.28);
  background: rgba(20,20,20,.45);
  backdrop-filter: blur(10px);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, color .18s ease;
}
.btn-secondary:hover{ transform: translateY(-2px); box-shadow:0 0 18px rgba(212,175,55,.18); border-color: rgba(212,175,55,.6); color:#D4AF37;}
.btn-secondary:active{ transform: translateY(0); box-shadow:0 0 10px rgba(212,175,55,.12);}

.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.35rem .6rem;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  border-radius: 999px;
  font-size: .75rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-family:'Montserrat', sans-serif;
}

.hero-spotlight{
  position:absolute;
  width:min(560px, 90vw);
  height:min(560px, 90vw);
  border-radius:999px;
  background: radial-gradient(circle at 50% 45%,
    rgba(212,175,55,.30),
    rgba(212,175,55,.12) 40%,
    rgba(212,175,55,0) 70%);
  opacity:.9;
  transform: translateY(-10px);
  animation: heroSpot 8s ease-in-out infinite;
}
@keyframes heroSpot{
  0%,100%{ transform: translateY(-10px) scale(1); opacity:.88;}
  50%{ transform: translateY(-18px) scale(1.04); opacity:.98;}
}

.hero-rings{
  position:absolute;
  width:min(620px, 92vw);
  height:min(620px, 92vw);
  display:grid;
  place-items:center;
  opacity:.9;
}
.hero-rings .ring{
  position:absolute;
  inset:0;
  border-radius:999px;
  border:1px solid rgba(212,175,55,.25);
  box-shadow: 0 0 30px rgba(212,175,55,.08);
}
.hero-rings .ring-a{ transform: scale(1.0); animation: ringSpin 18s linear infinite; }
.hero-rings .ring-b{ transform: scale(.86) rotate(25deg); border-color: rgba(229,228,226,.14); animation: ringSpinReverse 26s linear infinite; }
.hero-rings .ring-c{ transform: scale(.72) rotate(-15deg); border-style:dashed; border-color: rgba(212,175,55,.18); animation: ringPulse 5.5s ease-in-out infinite; }

@keyframes ringSpin{ to{ transform: scale(1.0) rotate(360deg);} }
@keyframes ringSpinReverse{ to{ transform: scale(.86) rotate(-360deg);} }
@keyframes ringPulse{
  0%,100%{ transform: scale(.72) rotate(-15deg); opacity:.65;}
  50%{ transform: scale(.75) rotate(10deg); opacity:.92;}
}

.hero-logo-wrap{
  position:absolute;
  top:-18px;
  left:50%;
  transform: translateX(-50%);
  width:min(340px, 68vw);
  opacity:.95;
  filter: drop-shadow(0 0 18px rgba(212,175,55,.16));
  animation: heroLogoFloat 6.2s ease-in-out infinite;
  will-change: transform;
}

.hero-logo{ width:100%; height:auto; }
@keyframes heroLogoFloat{
  0%,100%{ transform: translateX(-50%) translateY(0); }
  50%{ transform: translateX(-50%) translateY(-10px); }
}

.hero-dj-wrap{
  position:relative;
  width:min(520px, 88vw);
  max-width:520px;
  animation: heroDJFloat 5.6s ease-in-out infinite;
  will-change: transform;
}
.hero-dj{
  width:100%;
  height:auto;
  object-fit:contain;
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.55));
}
@keyframes heroDJFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-12px); }
}

.hero-base-fade{
  position:absolute;
  bottom:-2px;
  left:0;
  right:0;
  height: 34%;
  background: linear-gradient(to top, rgba(5,5,5,1), rgba(5,5,5,.85), rgba(5,5,5,0));
}

.hero-scroll-cue{
  position:absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(169,169,169,.55);
  font-size: 1.25rem;
  transition: color .18s ease, transform .18s ease;
}
.hero-scroll-cue:hover{ color: rgba(212,175,55,.75); transform: translateX(-50%) translateY(-2px); }

/* Ensure the canvas never blocks clicks */
#canvas-container{ pointer-events:none; }

/* =========================
   HERO (Modern Cutout)
   ========================= */
#canvas-container{ pointer-events:none; }

.btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1rem 2rem;
  background:#D4AF37;
  color:#050505;
  font-family:'Montserrat', sans-serif;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  border:1px solid rgba(212,175,55,.70);
  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease;
}
.btn-primary:hover{ transform: translateY(-2px); box-shadow:0 0 24px rgba(212,175,55,.22); background:#ffffff;}
.btn-primary:active{ transform: translateY(0); box-shadow:0 0 12px rgba(212,175,55,.14);}

.btn-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1rem 2rem;
  color:#E5E4E2;
  font-family:'Montserrat', sans-serif;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  border:1px solid rgba(229,228,226,.22);
  background: rgba(20,20,20,.35);
  backdrop-filter: blur(10px);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, color .18s ease, background-color .18s ease;
}
.btn-secondary:hover{
  transform: translateY(-2px);
  box-shadow:0 0 18px rgba(212,175,55,.14);
  border-color: rgba(212,175,55,.55);
  color:#D4AF37;
  background: rgba(20,20,20,.45);
}
.btn-secondary:active{ transform: translateY(0); box-shadow:0 0 10px rgba(212,175,55,.10);}

.hero-cta{ border-radius: 0; }

.hero-microcopy{ letter-spacing: .08em; }

.hero-grid{
  position:absolute;
  width:min(620px, 92vw);
  height:min(620px, 92vw);
  opacity:.65;
  background:
    linear-gradient(rgba(212,175,55,.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,175,55,.10) 1px, transparent 1px);
  background-size: 34px 34px;
  filter: drop-shadow(0 0 18px rgba(212,175,55,.12));
  transform: translateY(-6px);
  animation: gridDrift 14s ease-in-out infinite;
  border-radius: 9999px;
  overflow: hidden;
}
@keyframes gridDrift{
  0%,100%{ transform: translateY(-6px) translateX(0); opacity:.55; }
  50%{ transform: translateY(-14px) translateX(10px); opacity:.78; }
}

.hero-frame{
  position:absolute;
  width:min(660px, 95vw);
  height:min(660px, 95vw);
  border: 1px solid rgba(229,228,226,.10);
  box-shadow: inset 0 0 0 1px rgba(212,175,55,.18);
  opacity:.9;
  transform: rotate(0.5deg);
  animation: frameBreathe 8.5s ease-in-out infinite;
  border-radius: 9999px;
  overflow: hidden;
  border: none;
  box-shadow: none;
}
.hero-frame::before,
.hero-frame::after{
  content:"";
  position:absolute;
  inset: 14px;
  border: 1px solid rgba(212,175,55,.16);
  opacity:.9;
}
.hero-frame::after{
  inset: 28px;
  border-color: rgba(229,228,226,.08);
}
@keyframes frameBreathe{
  0%,100%{ transform: rotate(0.5deg) scale(1); }
  50%{ transform: rotate(-0.5deg) scale(1.01); }
}

.hero-scan{
  position:absolute;
  width:min(660px, 95vw);
  height:min(660px, 95vw);
  overflow:hidden;
  opacity:.7;
  mix-blend-mode: screen;
  border-radius: 9999px;
  overflow: hidden;
}
.hero-scan::before{
  content:"";
  position:absolute;
  left:-30%;
  top:-40%;
  width: 70%;
  height: 180%;
  background: linear-gradient(90deg, transparent, rgba(212,175,55,.20), transparent);
  transform: skewX(-12deg);
  animation: scanMove 4.6s linear infinite;
}
@keyframes scanMove

/* Hero circular presentation (rings) */
.hero-grid,
.hero-frame,
.hero-scan{
  border-radius: 9999px;
}

.hero-grid,
.hero-scan{
  overflow: hidden;
  -webkit-mask-image: radial-gradient(circle at 50% 50%, #000 62%, transparent 64%);
  mask-image: radial-gradient(circle at 50% 50%, #000 62%, transparent 64%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.hero-frame::before,
.hero-frame::after{
  border-radius: 9999px;
}

{
  0%{ transform: translateX(0) skewX(-12deg); opacity:.0; }
  15%{ opacity:.55; }
  50%{ opacity:.45; }
  85%{ opacity:.55; }
  100%{ transform: translateX(220%) skewX(-12deg); opacity:.0; }
}

.hero-logo-wrap{
  position:absolute;
  top:-18px;
  left:50%;
  transform: translateX(-50%);
  width:min(340px, 68vw);
  opacity:.95;
  filter: drop-shadow(0 0 18px rgba(212,175,55,.16));
  animation: heroLogoFloat 6.2s ease-in-out infinite;
  will-change: transform;
}

.hero-logo{ width:100%; height:auto; }

@keyframes heroLogoFloat{
  0%,100%{ transform: translateX(-50%) translateY(0); }
  50%{ transform: translateX(-50%) translateY(-10px); }
}

.hero-dj-wrap{
  position:relative;
  width:min(540px, 90vw);
  max-width:540px;
  will-change: transform;
  animation: heroDJFloat 5.2s ease-in-out infinite;
}
.hero-dj{
  width:100%;
  height:auto;
  object-fit:contain;
  filter: drop-shadow(0 18px 44px rgba(0,0,0,.58));
}
@keyframes heroDJFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-12px); }
}

.hero-base-fade{
  position:absolute;
  bottom:-2px;
  left:0;
  right:0;
  height: 34%;
  background: linear-gradient(to top, rgba(5,5,5,1), rgba(5,5,5,.88), rgba(5,5,5,0));
}

.hero-scroll-cue{
  position:absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(169,169,169,.55);
  font-size: 1.25rem;
  transition: color .18s ease, transform .18s ease;
}
.hero-scroll-cue:hover{ color: rgba(212,175,55,.75); transform: translateX(-50%) translateY(-2px); }

/* Square corners across UI */
.glass-panel{ border-radius: 0; }
.video-container{ border-radius: 0; }
input, textarea, button{ border-radius: 0; }

/* =========================
   MOBILE MENU (Square, 90% opacity)
   ========================= */
.mobile-menu{
  position: fixed;
  inset: 0;
  z-index: 60;
}
.mobile-menu-panel{
  position:absolute;
  top: 0;
  right: 0;
  width: min(420px, 92vw);
  height: 100%;
  background: rgba(5,5,5,0.90);
  border-left: 1px solid rgba(255,255,255,0.06);
  padding: 96px 22px 22px;
  display:flex;
  flex-direction:column;
  gap: 18px;
}
.mobile-link{
  font-family:'Montserrat', sans-serif;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:800;
  color: #E5E4E2;
  padding: 14px 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.02);
  transition: border-color .18s ease, color .18s ease, transform .18s ease, background-color .18s ease;
}
.mobile-link:hover{
  border-color: rgba(212,175,55,0.55);
  color: #D4AF37;
  background: rgba(255,255,255,0.03);
  transform: translateX(-2px);
}
.mobile-link:active{ transform: translateX(0); }

.square-ui, .square-ui *{
  border-radius: 0 !important;
}

/* Hero art wrapper to keep logo + DJ aligned near top */
.hero-art-wrap{
  position:relative;
  width:min(620px, 92vw);
  height:min(620px, 92vw);
  display:flex;
  align-items:flex-start;
  justify-content:center;
  border-radius: 9999px;
  overflow: hidden;
}

/* Tone down any unintended rounded utilities */
input, textarea, button, a, .glass-panel, .video-container{
  border-radius:0 !important;
}

.hero-art-wrap::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:9999px;
  padding:1px;
  background: radial-gradient(circle at 30% 20%, rgba(255, 206, 90, .65), rgba(0,0,0,0) 55%),
              radial-gradient(circle at 70% 80%, rgba(255, 206, 90, .35), rgba(0,0,0,0) 60%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events:none;
  opacity:.9;
}
