:root{
  --bg:#0b0c10;
  --bg2:#0f1118;
  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.08);
  --line:rgba(255,255,255,.12);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.72);
  --soft:rgba(255,255,255,.58);
  --accent:#8b5cf6;
  --accent2:#22c55e;
  --shadow: 0 16px 60px rgba(0,0,0,.55);
  --radius:18px;
  --radius2:24px;
  --max: 1120px;
  --neo-cyan: #22d3ee;
  --neo-fuchsia: #d946ef;
  --neo-grad: linear-gradient(90deg, var(--neo-cyan), var(--neo-fuchsia));
  --grid-step: 48px;         /* tamanho dos quadrados */
  --grid-line: rgba(255,255,255,.055);
  --hero-glow: .26;          /* luminosidade do cyan/fuchsia */
  --grid-opacity: .50;       /* força da grelha */  
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:radial-gradient(1200px 800px at 20% 10%, rgba(139,92,246,.22), transparent 55%),
             radial-gradient(1000px 700px at 80% 20%, rgba(34,197,94,.12), transparent 50%),
             linear-gradient(180deg, var(--bg), #07080c 60%, #06070a);
  min-height:100vh;
}

img{max-width:100%; height:auto}

.container{max-width:var(--max); margin:0 auto; padding:0 20px}

.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left:12px; top:12px; width:auto; height:auto; padding:10px 12px;
  border-radius:12px; background:rgba(0,0,0,.75); color:#fff; z-index:9999;
  outline:2px solid rgba(255,255,255,.35);
}

/* Topbar */
.topbar{
  position:fixed; top:0; left:0; right:0;
  z-index:50;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(7,8,12,.52);
  border-bottom:1px solid rgba(255,255,255,.10);
}
.topbar__inner{
  display:flex; align-items:center; gap:16px;
  height:76px;
}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none}
.brand__logo{width:54px; height:54px; object-fit:contain; filter: drop-shadow(0 10px 30px rgba(0,0,0,.35));}
.brand__name{
  font-weight:700;
  letter-spacing:.02em;
  font-size:14px;
  color:rgba(255,255,255,.88);
  white-space:nowrap;
}

.nav{display:flex; gap:14px; align-items:center; margin-left:auto}
.nav__link{
  text-decoration:none; color:var(--muted);
  font-weight:500; font-size:14px;
  padding:10px 10px;
  border-radius:12px;
  transition: all .18s ease;
}


/* Menu (tabs) com underline em gradiente */
.nav__link{
  position: relative;
  text-decoration: none;
  color: var(--muted);
  font-weight: 500;
  font-size: 14px;
  padding: 10px 12px;
  border-radius: 12px;
  transition: color .18s ease, background .18s ease;
}

/* underline em gradiente (invisível por defeito) */
.nav__link::after{
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 6px;
  height: 2px;
  border-radius: 999px;

  /* CORES IGUAIS AO HEADER */
  background: linear-gradient(
    90deg,
    #22d3ee,
    #d946ef
  );

  opacity: 0;
  transform: scaleX(0);
  transform-origin: center;
  transition: opacity .18s ease, transform .18s ease;
}

/* hover */
.nav__link:hover{
  color: var(--text);
  background: rgba(255,255,255,.04);
}

.nav__link:hover::after{
  opacity: 1;
  transform: scaleX(1);
}

/* estado activo */
.nav__link.is-active{
  color: var(--text);
}

.nav__link.is-active::after{
  opacity: 1;
  transform: scaleX(1);
}


.topbar__cta{display:flex}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  color:var(--text);
  background:rgba(255,255,255,.05);
  transition: transform .14s ease, background .14s ease, border-color .14s ease;
}
.btn:hover{transform:translateY(-1px); background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.24)}
.btn:active{transform:translateY(0)}
.btn--primary{
  background: linear-gradient(135deg, rgba(139,92,246,.95), rgba(34,197,94,.75));
  border-color: rgba(255,255,255,.20);
  box-shadow: 0 16px 60px rgba(139,92,246,.18);
}
.btn--primary:hover{background: linear-gradient(135deg, rgba(139,92,246,1), rgba(34,197,94,.85))}
.btn--ghost{background:rgba(255,255,255,.03)}

.menuBtn{
  display:none;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.04);
  margin-left:auto;
}
.menuBtn span{
  display:block;
  width:18px; height:2px;
  margin:4px auto;
  background:rgba(255,255,255,.75);
  border-radius:2px;
}

.mobileMenu{
  border-top:1px solid rgba(255,255,255,.10);
  background:rgba(7,8,12,.72);
  backdrop-filter:saturate(140%) blur(12px);
}
.mobileMenu__inner{padding:14px 20px 18px; display:grid; gap:10px}
.mobileMenu__link{
  display:flex; align-items:center; gap:10px;
  text-decoration:none; color:var(--text);
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
}
.mobileMenu__link i{opacity:.9}
.mobileMenu__cta{width:100%}

/* Hero (fixed background) */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;

  /* resolve stacking / z-index */
  z-index:0;
  isolation:isolate;
}

/* imagem de fundo */
.hero__media{
  position:fixed;
  inset:0;
  overflow:hidden;
  z-index:0; /* sem negativos */
}

/* (se já não usas vídeo, podes apagar a classe .hero__video do CSS) */
.hero__fallback{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  pointer-events:none;

  opacity:1; /* ✅ antes estava 0, por isso desaparecia */
}

/* ✅ GRELHA igual à imagem (principais + secundárias) + fade */
.hero__overlay::before{
  content:"";
  position:absolute;
  inset:0;

  background:
    /* principais (48px) */
    repeating-linear-gradient(
      to right,
      rgba(255,255,255,.075) 0px,
      rgba(255,255,255,.075) 1px,
      transparent 1px,
      transparent 48px
    ),
    repeating-linear-gradient(
      to bottom,
      rgba(255,255,255,.075) 0px,
      rgba(255,255,255,.075) 1px,
      transparent 1px,
      transparent 48px
    ),
    /* secundárias (12px) */
    repeating-linear-gradient(
      to right,
      rgba(255,255,255,.030) 0px,
      rgba(255,255,255,.030) 1px,
      transparent 1px,
      transparent 12px
    ),
    repeating-linear-gradient(
      to bottom,
      rgba(255,255,255,.030) 0px,
      rgba(255,255,255,.030) 1px,
      transparent 1px,
      transparent 12px
    );

  opacity:.62;

  /* ✅ fade/vinheta para ficar como o print */
  -webkit-mask-image: radial-gradient(1200px 520px at 50% 12%, #000 0%, #000 55%, transparent 100%);
  mask-image: radial-gradient(1200px 520px at 50% 12%, #000 0%, #000 55%, transparent 100%);
}

/* ✅ brilho extra suave (aumenta a “luminosidade”) */
.hero__overlay{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;

  /* mais luminoso */
  background:
    radial-gradient(900px 520px at 18% 18%, rgba(34,211,238,.30), transparent 62%),
    radial-gradient(900px 520px at 82% 18%, rgba(217,70,239,.26), transparent 62%),

    /* menos “preto” para abrir o fundo */
    linear-gradient(180deg, rgba(0,0,0,.38), rgba(0,0,0,.30) 30%, rgba(0,0,0,.58));
}


/* Conteúdo acima de tudo */
.hero__content{
  position:relative;
  z-index:2;
  padding-top:96px;
  padding-bottom:60px;
}
.hero__content--center{display:flex; justify-content:center}



.heroCard{
  width:min(720px, 100%);
  background: linear-gradient(180deg, rgba(12,13,18,.52), rgba(12,13,18,.26));
  border:1px solid rgba(255,255,255,.16);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  padding: 28px 28px 22px;
}
.heroCard--center{text-align:center}
.heroCard--center .heroCard__actions{justify-content:center}
.eyebrow{margin:0 0 8px; letter-spacing:.16em; text-transform:uppercase; font-size:12px; color:rgba(255,255,255,.72)}
.heroCard h1{margin:0 0 10px; font-size: clamp(28px, 4vw, 44px); line-height:1.08}
.lead{margin:0 0 18px; font-size:16px; line-height:1.6; color:var(--muted)}
.heroCard__actions{display:flex; gap:10px; flex-wrap:wrap}
.micro{margin:14px 0 0; font-size:13px; color:var(--soft)}

/* Scroll hint (arrow) */
.scrollHint{
  position:absolute;
  left:50%;
  bottom:26px;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.22);
  backdrop-filter: blur(8px);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  transform: translateX(-50%);
  animation: hint 1.8s ease-in-out infinite;
}

.scrollHint:hover{
  background: rgba(0,0,0,.30);
  border-color: rgba(255,255,255,.24);
}

.scrollHint__arrow{
  width:10px;
  height:10px;
  border-right:2px solid rgba(255,255,255,.78);
  border-bottom:2px solid rgba(255,255,255,.78);
  transform: rotate(45deg);
  margin-top:-2px;
}

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

/* Sections (fundos sólidos, nunca transparentes) */
.section{
  padding:76px 0;
  position:relative;
  z-index:1;
  background-color: var(--bg);
}

/* ALT: base sólida + overlay com gradiente e grid (sem transparência no “fundo real”) */
.section--alt{
  padding:76px 0;
  position:relative;
  z-index:1;

  /* ✅ base sólida (isto impede “transparência”) */
  background-color: var(--bg2);

  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}

/* ✅ overlay (gradiente cyan->roxo + grid subtil) */
.section--alt::before{
  content:"";
  position:absolute;
  inset:-1px; /* evita gaps nas bordas */
  pointer-events:none;

  background:
    /* glow cyan (esquerda) */
    radial-gradient(900px 320px at 0% 0%,
      rgba(34,211,238,.22),
      transparent 60%
    ),
    /* glow fuchsia (direita) */
    radial-gradient(900px 320px at 100% 0%,
      rgba(217,70,239,.18),
      transparent 60%
    ),
    /* grid horizontal */
    repeating-linear-gradient(
      to bottom,
      rgba(255,255,255,.045) 0px,
      rgba(255,255,255,.045) 1px,
      transparent 1px,
      transparent 48px
    ),
    /* grid vertical */
    repeating-linear-gradient(
      to right,
      rgba(255,255,255,.045) 0px,
      rgba(255,255,255,.045) 1px,
      transparent 1px,
      transparent 48px
    ),
    /* vinheta escura por cima para ficar “premium” */
    linear-gradient(
      180deg,
      rgba(15,17,24,.00) 0%,
      rgba(15,17,24,.55) 35%,
      rgba(15,17,24,.88) 100%
    );

  opacity:.95;
}

/* ✅ garante que o conteúdo fica acima do overlay */
.section--alt > *{
  position:relative;
  z-index:1;
}



.section__header{max-width:820px}
.section__header h2{margin:0 0 10px; font-size: clamp(22px, 2.5vw, 30px)}
.section__header p{margin:0; color:var(--muted); line-height:1.7}
.section__micro{margin:16px 0 0; color:var(--soft); font-size:13px}

.grid{
  margin-top:22px;
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:14px;
}
.card{
  display:block;
  text-decoration:none;
  color:var(--text);
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  border-radius: var(--radius);
  padding:18px;
  transition: transform .16s ease, background .16s ease, border-color .16s ease;
}
.card:hover{transform:translateY(-2px); background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.18)}
.card__icon{font-size:26px; margin-bottom:10px}
.card__title{font-weight:700; font-size:16px}
.card__meta{color:var(--soft); font-size:13px; margin-top:6px}

.about{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:18px;
  align-items:stretch;
  
}
/* Tirar a grelha só do #about */
#about.section--alt::before{
  background:
    radial-gradient(900px 320px at 0% 0%, rgba(34,211,238,.22), transparent 60%),
    radial-gradient(900px 320px at 100% 0%, rgba(217,70,239,.18), transparent 60%),
    linear-gradient(180deg, rgba(15,17,24,.00) 0%, rgba(15,17,24,.55) 35%, rgba(15,17,24,.88) 100%);
}

.about h2{margin:0 0 10px}
.about p{margin:0 0 14px; color:var(--muted); line-height:1.7}
.about__chips{display:flex; flex-wrap:wrap; gap:10px}
.chip{
  padding:9px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.78);
  font-size:13px;
}
.panel{
  height:100%;
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  padding:18px;
  box-shadow: 0 12px 40px rgba(0,0,0,.35);
}
.panel h3{margin:0 0 8px; font-size:18px}
.panel p{margin:0 0 14px; color:var(--muted); line-height:1.6}
.panel__actions{display:flex; gap:10px; flex-wrap:wrap}

/* Footer (also solid background) */
.footer{
  padding:42px 0 28px;
  position:relative;
  z-index:1;
  background-color: var(--bg);
}

.footer__inner{
  display:grid;
  grid-template-columns: 1.2fr 1fr;
  gap:22px;
  align-items:start;
}
.footer__logo{width:52px; height:52px; object-fit:contain; opacity:.92}
.footer__lead{margin:10px 0 0; color:var(--muted)}
.footer__links{display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:10px}
.social{
  display:flex; align-items:center; gap:10px;
  padding:12px 12px;
  border-radius:14px;
  text-decoration:none;
  color:var(--text);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
}

/* Social – apenas COR (sem linha) */
.social{
  transition: transform .16s ease, background .16s ease, border-color .16s ease;
}

/* hover geral */
.social:hover{
  background: linear-gradient(
    90deg,
    rgba(34,211,238,.10),
    rgba(217,70,239,.10)
  );
  border-color: rgba(255,255,255,.20);
  transform: translateY(-1px);
}

/* texto + ícone com gradiente */
.social:hover span,
.social:hover i,
.social:hover svg{
  background: var(--neo-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}



.footer__legal{
  grid-column:1 / -1;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:14px;
  color:rgba(255,255,255,.55);
  font-size:13px;
}
.footer__made{margin:10px 0 0; color:rgba(255,255,255,.55)}
.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}

/* Responsive */
@media (max-width: 980px){
  .grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .about{grid-template-columns: 1fr}
  .footer__inner{grid-template-columns: 1fr}
}

@media (max-width: 760px){
  .nav, .topbar__cta{display:none}
  .brand__name{display:none}
  .menuBtn{display:inline-flex; align-items:center; justify-content:center}
  .topbar__inner{height:72px}
  .hero{min-height:100vh}
  .heroCard{padding:22px}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .btn, .card{transition:none}
  .scrollHint{animation:none}
}

/* Base: deixa os icones mais "neutros" antes do hover */
.card__icon i{
  color: rgba(255,255,255,.70);
  transition: color .16s ease, transform .16s ease, filter .16s ease;
}
.card__title{
  transition: color .16s ease;
}

/* Acessibilidade: focus bonito via teclado */
.card:focus-visible{
  outline: 2px solid rgba(255,255,255,.26);
  outline-offset: 3px;
}

/* Brand hover - Spotify */
.card--spotify:hover{
  border-color: rgba(29,185,84,.70);
  background: rgba(29,185,84,.10);
  box-shadow: 0 0 0 1px rgba(29,185,84,.25), 0 18px 60px rgba(29,185,84,.12);
}
.card--spotify:hover .card__icon i,
.card--spotify:hover .card__title{
  color: #1DB954;
}
.card--spotify:hover .card__icon i{ transform: translateY(-1px); }

/* Brand hover - YouTube */
.card--youtube:hover{
  border-color: rgba(255,0,0,.65);
  background: rgba(255,0,0,.09);
  box-shadow: 0 0 0 1px rgba(255,0,0,.22), 0 18px 60px rgba(255,0,0,.10);
}
.card--youtube:hover .card__icon i,
.card--youtube:hover .card__title{
  color: #FF0000;
}
.card--youtube:hover .card__icon i{ transform: translateY(-1px); }

/* Brand hover - Amazon Music */
.card--amazon:hover{
  border-color: rgba(255,153,0,.70);
  background: rgba(255,153,0,.10);
  box-shadow: 0 0 0 1px rgba(255,153,0,.22), 0 18px 60px rgba(255,153,0,.12);
}
.card--amazon:hover .card__icon i,
.card--amazon:hover .card__title{
  color: #FF9900;
}
.card--amazon:hover .card__icon i{ transform: translateY(-1px); }

/* Brand hover - Apple Music (mais "clean", menos saturado) */
.card--apple:hover{
  border-color: rgba(255,255,255,.32);
  backgroundp: rgba(255,255,255,.06);
  background: rgba(255,255,255,.06);
  box-shadow: 0 0 0 1px rgba(255,255,255,.12), 0 18px 60px rgba(255,255,255,.06);
}
.card--apple:hover .card__icon i,
.card--apple:hover .card__title{
  color: rgba(255,255,255,.92);
}
.card--apple:hover .card__icon i{ transform: translateY(-1px); }

/* Brand hover - Deezer (magenta, discreto) */
.card--deezer:hover{
  border-color: rgba(255,0,146,.65);
  background: rgba(255,0,146,.09);
  box-shadow: 0 0 0 1px rgba(255,0,146,.20), 0 18px 60px rgba(255,0,146,.10);
}
.card--deezer:hover .card__icon i,
.card--deezer:hover .card__title{
  color: #FF0092;
}
.card--deezer:hover .card__icon i{ transform: translateY(-1px); }

/* HERO text (igual à imagem) */
.hero__content--center{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}

.heroIntro{
  max-width: 1100px;
  padding: 0 20px;
}

.heroIntro__kicker{
  margin:0 0 18px;
  text-transform:uppercase;
  letter-spacing:.38em;
  font-size: clamp(12px, 1.2vw, 15px);
  font-weight: 500;
  color: rgba(255,255,255,.70);
  text-shadow: 0 2px 18px rgba(0,0,0,.55);
}

.heroIntro__sub{
  margin:0;
  font-size: clamp(16px, 1.8vw, 22px);
  line-height:1.6;
  font-weight: 400;
  color: rgba(255,255,255,.65);
  text-shadow: 0 2px 18px rgba(0,0,0,.55);
}

/* “EXPLORAR” no scrollHint (opcional, como na imagem) */
.scrollHint{
  flex-direction: column;
  gap: 8px;
}

.scrollHint__label{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.50);
}
/* Barra preta transparente atrás do texto */
.heroStrip{
  display:inline-block;
  padding: 18px 26px;
  border-radius: 18px;

  background: rgba(0,0,0,.40);
  border: 1px solid rgba(255,255,255,.10);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  box-shadow: 0 18px 60px rgba(0,0,0,.45);
}

/* espaçamento entre as duas linhas */
.heroStrip .heroIntro__kicker{ margin:0 0 10px; }
.heroStrip .heroIntro__sub{ margin:0; }
