/* ==========================================================
   PRXDIGY STUDIO
   ========================================================== */

:root{
  --black:#000000;
  --black-2:#0a0a0a;
  --black-3:#111111;
  --border:#1a1a1a;
  --border-hot:#2a2a2a;
  --white:#ffffff;
  --gray:#8a8a8a;
  --gray-dim:#5a5a5a;
  --red:#ff1a1a;
  --red-glow:rgba(255,26,26,0.35);
  --red-deep:#c70000;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  font-family:'Inter',sans-serif;
  background:var(--black);
  color:var(--white);
  overflow-x:hidden;
  line-height:1.5;
  font-weight:300;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* Texture overlays ---------------------------------------- */
.grid-overlay{
  position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:
    linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);
  background-size:60px 60px;
  opacity:.6;
}
.noise-overlay{
  position:fixed;inset:0;pointer-events:none;z-index:2;opacity:.03;
  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'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ==========================================================
   NAV
   ========================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:20px 40px;
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:500}
.nav-logo-img{width:28px;height:28px;object-fit:contain}
.footer-logo-img{width:24px;height:24px;object-fit:contain}
.logo-mark{
  color:var(--red);font-family:'Bebas Neue',sans-serif;
  font-size:1.2rem;line-height:1;
  text-shadow:0 0 10px var(--red-glow);
}
.logo-text{
  font-family:'JetBrains Mono',monospace;
  font-size:.8rem;letter-spacing:.15em;
}
.logo-text .red{color:var(--red)}
.nav-status{display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.2em;color:var(--gray)}
.status-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--red);
  box-shadow:0 0 8px var(--red);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.4}}

/* ==========================================================
   SHARED
   ========================================================== */
section{position:relative;z-index:3;padding:120px 40px;max-width:1400px;margin:0 auto}
.section-header{margin-bottom:60px;max-width:700px}
.section-header.center{margin-left:auto;margin-right:auto;text-align:center}
.section-num{
  display:inline-block;font-family:'JetBrains Mono',monospace;
  font-size:.75rem;letter-spacing:.3em;color:var(--red);
  margin-bottom:16px;
}
.section-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.5rem,6vw,5rem);
  letter-spacing:.02em;line-height:.95;
  margin-bottom:16px;
}
.section-title .red{color:var(--red);text-shadow:0 0 30px var(--red-glow)}
.section-sub{color:var(--gray);font-size:1rem;max-width:520px;line-height:1.6}
.section-header.center .section-sub{margin:0 auto}

/* Buttons ------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 36px;
  font-family:'JetBrains Mono',monospace;
  font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;
  font-weight:500;
  transition:all .3s cubic-bezier(.2,.8,.2,1);
  position:relative;
}
.btn-primary{
  background:var(--red);color:var(--white);
  box-shadow:0 0 30px var(--red-glow),inset 0 0 0 1px rgba(255,255,255,.15);
}
.btn-primary:hover{
  background:var(--red-deep);
  transform:translateY(-2px);
  box-shadow:0 0 50px var(--red-glow),inset 0 0 0 1px rgba(255,255,255,.25);
}
.btn-arrow{transition:transform .3s ease}
.btn:hover .btn-arrow{transform:translateX(4px)}
.btn-ghost{
  font-family:'JetBrains Mono',monospace;
  font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gray);
  border-bottom:1px solid transparent;
  padding:4px 0;
  transition:all .3s ease;
}
.btn-ghost:hover{color:var(--white);border-bottom-color:var(--red)}
.divider-dot{color:var(--gray-dim);margin:0 12px}

/* ==========================================================
   1. HERO
   ========================================================== */
.hero{
  min-height:100vh;
  padding:120px 40px 80px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
  max-width:none;margin:0;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse at 30% 50%,var(--red-glow) 0%,transparent 50%),
    radial-gradient(ellipse at 70% 80%,rgba(199,0,0,.2) 0%,transparent 60%);
  opacity:.5;
  animation:drift 15s ease-in-out infinite;
}
.hero-bg::before{
  content:'';position:absolute;inset:0;
  background:url('assets/hero-bg.png') center/cover no-repeat;
  opacity:.7;
  filter:blur(1px) saturate(1.4) brightness(1.6) contrast(1.1);
  z-index:-1;
}
.hero::after{
  content:'';position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,.45) 50%,rgba(0,0,0,.85) 100%);
  pointer-events:none;
}
@keyframes drift{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-20px,10px) scale(1.05)}
}
.hero-content{
  position:relative;z-index:3;
  max-width:1400px;width:100%;margin:0 auto;
  opacity:0;transform:translateY(20px);
  animation:hero-in 1s cubic-bezier(.2,.8,.2,1) .3s forwards;
}
@keyframes hero-in{to{opacity:1;transform:translateY(0)}}
.hero-tag{
  display:flex;align-items:center;gap:16px;
  font-family:'JetBrains Mono',monospace;
  font-size:.75rem;letter-spacing:.25em;color:var(--gray);
  margin-bottom:40px;
}
.tag-line{width:60px;height:1px;background:var(--red)}
.hero-headline{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(4rem,13vw,11rem);
  line-height:.85;letter-spacing:-.01em;
  margin-bottom:32px;
}
.hero-headline .red{color:var(--red);text-shadow:0 0 60px var(--red-glow)}
.hero-sub{
  font-size:1.1rem;color:var(--gray);
  max-width:440px;margin-bottom:56px;line-height:1.6;
}
.hero-cta{display:flex;flex-direction:column;gap:24px;align-items:flex-start}
.hero-secondary{display:flex;align-items:center;flex-wrap:wrap}
.hero-scroll{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  font-family:'JetBrains Mono',monospace;font-size:.65rem;
  letter-spacing:.3em;color:var(--gray);
  z-index:3;
}
.scroll-line{
  width:1px;height:40px;
  background:linear-gradient(to bottom,var(--red),transparent);
  animation:scroll-pulse 2s ease-in-out infinite;
}
@keyframes scroll-pulse{0%,100%{opacity:1;height:40px}50%{opacity:.3;height:25px}}

/* ==========================================================
   MARQUEE
   ========================================================== */
.marquee{
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:28px 0;overflow:hidden;
  background:var(--black-2);
  position:relative;z-index:3;
}
.marquee-track{
  display:flex;gap:40px;white-space:nowrap;
  animation:scroll 35s linear infinite;
  font-family:'Bebas Neue',sans-serif;
  font-size:1.5rem;letter-spacing:.2em;
  color:var(--gray);
}
.marquee-track span{flex-shrink:0}
.red-x{color:var(--red)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ==========================================================
   1.5 LISTEN TO THE WORK (Spotify)
   ========================================================== */
.listen-embed{
  max-width:960px;margin:0 auto;
  border:1px solid var(--border);
  background:var(--black-2);
  padding:12px;
  border-radius:14px;
  position:relative;
  overflow:hidden;
  transition:border-color .4s ease, transform .4s ease;
}
.listen-embed:hover{border-color:var(--red)}
.listen-embed iframe{display:block;width:100%;border-radius:10px}
@media (max-width:720px){
  .listen-embed iframe{height:352px}
}

/* ==========================================================
   2. PROOF / PORTFOLIO
   ========================================================== */
.proof-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:repeat(2,260px);
  gap:4px;
}
.proof-card{
  position:relative;overflow:hidden;
  background:var(--black-2);
  border:1px solid var(--border);
  transition:all .5s cubic-bezier(.2,.8,.2,1);
}
.proof-lg{grid-column:span 1;grid-row:span 2;min-height:524px}
.proof-card:hover{border-color:var(--red);transform:translateY(-3px)}
.proof-card:hover .media-placeholder::after{opacity:1}

.media-placeholder{
  position:relative;width:100%;height:100%;
  background:
    linear-gradient(135deg,var(--black-3) 0%,var(--black-2) 100%);
  display:flex;align-items:flex-end;
  padding:20px;
  overflow:hidden;
}
.media-placeholder::before{
  content:attr(data-label);
  position:absolute;top:16px;left:16px;
  font-family:'JetBrains Mono',monospace;
  font-size:.65rem;letter-spacing:.2em;
  color:var(--gray-dim);
  background:rgba(0,0,0,.6);padding:4px 8px;
  border:1px solid var(--border);
  z-index:2;
}
.media-placeholder::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 50%,var(--red-glow) 0%,transparent 60%);
  opacity:0;transition:opacity .5s ease;
}
.media-placeholder img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
}

/* Real media wrapper */
.media-wrap{
  position:relative;width:100%;height:100%;
  overflow:hidden;
  background:var(--black);
}
.media-wrap img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .8s cubic-bezier(.2,.8,.2,1), filter .4s ease;
  filter:saturate(1.1) contrast(1.05);
}
.proof-card:hover .media-wrap img{
  transform:scale(1.04);
  filter:saturate(1.3) contrast(1.1);
}
.vibe-panel:hover .media-wrap img{
  transform:scale(1.04);
}
.media-wrap::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,.5) 100%);
  pointer-events:none;
}

/* ==========================================================
   3. SERVICES
   ========================================================== */
.services-list{
  border-top:1px solid var(--border);
}
.service-row{
  display:grid;
  grid-template-columns:80px 1fr 2fr;
  gap:40px;align-items:center;
  padding:36px 0;
  border-bottom:1px solid var(--border);
  transition:all .4s ease;
  cursor:default;
}
.service-row:hover{
  background:linear-gradient(90deg,rgba(255,26,26,.04),transparent);
  padding-left:20px;
}
.service-row:hover .service-num{color:var(--red)}
.service-num{
  font-family:'JetBrains Mono',monospace;
  font-size:.85rem;letter-spacing:.2em;
  color:var(--gray-dim);
  transition:color .4s ease;
}
.service-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:2rem;letter-spacing:.05em;
}
.service-desc{color:var(--gray);font-size:.95rem}

/* ==========================================================
   4. VIBE / ENVIRONMENT
   ========================================================== */
.vibe-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:60px;align-items:center;
}
.vibe-text .section-title{margin-bottom:32px}
.vibe-copy{color:var(--gray);font-size:1.05rem;line-height:1.7;max-width:420px}
.vibe-visuals{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:200px 200px;
  gap:4px;
}
.vibe-panel{
  background:var(--black-2);
  border:1px solid var(--border);
  position:relative;overflow:hidden;
  transition:border-color .4s ease;
}
.vibe-panel:hover{border-color:var(--red)}
.vibe-panel-wide{grid-column:span 2}

/* ==========================================================
   5. EXCLUSIVITY
   ========================================================== */
.exclusive{padding:80px 40px}
.exclusive-panel{
  position:relative;
  max-width:900px;margin:0 auto;
  padding:80px 60px;
  background:var(--black-2);
  border:1px solid var(--border);
  text-align:center;
}
.panel-corner{
  position:absolute;width:20px;height:20px;
  border:1px solid var(--red);
}
.panel-corner.tl{top:-1px;left:-1px;border-right:0;border-bottom:0}
.panel-corner.tr{top:-1px;right:-1px;border-left:0;border-bottom:0}
.panel-corner.bl{bottom:-1px;left:-1px;border-right:0;border-top:0}
.panel-corner.br{bottom:-1px;right:-1px;border-left:0;border-top:0}
.exclusive-label{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:.7rem;letter-spacing:.3em;color:var(--red);
  margin-bottom:24px;
}
.exclusive-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.5rem,6vw,4.5rem);
  letter-spacing:.02em;line-height:.95;
  margin-bottom:40px;
}
.exclusive-rules{
  list-style:none;
  display:inline-flex;flex-direction:column;gap:16px;
  text-align:left;margin-bottom:40px;
}
.exclusive-rules li{
  display:flex;align-items:center;gap:16px;
  font-family:'JetBrains Mono',monospace;
  font-size:.9rem;color:var(--white);
  letter-spacing:.05em;
}
.rule-x{color:var(--red);font-size:1rem;text-shadow:0 0 10px var(--red-glow)}
.exclusive-note{color:var(--gray);max-width:480px;margin:0 auto;font-size:.95rem}

/* ==========================================================
   6. FINAL CTA + FORM
   ========================================================== */
.intake-form{
  max-width:700px;margin:0 auto;
  display:flex;flex-direction:column;gap:28px;
}
.form-row{display:flex;flex-direction:column;gap:10px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.intake-form label{
  font-family:'JetBrains Mono',monospace;
  font-size:.7rem;letter-spacing:.25em;color:var(--gray);
}
.intake-form input,
.intake-form textarea,
.intake-form select{
  width:100%;
  background:var(--black-2);
  border:1px solid var(--border);
  color:var(--white);
  padding:16px 18px;
  font-family:'Inter',sans-serif;
  font-size:.95rem;
  transition:all .3s ease;
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  border-radius:0;
}
.intake-form select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23ff1a1a' fill='none' stroke-width='1.5'/></svg>");
  background-repeat:no-repeat;
  background-position:right 18px center;
  padding-right:44px;
}
.intake-form input:focus,
.intake-form textarea:focus,
.intake-form select:focus{
  outline:none;
  border-color:var(--red);
  background:var(--black-3);
  box-shadow:0 0 0 3px rgba(255,26,26,.1);
}
.intake-form textarea{resize:vertical;min-height:90px;font-family:inherit}
.intake-form input.error,
.intake-form textarea.error,
.intake-form select.error{
  border-color:var(--red);
  animation:shake .4s ease;
}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-4px)}
  75%{transform:translateX(4px)}
}
.btn-submit{
  margin-top:12px;
  align-self:flex-start;
  justify-content:center;
  padding:20px 44px;
}

/* Form SMS/legal disclaimer */
.form-disclaimer{
  margin-top:20px;
  font-family:'JetBrains Mono',monospace;
  font-size:.68rem;letter-spacing:.08em;
  color:var(--gray-dim);line-height:1.7;
  max-width:620px;
}
.form-disclaimer a{
  color:var(--gray);
  border-bottom:1px solid var(--border);
  transition:all .3s ease;
}
.form-disclaimer a:hover{
  color:var(--red);
  border-bottom-color:var(--red);
}

/* Success state */
.form-success{
  max-width:700px;margin:0 auto;
  text-align:center;padding:60px 40px;
  border:1px solid var(--red);
  background:rgba(255,26,26,.05);
  animation:fade-in .6s ease;
}
@keyframes fade-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.success-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:50%;
  border:1px solid var(--red);color:var(--red);
  font-size:1.5rem;margin-bottom:24px;
  box-shadow:0 0 30px var(--red-glow);
}
.form-success h3{
  font-family:'Bebas Neue',sans-serif;
  font-size:2rem;letter-spacing:.05em;margin-bottom:12px;
}
.form-success p{color:var(--gray)}
.form-success a{color:var(--red);text-decoration:underline}

/* Final CTA */
.final-cta{max-width:700px;margin:80px auto 0;text-align:center}
.final-divider{height:1px;background:var(--border);margin-bottom:24px}
.final-or{
  font-family:'JetBrains Mono',monospace;
  font-size:.75rem;letter-spacing:.3em;color:var(--gray-dim);
  margin-bottom:32px;
}
.final-buttons{
  display:flex;flex-wrap:wrap;gap:20px;
  justify-content:center;align-items:center;
}

/* ==========================================================
   FOOTER
   ========================================================== */
.footer{
  border-top:1px solid var(--border);
  padding:40px;position:relative;z-index:3;
}
.footer-grid{
  max-width:1400px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:20px;
}
.footer-brand{
  display:flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;
  font-size:.8rem;letter-spacing:.15em;
}
.footer-meta{
  display:flex;gap:24px;
  font-family:'JetBrains Mono',monospace;
  font-size:.7rem;letter-spacing:.2em;color:var(--gray-dim);
  flex-wrap:wrap;align-items:center;
}
.footer-link{
  color:var(--gray);
  border-bottom:1px solid transparent;
  transition:all .3s ease;
}
.footer-link:hover{
  color:var(--red);
  border-bottom-color:var(--red);
}

/* ==========================================================
   REVEAL ON SCROLL
   ========================================================== */
.reveal{opacity:0;transform:translateY(30px);transition:all .9s cubic-bezier(.2,.8,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media (max-width:900px){
  .nav{padding:16px 20px}
  .nav-status{display:none}
  section{padding:80px 20px}
  .hero{padding:100px 20px 60px}
  .hero-scroll{display:none}

  .proof-grid{
    grid-template-columns:repeat(2,1fr);
    grid-template-rows:repeat(3,200px);
  }
  .proof-lg{grid-column:span 2;grid-row:span 1;min-height:200px}

  .service-row{
    grid-template-columns:60px 1fr;
    gap:20px;
  }
  .service-row .service-desc{grid-column:2;font-size:.9rem}
  .service-name{font-size:1.6rem}

  .vibe-grid{grid-template-columns:1fr;gap:40px}
  .vibe-visuals{grid-template-rows:180px 180px}

  .exclusive-panel{padding:50px 28px}

  .form-grid{grid-template-columns:1fr;gap:28px}
  .btn-submit{align-self:stretch}

  .final-buttons{flex-direction:column;gap:24px}

  .hero-secondary{flex-direction:column;align-items:flex-start;gap:12px}
  .divider-dot{display:none}

  .footer-grid{flex-direction:column;text-align:center}
  .footer-meta{flex-direction:column;gap:8px}
}
