/* ===========================================================
   MAD MUNNY — madmunny.com
   Reggae-Cumbia artist site. Dark Miami-neon theme.
   =========================================================== */

:root{
  /* Brand palette (from the official Mad Munny colour system) */
  --gold:#F0C428;
  --green:#56A142;
  --orange:#EB881F;
  --purple:#623078;
  --magenta:#BB3388;
  --cyan:#48B7D6;

  /* UI tones */
  --bg:#08070c;
  --bg-2:#0d0c13;
  --card:#15131d;
  --card-2:#1c1928;
  --line:rgba(255,255,255,.09);
  --ink:#f5f3f9;
  --muted:#9c98ab;

  --maxw:1180px;
  --radius:18px;
  --shadow:0 24px 60px -20px rgba(0,0,0,.8);
  --font-display:'Russo One',system-ui,sans-serif;
  --font-body:'Manrope',system-ui,-apple-system,Segoe UI,sans-serif;
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
iframe{border:0}
section{position:relative}

/* ---------- Shared layout ---------- */
.section{
  max-width:var(--maxw);
  margin:0 auto;
  padding:96px 22px;
}
.kicker{
  font-family:var(--font-display);
  font-size:.82rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:14px;
}
.section__head{max-width:680px;margin:0 auto 52px;text-align:center}
.section__title{
  font-family:var(--font-display);
  font-size:clamp(2.1rem,5.6vw,3.6rem);
  line-height:1.05;
  letter-spacing:.01em;
}
.section__lead{color:var(--muted);margin-top:16px;font-size:1.05rem}
.grad{
  background:linear-gradient(100deg,var(--gold),var(--orange),var(--magenta),var(--cyan));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:800;font-size:.98rem;
  padding:14px 24px;border-radius:999px;
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
  white-space:nowrap;
}
.btn svg{width:20px;height:20px;fill:currentColor;flex:none}
.btn:hover{transform:translateY(-3px)}
.btn:active{transform:translateY(-1px)}
.btn--spotify{background:#1ED760;color:#062b13;box-shadow:0 12px 30px -10px rgba(30,215,96,.6)}
.btn--apple{background:#fff;color:#111}
.btn--youtube{background:#FF0033;color:#fff;box-shadow:0 12px 30px -10px rgba(255,0,51,.55)}
.btn--gold{background:linear-gradient(120deg,var(--gold),var(--orange));color:#2a1500;box-shadow:0 12px 30px -10px rgba(240,196,40,.55)}
.btn--ghost{background:rgba(255,255,255,.06);color:var(--ink);border:1px solid var(--line)}
.btn--ghost:hover{background:rgba(255,255,255,.12)}

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;
  background:rgba(8,7,12,0);
  transition:background .3s ease,border-color .3s ease,padding .3s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(8,7,12,.9);
  backdrop-filter:blur(14px);
  border-bottom-color:var(--line);
  padding:10px 22px;
}
.nav__brand{display:flex;align-items:center;gap:11px}
.nav__mark{width:38px;height:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.6))}
.nav__name{
  font-family:var(--font-display);font-size:1.05rem;letter-spacing:.14em;
}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{
  font-weight:700;font-size:.95rem;color:var(--muted);
  transition:color .15s ease;
}
.nav__links a:hover{color:var(--ink)}
.nav__cta{
  font-family:var(--font-display);font-size:.85rem;letter-spacing:.06em;
  color:#2a1500 !important;
  background:linear-gradient(120deg,var(--gold),var(--orange));
  padding:10px 18px;border-radius:999px;
  box-shadow:0 10px 26px -12px rgba(240,196,40,.7);
  transition:transform .16s ease;
}
.nav__cta:hover{transform:translateY(-2px)}
.nav__toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__toggle span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.25s}
.nav.open .nav__toggle span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav.open .nav__toggle span:nth-child(2){opacity:0}
.nav.open .nav__toggle span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
  padding:120px 22px 90px;
  overflow:hidden;
  background:
    radial-gradient(900px 500px at 50% -10%,rgba(98,48,120,.45),transparent 70%),
    var(--bg);
}
.hero__glow{
  position:absolute;border-radius:50%;
  filter:blur(90px);opacity:.55;z-index:0;
  animation:drift 17s ease-in-out infinite alternate;
}
.hero__glow--1{width:440px;height:440px;background:var(--magenta);top:-80px;left:-90px}
.hero__glow--2{width:520px;height:520px;background:var(--cyan);bottom:-150px;right:-120px;animation-delay:-5s}
.hero__glow--3{width:380px;height:380px;background:var(--green);bottom:40px;left:30%;animation-delay:-9s;opacity:.4}
@keyframes drift{
  from{transform:translate(0,0) scale(1)}
  to{transform:translate(40px,-30px) scale(1.15)}
}

.hero__inner{position:relative;z-index:2;max-width:780px;width:100%}
.hero__pill{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:700;font-size:.85rem;letter-spacing:.04em;
  padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid var(--line);
  color:var(--ink);margin-bottom:30px;
  transition:border-color .2s ease,background .2s ease;
}
.hero__pill:hover{border-color:var(--cyan);background:rgba(72,183,214,.12)}
.hero__pill .dot{
  width:9px;height:9px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 0 rgba(86,161,66,.7);
  animation:pulse 2.2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(86,161,66,.7)}
  70%{box-shadow:0 0 0 12px rgba(86,161,66,0)}
  100%{box-shadow:0 0 0 0 rgba(86,161,66,0)}
}
.hero__mascot{
  width:128px;height:auto;margin:0 auto 6px;
  filter:drop-shadow(0 14px 30px rgba(0,0,0,.7));
  animation:float 4.5s ease-in-out infinite;
}
@keyframes float{50%{transform:translateY(-14px)}}
.hero__wordmark{
  width:min(560px,86vw);height:auto;margin:0 auto 8px;
  filter:drop-shadow(0 10px 30px rgba(0,0,0,.6));
}
.hero__title{
  font-family:var(--font-display);
  font-size:clamp(1.2rem,3.6vw,2.1rem);
  line-height:1.2;margin-top:8px;
  overflow-wrap:break-word;
}
.hero__sub{
  color:var(--muted);max-width:560px;margin:16px auto 0;font-size:1.05rem;
}
.hero__cta{
  display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:32px;
}
.hero__scroll{
  position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;
  width:26px;height:42px;border:2px solid rgba(255,255,255,.3);border-radius:14px;
}
.hero__scroll span{
  position:absolute;top:8px;left:50%;width:4px;height:8px;margin-left:-2px;
  background:var(--ink);border-radius:2px;
  animation:scroll 1.7s infinite;
}
@keyframes scroll{0%{opacity:0;transform:translateY(0)}40%{opacity:1}80%{opacity:0;transform:translateY(12px)}}

/* ===========================================================
   MARQUEE
   =========================================================== */
.marquee{
  background:linear-gradient(90deg,var(--purple),var(--magenta),var(--orange),var(--cyan));
  padding:13px 0;overflow:hidden;white-space:nowrap;
}
.marquee__track{display:flex;width:max-content;animation:marquee 32s linear infinite}
.marquee__track span{
  font-family:var(--font-display);font-size:1rem;letter-spacing:.05em;
  color:#0c0a12;text-transform:uppercase;
}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ===========================================================
   VIDEOS
   =========================================================== */
.video-feature{
  max-width:920px;margin:0 auto;
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid var(--line);
}
.video-facade,.video-frame{
  position:relative;display:block;width:100%;
  aspect-ratio:16/9;background:#000;
}
.video-facade__img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease,filter .3s ease;
}
.video-facade:hover .video-facade__img{transform:scale(1.05);filter:brightness(.78)}
.video-facade__play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:84px;height:84px;border-radius:50%;
  background:linear-gradient(120deg,var(--orange),var(--magenta));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 40px -8px rgba(187,51,136,.7);
  transition:transform .2s ease;
}
.video-facade:hover .video-facade__play{transform:translate(-50%,-50%) scale(1.12)}
.video-facade__play svg{width:34px;height:34px;fill:#fff;margin-left:4px}
.video-facade__label{
  position:absolute;left:0;right:0;bottom:0;
  padding:34px 20px 16px;
  background:linear-gradient(transparent,rgba(0,0,0,.85));
  font-family:var(--font-display);font-size:1.05rem;text-align:left;
}
.video-feature iframe{width:100%;aspect-ratio:16/9;display:block}

.video-strip{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
  margin-top:20px;
}
.video-thumb{
  position:relative;width:200px;aspect-ratio:16/9;
  border-radius:12px;overflow:hidden;
  border:2px solid var(--line);
  transition:border-color .2s ease,transform .2s ease;
}
.video-thumb img{width:100%;height:100%;object-fit:cover}
.video-thumb:hover{transform:translateY(-4px)}
.video-thumb.is-active{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(72,183,214,.25)}
.video-thumb__play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:40px;height:40px;border-radius:50%;
  background:rgba(0,0,0,.6);color:#fff;font-size:.8rem;
  display:flex;align-items:center;justify-content:center;padding-left:3px;
}
.video-thumb__name{
  position:absolute;left:0;right:0;bottom:0;
  padding:18px 10px 7px;
  background:linear-gradient(transparent,rgba(0,0,0,.85));
  font-weight:800;font-size:.85rem;text-align:left;
}
.videos__more{text-align:center;margin-top:30px}

/* ===========================================================
   MUSIC
   =========================================================== */
.releases{display:grid;gap:24px}
@media(min-width:860px){.releases{grid-template-columns:repeat(3,1fr)}}

.release{
  background:linear-gradient(180deg,var(--card),var(--bg-2));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:transform .22s ease,border-color .22s ease;
}
.release::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(360px 160px at 50% 0,var(--accent),transparent 70%);
  opacity:.16;pointer-events:none;
}
.release:hover{transform:translateY(-6px);border-color:var(--accent)}
.release--badman{--accent:var(--orange)}
.release--hateme{--accent:var(--magenta)}
.release--moonlight{--accent:var(--cyan)}

.release__art{position:relative;border-radius:13px;overflow:hidden;margin-bottom:16px}
.release__art img{
  width:100%;aspect-ratio:1/1;object-fit:cover;
  transition:transform .4s ease;
}
.release:hover .release__art img{transform:scale(1.06)}
.release__art::after{
  content:"";position:absolute;inset:0;
  box-shadow:inset 0 0 0 2px var(--accent);
  border-radius:13px;opacity:.55;
}
.release__no{
  position:absolute;top:10px;left:10px;
  font-family:var(--font-display);font-size:.9rem;
  background:var(--accent);color:#0c0a12;
  width:32px;height:32px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
}
.release__body{display:flex;flex-direction:column;flex:1}
.release__tag{
  font-size:.74rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);
}
.release__title{
  font-family:var(--font-display);font-size:1.55rem;margin:4px 0 8px;
}
.release__desc{color:var(--muted);font-size:.94rem;flex:1}
.spotify-embed{
  border-radius:12px;margin:16px 0 14px;
  min-height:152px;background:var(--card-2);
}
.release__links{display:flex;flex-wrap:wrap;gap:9px}
.chip{
  display:inline-flex;align-items:center;
  font-weight:800;font-size:.82rem;
  padding:9px 14px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  transition:transform .15s ease,background .15s ease,border-color .15s ease;
}
.chip:hover{transform:translateY(-2px)}
.chip--spotify:hover{background:rgba(30,215,96,.16);border-color:#1ED760;color:#3ff58a}
.chip--apple:hover{background:rgba(255,255,255,.14);border-color:#fff}
.chip--yt:hover{background:rgba(255,0,51,.16);border-color:#FF0033;color:#ff6b87}
.chip--sc:hover{background:rgba(235,136,31,.16);border-color:var(--orange);color:#ffae5e}

/* ===========================================================
   STORY
   =========================================================== */
.story{padding-top:40px}
.story__grid{display:grid;gap:52px;align-items:center}
@media(min-width:900px){.story__grid{grid-template-columns:340px 1fr}}
.story__photo{position:relative;max-width:340px;margin:0 auto}
.story__photo>img:first-child{
  display:block;width:100%;height:auto;
  border-radius:var(--radius);
  border:1px solid var(--line);box-shadow:var(--shadow);
}
.story__logo{
  position:absolute;right:-20px;bottom:-26px;
  width:104px;height:auto;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.9));
  animation:float 4.5s ease-in-out infinite;
}
.story__text p{color:var(--muted);margin-top:16px;font-size:1.05rem}
.story__text strong{color:var(--ink)}
.story__quote{
  font-family:var(--font-display);
  font-size:clamp(1.3rem,2.6vw,1.7rem);
  line-height:1.35;margin-top:26px;padding-left:20px;
  border-left:4px solid var(--gold);
  color:var(--ink);
}

/* ===========================================================
   CONNECT + SIGNUP
   =========================================================== */
.social-grid{
  display:flex;flex-wrap:wrap;justify-content:center;gap:14px;
  max-width:760px;margin:0 auto;
}
.social{
  flex:1 1 130px;max-width:180px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:22px 12px;border-radius:14px;
  background:var(--card);border:1px solid var(--line);
  font-weight:800;font-size:.9rem;
  transition:transform .18s ease,border-color .18s ease,background .18s ease;
}
.social svg{width:30px;height:30px;fill:var(--ink);transition:fill .18s ease}
.social:hover{transform:translateY(-5px)}
.social--spotify:hover{border-color:#1ED760}.social--spotify:hover svg{fill:#1ED760}
.social--apple:hover{border-color:#fff}.social--apple:hover svg{fill:#fff}
.social--youtube:hover{border-color:#FF0033}.social--youtube:hover svg{fill:#FF0033}
.social--instagram:hover{border-color:#E1306C}.social--instagram:hover svg{fill:#E1306C}
.social--sc:hover{border-color:var(--orange)}.social--sc:hover svg{fill:var(--orange)}

.signup{
  max-width:760px;margin:54px auto 0;
  background:linear-gradient(120deg,var(--card),var(--card-2));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:34px;text-align:center;
}
.signup__text h3{font-family:var(--font-display);font-size:1.5rem}
.signup__text p{color:var(--muted);margin-top:8px}
.signup__form{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
  margin-top:22px;
}
.signup__form input{
  flex:1;min-width:240px;max-width:340px;
  padding:14px 18px;border-radius:999px;
  background:var(--bg);border:1px solid var(--line);
  color:var(--ink);font-size:1rem;font-family:inherit;
}
.signup__form input:focus{outline:2px solid var(--cyan);outline-offset:1px}
.signup__msg{margin-top:14px;font-weight:700;min-height:1.2em}
.signup__msg.ok{color:var(--green)}
.signup__msg.err{color:var(--magenta)}

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{
  background:var(--bg-2);border-top:1px solid var(--line);
  padding:54px 22px 28px;margin-top:40px;
}
.footer__top{
  max-width:var(--maxw);margin:0 auto;
  display:flex;flex-wrap:wrap;gap:30px;
  align-items:center;justify-content:space-between;
}
.footer__brand img{width:200px;height:auto}
.footer__links{display:flex;gap:24px;flex-wrap:wrap}
.footer__links a{color:var(--muted);font-weight:700;transition:color .15s ease}
.footer__links a:hover{color:var(--ink)}
.footer__label{
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--cyan);font-weight:800;margin-bottom:4px;
}
.footer__contact a{font-weight:700}
.footer__contact a:hover{color:var(--gold)}
.footer__bar{
  max-width:var(--maxw);margin:34px auto 0;padding-top:20px;
  border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;
  color:var(--muted);font-size:.85rem;
}
.footer__tag{font-family:var(--font-display);letter-spacing:.04em}

/* ===========================================================
   SCROLL REVEAL
   =========================================================== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ===========================================================
   RESPONSIVE — NAV
   =========================================================== */
@media(max-width:760px){
  .nav__toggle{display:flex}
  .nav__links{
    position:fixed;top:0;right:0;
    height:100svh;width:min(78vw,320px);
    flex-direction:column;align-items:flex-start;justify-content:center;
    gap:26px;padding:40px;
    background:rgba(13,12,19,.98);backdrop-filter:blur(16px);
    border-left:1px solid var(--line);
    transform:translateX(110%);transition:transform .32s ease;
  }
  .nav.open .nav__links{transform:translateX(0)}
  .nav__links a{font-size:1.2rem}
  .nav__cta{margin-top:6px}
  .section{padding:72px 20px}
  .signup{padding:26px}
}

@media(max-width:480px){
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%;justify-content:center}
  .video-thumb{width:46%}
  .release{padding:14px}
}

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