:root{
  /* Brand palette */
  --brand1:#BC89EC;      /* lilac/purple */
  --brand2:#F86D68;      /* coral */
  --teal:#2BB7BE;        /* teal */
  --deep:#3C2A8E;        /* deep purple */
  --amarelo:#FFFBE6;     /* cream */

  --azul:#5787DB;
  --verdeclaro:#E5F9F3;
  --verde:#39ABB6;
  --roxo:#7356AC;

  /* UI */
  --bg:#F6F7FB;
  --card:#FFFFFF;
  --muted:#64748B;
  --text:#3B4243;
  --ring:0 0 0 3px rgba(168,119,255,.35);
  --radius:16px;
  --shadow:0 10px 30px rgba(0,0,0,.06);
  scroll-behavior:smooth;
}

*{box-sizing:border-box}
html,body{
  margin:0; padding:0; background:var(--bg); color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
  letter-spacing:.1px;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}


body{
  background:
    radial-gradient(60% 45% at 20% 0%,   rgba(188,137,236,.24), transparent 60%),
    radial-gradient(55% 40% at 80% 100%, rgba(43,183,190,.16),  transparent 60%),
    linear-gradient(var(--bg), var(--bg));  /* cor base */
  background-attachment: fixed, fixed, fixed; /* o “glow” não mexe ao fazer scroll */
  background-repeat: no-repeat;
}

h1{font-size:clamp(24px,6vw,32px);line-height:1.05;margin:0 0 8px}

/* Layout base */
.container{width:min(1120px,92%);margin-inline:auto}
section {margin-top:100px; margin-bottom: 100px;}

/* Header */
header{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.7);backdrop-filter:blur(6px);
  border-bottom:1px solid rgba(15,23,42,.06)
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.2px}
.logo-img{height:28px;display:block}
.menu{display:flex;gap:18px;align-items:center}
.menu a{opacity:.9}
.menu a:hover{opacity:1}
.cta{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--brand1),var(--brand2));padding:10px 14px;border-radius:12px;font-weight:600;box-shadow:var(--shadow);color:#fff}
.hamb{display:none;width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.12);align-items:center;justify-content:center}

/* Hero */
.hero{position:relative;isolation:isolate;padding:84px 0 60px}
.glow{position:absolute;inset:auto -20% -35% -20%;
  height:420px;
  background:radial-gradient(50% 50% at 50% 50%, rgba(124,58,237,.25), rgba(34,211,238,.12) 50%, rgba(11,15,26,0) 70%);
  filter:blur(40px);z-index:-1}
/* Impede o efeito .glow de causar overflow lateral */
.glow {
  position: fixed;        /* passa a ser global e não afeta layout */
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  z-index: -1;
  overflow: clip;         /* evita o scroll horizontal */
  background: radial-gradient(
    50% 50% at 50% 50%,
    rgba(124, 58, 237, .25),
    rgba(34, 211, 238, .12) 50%,
    rgba(11, 15, 26, 0) 70%
  );
  filter: blur(40px);
}

/* Garante que o body nunca cria scroll lateral */
html, body {
  overflow-x: clip;
}


.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:36px;align-items:center}
.hero h1{font-size:clamp(32px,6vw,56px);line-height:1.05;margin:0 0 8px}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.btn{border:1px solid rgba(255,255,255,.12);padding:10px 14px;border-radius:12px}
.btn:hover{box-shadow:var(--shadow)}
.preview{background:#fff;border:1px solid rgba(15,23,42,.06);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.tiles{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.tile{aspect-ratio:1/1;border-radius:10px;display:grid;place-items:center;font-weight:800;background:#F1F5F9;border:1px solid rgba(15,23,42,.08);color:#0F172A}
.tile.ok{background:#E6FFF8;border-color:#2dd4bf}
.tile.maybe{background:#FFF4E6;border-color:#f59e0b}
.tile.no{background:#FDECEC;border-color:#f43f5e}

/* Cards genéricos */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{grid-column:span 6;background:var(--card);border:1px solid rgba(15,23,42,.06);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.card h3{margin:30px 0 8px;font-size:20px}
.card p{margin:0;color:var(--muted)}

/* ===== JOGOS ===== */
.games{ display:grid; gap:16px; grid-template-columns:1fr; }
.games h1{margin:0 0 8px;font-size:clamp(22px,3vw,28px)}

@media (min-width:900px){ .games{ grid-template-columns:repeat(4, minmax(0,1fr)); } }





/* ===== Newsletter / botão ===== */
.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}
.newsletter .cf-card {
  background: var(--card);
  border: 1px solid rgba(15,23,42,.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 32px;
}
.newsletter h2{margin:0 0 8px;font-size:clamp(22px,3vw,28px)}
.newsletter .sub{margin:0 0 16px;color:var(--muted)}
.nl{display:flex;gap:12px;flex-wrap:wrap;align-items:center;
  justify-content: center; margin: 0 auto;   max-width: 480px;
}
@media (max-width: 600px) {
  .nl {flex-direction: column;max-width: 100%;}
  .nl input, .nl .btn-cta { width: 100%;}
}
.nl input{flex:1;min-width:260px;height:44px;background:#fff;border:1px solid rgba(15,23,42,.12);border-radius:12px;padding:10px 14px;color:var(--text);box-shadow:0 1px 1px rgba(2,6,23,.02)}
.nl input::placeholder{color:#94a3b8}
.nl input:focus{outline:none;border-color:transparent;box-shadow:0 0 0 3px rgba(188,137,236,.35)}
.btn-cta{
  height:44px;padding:0 16px;border-radius:12px;border:0;font-weight:600;color:#fff;
  background:linear-gradient(135deg,var(--brand1),var(--brand2));
  box-shadow:0 8px 18px rgba(248,109,104,.18);
  cursor:pointer;transition:transform .15s, box-shadow .15s, opacity .15s;
}
.btn-cta:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(248,109,104,.22)}
.btn-cta:active{transform:translateY(0);opacity:.9}

/* Footer */
footer{padding:36px 0;color:var(--muted);border-top:1px solid rgba(15,23,42,.06);margin-top:32px;background:#fff}

/* ===== Responsive header/menu ===== */
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr}
  .grid .card, .games .game{grid-column:span 12}
  .menu{display:none}
  .menu.open{display:flex;flex-direction:column;position:absolute;left:4%;right:4%;top:58px;background:var(--card);padding:12px;border-radius:14px;border:1px solid rgba(255,255,255,.08)}
  .hamb{display:inline-flex}
}




/* Garante que a newsletter fica acima de qualquer overlay */
.newsletter {
  position: relative;
  z-index: 10;
}


/* Layout 2 colunas para a secção */
.cf-grid2{
  display:grid;
  grid-template-columns: 1fr 1fr; /* texto | imagem */
  gap: 24px;
  align-items: center;
}

/* Cartão de texto (já tens .card, reforço só padding) */
.cf-copy.card{ margin:0; }

/* Coluna da imagem */
.cf-visual{
  display:flex;
  justify-content:center; /* centra na coluna */
}

/* Imagem responsiva com moldura suave */
.cf-visual img{
  width: clamp(280px, 40vw, 520px); /* nunca gigante, nunca minúscula */
  height:auto;
  border-radius: 20px;
  background:#fff;
  box-shadow: 0 18px 46px rgba(2,6,23,.12), 0 2px 8px rgba(2,6,23,.06);
}

/* Mobile: empilha (texto em cima, imagem em baixo) */
@media (max-width: 900px){
  .cf-grid2{
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .cf-visual img{
    width: clamp(260px, 82vw, 520px);
  }
}

/* Cartão branco */
#como-funciona .cf-card {
  background: var(--card);
  border: 1px solid rgba(15,23,42,.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 32px;
    display: flex;
  align-items: center;
  padding: 0px;
}

/* Grid interna: texto + imagem dentro da mesma caixa */
#como-funciona .cf-inner {
  display: grid;
  grid-template-columns: 3fr 1fr;
  align-items: center;
  gap: 24px;
}
#como-funciona .cf-texto {
  padding: 40px;
}



/* Texto à esquerda */
#como-funciona .cf-texto h3 {
  margin: 24px 0 8px;
  font-size: 20px;
}
#como-funciona .cf-texto p {
  margin: 0;
  color: var(--muted);
}

#como-funciona .cf-imagem {
  margin-left: auto;    
  padding-right: 0;
  padding-top: 40px;
}
#como-funciona .cf-imagem img {
  display: block;
  max-width: 340px;    
  height: auto;
  border-radius: 20px;
  margin: 0;
}

#como-funciona .cf-texto p {margin-top: 5%;}
.brevemente, #como-funciona .cf-texto h1 {background-image: linear-gradient(to right, var(--brand1),var(--brand2));
  
  /* Segundo passo: apagar do fundo tudo que não estiver imediatamente atrás de texto */
  background-clip: text;
  -webkit-background-clip: text; /* Alguns navegadores precisam do prefixo */

  /* Terceiro passo: apagar o texto, deixando apenas o fundo atrás dele */
  -webkit-text-fill-color: transparent;

  /* Cor que contraste com o degradê, caso o navegador não suporte `background-clip: text` */
  color: black;
  }

/* Mobile: empilha dentro do mesmo cartão */
@media (max-width: 900px) {
  #como-funciona .cf-inner {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  #como-funciona .cf-imagem img {
    width: clamp(120px, 60vw, 300px);
  }
}


/* grupo dos badges */
.store-badges{
  display:flex;
  gap:12px;
  align-items:center;
  margin-top:10px;
  flex-wrap:wrap;
}

/* cada badge não herda line-height do texto */
.store-badges .badge{
  display:inline-flex;        /* tira baseline */
  line-height:0;              /* nada de altura extra */
  margin:7%;
}

/* o SVG não pode “encolher” nem cortar */
.store-badges .badge svg{
  display:block;              /* remove baseline do SVG */
  height:44px;                /* um pouco mais alto */
  overflow:visible;           /* evita clip de sombras/raios */
}

.store-badges {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
  margin: 24px 0;
}

.store-badges img {
  width: 180px;        
  max-width: 100%; 
  height: auto;
}


/* grid responsiva */
.cards{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 20px;
  width:min(1120px, 92%); 
  margin-inline:auto; }

@media (min-width: 900px){
  .cards > *{ grid-column: span 3; }  /* 4 por linha */
}
@media (max-width: 899px){
  .cards > *{ grid-column: span 6; }  /* 2 por linha */
}
@media (max-width: 560px){
  .cards > *{ grid-column: span 12; } /* 1 por linha */
}

/* cartão */
.cardX{
  display:flex;
  flex-direction:column;
  background: var(--card);
  border: 1px solid rgba(15,23,42,.06);
  border-radius: 28px;                 /* mais redondo */
  overflow:hidden;
  text-decoration:none;
  color: inherit;
  box-shadow: 0 10px 28px rgba(2,6,23,.06);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.cardX:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 44px rgba(2,6,23,.12);
  border-color: rgba(15,23,42,.12);
}

/* cabeçalho colorido com ícone */
.cardX-head{
  height: 140px;
  display:grid;
  place-items:center;
  position:relative;
  isolation:isolate;
}

/* pequeno brilho diagonal no topo para dar “vidinha” */
.cardX-head::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,0) 40%);
  mix-blend-mode: soft-light;
  pointer-events:none;
}

.cardX-head img{
  width: 62px; height: 62px; object-fit: contain;
  filter: drop-shadow(0 6px 10px rgba(2,6,23,.18));
}

/* corpo branco */
.cardX-body{
  padding: 22px 22px 24px;
}
.cardX-body h3{
  margin: 10px 0 8px;
  font-size: 22px;
  line-height: 1.2;
}
.cardX-body p{
  margin: 0;
  color: var(--muted);
}

/* paletas (usamos as tuas variáveis e um gradiente suave) */
.c-azul   .cardX-head{ background: linear-gradient(135deg, var(--azul) 0%, #6ea2f0 100%); }
.c-lilac  .cardX-head{ background: linear-gradient(135deg, var(--brand1) 0%, #d3a8ff 100%); }
.c-yellow .cardX-head{ background: linear-gradient(135deg, var(--amarelo) 0%, #fff3b8 100%); }
.c-teal   .cardX-head{ background: linear-gradient(135deg, var(--verdeclaro) 0%, #c8f0e6 100%); }

/* foco acessível para quem navega por teclado */
.cardX:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px rgba(188,137,236,.35);
}
.cardX-head::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image: radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 3px 3px; opacity:.4;
}

.sobre{
  text-align:center;
}
.sobre h2{
  font-size:clamp(24px,3vw,32px);
  margin-bottom:12px;
}
.sobre-intro{
  color:var(--muted);
  max-width:640px;
  margin:0 auto 40px;
  font-size:clamp(16px,2.4vw,18px);
  line-height:1.6;
}

.sobre-grid{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(auto-fit, minmax(260px,1fr));
  margin-top:20px;
}

.sobre-card{
  background:var(--card);
  border:1px solid rgba(15,23,42,.06);
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:28px 24px;
  transition:transform .25s ease, box-shadow .25s ease;
}
.sobre-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 36px rgba(2,6,23,.08);
}
.sobre-card .emoji{
  font-size:32px;
  display:block;
  margin-bottom:10px;
}
.sobre-card h3{
  margin:0 0 6px;
  font-size:20px;
}
.sobre-card p{
  margin:0;
  color:var(--muted);
  font-size:16px;
}


/* Footer base */
footer {
  padding: 36px 0;
  color: var(--muted);
  border-top: 1px solid rgba(15,23,42,.06);
  background: #fff;
  font-size: 15px;
}

/* Ícones sociais no footer */
footer a img {
  opacity: 0.9;
  transition: opacity .2s, transform .2s;
}
footer a img:hover {
  opacity: 1;
  transform: scale(1.08);
}

/* FAQs */

.faq-card {
  background: var(--card);
  border: 1px solid rgba(15, 23, 42, 0.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 40px 32px;
}

.faq {
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.faq-question {
  width: 100%;
  text-align: left;
  font-weight: 600;
  background: none;
  border: 0;
  padding: 18px 0;
  font-size: 16px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color:var(--text);
}

.faq-question::after {
  content: "+";
  font-weight: 700;
  transition: transform 0.2s;
}

.faq.open .faq-question::after {
  content: "–";
  transform: rotate(180deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  color: var(--muted);
}

.faq.open .faq-answer {
  max-height: 200px; /* ajusta conforme o texto */
}

.legal h2{
  margin-top: 3%; 
  font-size:clamp(16px,3vw,16px); font-weight: 200;}
.legal h3{font-size:clamp(16px,3vw,16px); font-weight: normal;font-weight: 200;}




.press-release{
  max-width: 760px;
  margin: 0 auto;
  padding: 0 24px;
  line-height: 1.5;
  text-align: justify;
}

.press-release__header{
  margin: 18px 0 18px;
}

.press-release__title{
  margin: 0 0 6px;
  line-height: 1.1;
  background: none;
  padding: 0;
  border: 0;
}

.press-release__meta{
  margin: 0;
  opacity: .7;
  font-size: .95em;
}

.press-release p{
  margin: 0 0 1.05rem;
}
.press-release h1{
  margin-top: 10%;
}

.press-release h1::before,
.press-release h1::after{
  display: none !important;
}



.press-release__media{
  margin: 16px 0 22px;
}

.press-release__media img{
  display: block;
  width: 80%;
  margin-left: 10%;
  height: clamp(220px, 38vw, 360px); 
  object-fit: cover;
  border-radius: 18px;
}

.press-release__media figcaption{
  margin-top: 8px;
  font-size: .9em;
  opacity: .65;
}

/* Quotes: menos “caixa pesada” */
.press-release__quote{
  margin: 1.15rem 0;
  padding: .9rem 1rem;
  border-left: 4px solid rgba(0,0,0,.18);
  background: rgba(0,0,0,.03);
  border-radius: 14px;
}
.press-release__quote p{ margin: 0; }

/* Galeria de screenshots (Foto 2) */
.press-release__gallery{
  display: grid;
  grid-template-columns: 1fr;
  margin: 18px 0 22px;
}

.press-release__gallery img{
  width: 100%;
  object-fit: cover;
  border-radius: 16px;
}

.press-release__links{
  margin-top: 1.25rem;
}

.press-quote{
  position: relative;
  margin: 2rem 0;
  padding-left: 3rem;
  font-style: italic;
}

/* Aspas grandes */
.press-quote::before{
  content: "“";
  position: absolute;
  left: 0;
  top: -0.35em;
  font-size: 5rem;
  line-height: 1;
  left: -0.5rem;     /* puxa ligeiramente para fora */
  top: -0.2em;

  background: var(--brand1);

  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;

  background-clip: text; /* fallback */
}
.press-release__showcase{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin: 32px 0 36px;
}

/* cada “telemóvel” */
.press-release__showcase figure{
  margin: 0;
  text-align: center;
}

/* força proporção vertical */
.press-release__showcase img{
  width: 70%;
  margin-left: 15%;
  aspect-ratio: 9 / 19;   /* proporção de iPhone */
  object-fit: cover;
  border-radius: 28px;
}

/* legenda */
.press-release__showcase figcaption{
  margin-top: 10px;
  font-size: .9em;
  opacity: .7;
}

.news-imagem {
  display: flex;
  gap: 16px;              /* espaço entre imagens */
  align-items: center;
}

.news-imagem img {
  width: auto;           /* tamanho das imagens (ajusta como quiseres) */
  height: 50px;
  object-fit: contain;
}

/* tablet */
@media (max-width: 900px){
  .press-release__showcase{
    grid-template-columns: repeat(2, 1fr);
  }
}

/* mobile */
@media (max-width: 600px){
  .press-release__showcase{
    grid-template-columns: 1fr;
  }

  .press-release__showcase img{
    aspect-ratio: 9 / 18;
  }
}


/* Mobile */
@media (max-width: 640px){
  .press-quote{
    padding-left: 2.4rem;
  }
  .press-quote::before{
    font-size: 4rem;
  }
}


@media (max-width: 640px){
  .press-release{ padding: 0 16px; }
  .press-release__gallery{ grid-template-columns: 1fr; }
  .press-release__gallery img{ height: 240px; }
}

/* 🧱 Layout responsivo do footer */
@media (max-width: 700px) {
  footer .container > div {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 16px;
  }

  footer .container small {
    order: 3; /* Move o © para baixo, opcional */
  }

  footer .container a.btn {
    padding: 8px 14px;
    font-size: 15px;
  }

  footer .container a img {
    width: 26px;
    height: 26px;
  }
  .store-badges img {
    width: 140px;    
  }
}
