/* ========== FIRE BIRD THEME (primary #ff2800) ========== */
:root{
  --bg:#070A0F;
  --text:#EAF0FF;
  --muted:rgba(234,240,255,.70);

  --panel:rgba(255,255,255,.04);
  --panel2:rgba(255,255,255,.06);
  --stroke:rgba(255,255,255,.10);
  --stroke2:rgba(255,255,255,.16);

  --red:#ff2800;
  --orange:#ff6a00;
  --amber:#ff9a00;

  --glow:rgba(255,40,0,.45);
  --glow2:rgba(255,106,0,.35);

  --radius:18px;
  --radius2:14px;
  --shadow:0 18px 60px rgba(0,0,0,.55);

  --max:1180px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 500px at 15% 10%, rgba(255,40,0,.20), transparent 55%),
    radial-gradient(900px 500px at 85% 15%, rgba(255,106,0,.18), transparent 55%),
    linear-gradient(180deg,#05070C,var(--bg));
  overflow-x:hidden;
}

body::before{
  content:"";
  position:fixed; inset:0;
  background:repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 2px, rgba(255,255,255,0) 2px 10px);
  opacity:.08;
  pointer-events:none;
}

a{color:inherit; text-decoration:none}
.wrap{max-width:var(--max); margin:0 auto; padding:0 18px;}
img{max-width:100%; height:auto; display:block;}

.topline{
  height:4px;
  background:linear-gradient(90deg,var(--red),var(--orange),var(--amber));
  box-shadow:0 0 20px var(--glow);
}

/* =========================
   HEADER (topo)
========================= */
header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(12px);
  background:rgba(7,10,15,.75);
  border-bottom:1px solid var(--stroke);
}

.navrow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  flex-wrap:nowrap;
}

.brand{
  display:flex; align-items:center; gap:8px;
  flex:0 0 auto;
}
.brand img{
  width:32px; height:32px; object-fit:contain;
  filter:drop-shadow(0 0 10px var(--glow));
}
.brand strong{
  font-family:Orbitron, Inter, system-ui;
  font-size:11px;
  letter-spacing:.10em;
}

/* (IMPORTANTE) Aqui NÃO estilizamos mais o nav do menu dentro do header,
   porque agora o menu está na .menuBar abaixo. */

.actions{
  display:flex;
  gap:8px;
  align-items:center;
  flex:0 0 auto;
  flex-wrap:nowrap;
  white-space:nowrap;
}

.pill{
  display:inline-flex; align-items:center; justify-content:center;
  padding:8px 10px;
  border-radius:999px;
  background:var(--panel);
  border:1px solid var(--stroke);
  color:var(--text);
  transition:.2s;
  white-space:nowrap;
  font-size:13px;
}
.pill:hover{background:var(--panel2); border-color:var(--stroke2); transform:translateY(-1px);}

.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:16px;
  height:16px;
  padding:0 5px;
  border-radius:999px;
  margin-left:6px;
  background:linear-gradient(90deg,var(--red),var(--orange),var(--amber));
  color:#0b0d10;
  font-weight:900;
  font-size:11px;
}

/* Botão perigoso (Excluir) */
.pill-danger{
  background:#ff4d00 !important;
  color:#fff !important;
  border:none !important;
  box-shadow:0 0 10px rgba(255,77,0,.75) !important;
}
.pill-danger:hover{ background:#ff6a00 !important; }

/* =========================
   MENU BAR (barra cinza com brilho laranja)
   HTML esperado:
   <div class="menuBar"><div class="wrap">
     <nav class="mainNav">
       <a class="navrow" ...>...</a>
     </nav>
   </div></div>
========================= */
.menuBar{
  padding:12px 0 14px;
}

.menuBar .mainNav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;

  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,106,0,.55);
  border-radius: 999px;
  padding:10px 12px;

  box-shadow:
    0 0 0 1px rgba(255,106,0,.30),
    0 0 22px rgba(255,106,0,.25),
    inset 0 0 0 1px rgba(0,0,0,.25);
}

/* Links do menu (sua classe é navrow) */
.menuBar .mainNav .navrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  padding:10px 14px;
  border-radius:999px;

  font-family: Orbitron, Inter, system-ui;
  font-size:12px;
  letter-spacing:.10em;
  text-transform:uppercase;

  color: rgba(234,240,255,.92);
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.10);

  transition:.2s;
}

.menuBar .mainNav .navrow:hover{
  border-color: rgba(255,106,0,.75);
  background: linear-gradient(90deg, rgba(255,40,0,.85), rgba(255,106,0,.85));
  color:#0b0d10;
  box-shadow: 0 0 16px rgba(255,106,0,.28);
  transform: translateY(-1px);
}

/* =========================
   HERO
========================= */
.hero{padding:54px 0 34px;}
.heroGrid{
  display:grid;
  grid-template-columns: 1.12fr .88fr;
  gap:22px;
  align-items:stretch;
}
.kicker{
  font-family:Orbitron, Inter, system-ui;
  font-size:11px;
  letter-spacing:.12em;
  color:rgb(255,255,255);
  margin-bottom:10px;
}
h1{margin:0 0 14px; font-size:46px; line-height:1.05;}
.sub{margin:0 0 18px; color:var(--muted); line-height:1.55; max-width:60ch;}

.btnrow{display:flex; gap:12px; flex-wrap:wrap; margin:18px 0 18px;}
.btn{
  border:none;
  border-radius:999px;
  padding:12px 16px;
  font-weight:800;
  cursor:pointer;
  transition:.2s;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.btn.primary{
  background:linear-gradient(90deg,var(--red),var(--red),var(--red));
  color:#0b0d10;
  box-shadow:0 0 25px var(--glow), 0 10px 40px rgba(255,40,0,.35);
}
.btn.primary:hover{filter:brightness(1.05); transform:translateY(-1px);}
.btn.ghost{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.12);
  color:var(--text);
}
.btn.ghost:hover{background:rgba(255,255,255,.05); border-color:rgba(255,255,255,.18); transform:translateY(-1px);}
.btn.full{width:100%}

.stats{display:flex; gap:12px; flex-wrap:wrap; margin-top:10px;}
.stat{
  width:130px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--stroke);
  border-radius:var(--radius2);
  padding:12px;
}
.stat strong{display:block; font-size:18px;}
.stat span{display:block; margin-top:2px; font-size:12px; color:var(--muted);}

/* Banner da equipe */
.bannerCard{
  position:relative;
  border-radius:var(--radius);
  border:1px solid var(--stroke);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  overflow:hidden;
  box-shadow:var(--shadow);
  min-height:320px;
}
.teamBanner{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.05) contrast(1.05);
}
.bannerOverlay{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(7,10,15,.88), rgba(7,10,15,.35), rgba(255,40,0,.12)),
    radial-gradient(400px 260px at 70% 35%, rgba(255,40,0,.30), transparent 60%);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:18px;
}
.bannerTitle{
  font-family:Orbitron, Inter, system-ui;
  letter-spacing:.14em;
  font-weight:800;
  font-size:16px;
}
.bannerSub{
  color:rgba(234,240,255,.78);
  margin-top:6px;
  font-size:13px;
}

/* Sections */
.section{
  padding:40px 0;
  border-top:0;
  background:transparent;
}
.secTitle{display:flex; flex-direction:column; gap:6px; margin-bottom:16px;}
.secTitle h2{margin:0; font-size:26px;}
.muted{color:var(--muted);}
.list{margin:8px 0 0; padding-left:18px;}
.list li{margin:6px 0;}

.cards2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.card{
  background:rgba(255,255,255,.03);
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  padding:16px;
  transition:.2s;
}
.card:hover{background:rgba(255,255,255,.04); border-color:var(--stroke2); transform:translateY(-2px);}

.orderTopBar{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}

.btn.danger{
  background: rgba(246,26,25,.15);
  border: 1px solid rgba(246,26,25,.55);
  color:#fff;
  font-weight:800;
  border-radius:999px;
  padding:10px 14px;
  cursor:pointer;
  transition:.15s ease;
}

.btn.danger:hover{
  box-shadow:0 0 18px rgba(246,26,25,.20);
  border-color: rgba(246,26,25,.85);
}


/* Loja */
.productGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  margin-top:14px;
}
.productCard{
  border-radius:var(--radius);
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.03);
  overflow:hidden;
  transition:.2s;
}
.productCard:hover{border-color:var(--stroke2); transform:translateY(-2px);}
.productImg{height:170px; background:rgba(255,255,255,.02);}
.productImg img{width:100%; height:100%; object-fit:cover; display:block;}
.productBody{padding:14px;}
.productName{margin:0 0 6px; font-size:16px;}
.productDesc{margin:0 0 12px; font-size:13.5px; line-height:1.45;}
.productRow{display:flex; align-items:center; justify-content:space-between; margin-bottom:12px;}
.price{font-size:15px;}

/* ECO/SOCIAL gallery */
.galleryGrid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:16px;
  margin-top:18px;
}
.galleryItem{
  height:160px;
  border-radius:14px;
  overflow:hidden;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,106,0,.70);
  box-shadow:0 0 14px rgba(255,106,0,.22);
  transition:.2s;
}
.galleryItem:hover{
  transform:translateY(-3px);
  border-color:rgba(255,154,0,.85);
  box-shadow:0 0 24px rgba(255,106,0,.42);
}
.galleryItem img{
  width:100% !important;
  height:100% !important;
  object-fit:cover;
  display:block;
}

/* Footer */
.footer{
  padding:26px 0;
  border-top:1px solid var(--stroke);
}
.footerGrid{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.footerBrand{
  font-family:Orbitron, Inter, system-ui;
  letter-spacing:.12em;
}

/* Forms */
.formCard{
  max-width:520px;
  margin:26px auto;
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  background:rgba(255,255,255,.03);
  padding:18px;
}
.field{display:flex; flex-direction:column; gap:6px; margin:12px 0;}
.input{
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.22);
  color:var(--text);
  outline:none;
}
.input:focus{border-color:rgba(255,255,255,.22); box-shadow:0 0 0 3px rgba(255,40,0,.12);}
.alert{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,40,0,.10);
}

/* Orders */
.orderRow{
  display:grid;
  grid-template-columns: 1fr 220px;
  gap:16px;
  align-items:start;
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  background:rgba(10,12,16,.25);
  backdrop-filter: blur(8px);
  text-decoration:none;
  color:inherit;
}
.orderRow:hover{ border-color: rgba(255,40,0,.45); }
.orderLeft{ min-width:0; }
.orderTitle{ font-weight:900; font-size:16px; }
.orderMeta{
  margin-top:6px;
  font-size:13px;
  color: rgba(255,255,255,.72);
  line-height:1.35;
}
.orderMeta b{ color:#fff; }
.orderRight{ text-align:right; }
.orderRight .lbl{
  font-size:12px;
  color: rgba(255,255,255,.65);
  margin-top:8px;
}
.orderRight .val{
  font-weight:900;
  font-size:18px;
}

/* ===== MENU BAR (cinza com brilho laranja) ===== */

.menuNav{
  display: flex;
  flex-wrap: nowrap;     /* PC: 1 linha */
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.menuLink{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 10px 14px;
  border-radius: 999px;

  font-family: Orbitron, Inter, system-ui;
  font-size: 11px;
  letter-spacing: .10em;
  text-transform: uppercase;

  color: rgba(234,240,255,.92);
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.10);
  transition: .2s;
}

.menuLink:hover{
    background: rgb(246, 26, 25);
  border: 1px solid rgb(246, 26, 25);
  border-radius: 999px;
  padding: 10px 12px;
  
  transform: translateY(-1px);
  border-color: rgb(85, 10, 9);
  box-shadow: 0 0 16px rgb(85, 10, 9);
}

/* MOBILE: aparece e quebra em 2 linhas */
@media (max-width: 900px){
  .menuBar{ top: 58px; }

  .menuNav{
    width: 100%;          /* em mobile ocupa a largura */
    flex-wrap: wrap;      /* ✅ 2 linhas */
    border-radius: 18px;
    justify-content: center;
  }

  .menuLink{
    padding: 10px 12px;
    font-size: 10.5px;
  }
}

/* =========================
   MOBILE FIX PACK
   (cole no FINAL do style.css)
========================= */
@media (max-width: 900px){

  /* 1) HEADER: melhor distribuição e sem esmagar */
  header .navrow{
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
  }

  .brand{
    flex: 1 1 auto;
    min-width: 180px;
  }

  /* ações ficam embaixo e alinhadas, com quebra controlada */
  .actions{
    width: 100%;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 8px;
  }

  .pill{
    padding: 8px 10px;
    font-size: 12px;
  }

  /* 2) MENU BAR: largura 100%, menos “altura”, botões menores */
  .menuBar{
    margin-top: 8px;
    padding: 8px 0 10px;
  }

  .menuBar .menuNav{
    width: 100% !important;
    max-width: 100% !important;
    justify-content: center;
    gap: 8px;
    padding: 10px 10px;
    border-radius: 18px;
  }

  .menuBar .menuLink{
    padding: 9px 11px;
    font-size: 10px;
    letter-spacing: .08em;
  }

  /* 3) HERO: vira 1 coluna (texto em cima, banner embaixo) */
  .heroGrid{
    grid-template-columns: 1fr !important;
    gap: 14px;
  }

  h1{
    font-size: 36px;
    line-height: 1.05;
  }

  .sub{
    font-size: 14px;
    line-height: 1.55;
  }

  /* banner ocupa largura total e fica “bonito” */
  .bannerCard{
    min-height: 240px;
  }

  /* 4) Product grid já é 1 coluna, mas garante espaçamento */
  .productGrid{
    grid-template-columns: 1fr !important;
    gap: 12px;
  }
}

/* ainda menor (celulares pequenos) */
@media (max-width: 420px){
  h1{ font-size: 32px; }
  .menuBar .menuLink{ padding: 8px 10px; font-size: 9.5px; }
}

/* ===== FUNDO PRETO SÓLIDO + GLOW NO CURSOR ===== */
html, body{
  background:#050607 ; /* preto sólido tipo da sua foto */
}

body{
  background:#050607;
  overflow-x:hidden;
}

/* remove qualquer textura/gradiente antigo */
body::before,
body::after{
  content:none ;
  display:none ;
}

/* Camada do glow (fica por cima do fundo e atrás do conteúdo) */
.cursorGlow{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
}

/* garante que o site fique acima do glow */
header, .menuBar, main, footer{
  position:relative;
  z-index:1;
}

/* =========================
   HERO "NOVIDADE" COMO PAINEL GRANDE + BG FADE
   (cole no FINAL do style.css)
========================= */

/* garante que a seção hero não crie "cortes" */
.hero{
  padding: 18px 0 0;         /* menos espaçamento em cima */
  margin: 0;
}

/* este é o "retângulo branco" (o painel) */
.heroPanel{
  position: relative;
  border-radius: 22px;
  padding: 26px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.04),
    0 22px 80px rgba(0,0,0,.55);
  overflow: hidden;

  /* ✅ faz a "aba de novidade" ficar grande */
  min-height: 520px; /* ajuste: se quiser mais alto, aumenta */
}

/* banner no fundo do hero com baixa opacidade + degradê pro fundo */
.heroPanel .heroBg{
  position: absolute;
  inset: 0;
  background:
    /* imagem/banner (troque a URL pelo seu banner real) */
    linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.75)),
    url("assets/hero-banner.png");
  background-size: cover;
  background-position: center;
  opacity: .22;              /* baixa opacidade */
  filter: saturate(1.05) contrast(1.05);
  pointer-events: none;
  z-index: 0;
}

/* degradê extra embaixo pra "sumir" a divisão com a próxima seção */
.heroPanel::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-2px;
  height: 140px;
  background: linear-gradient(
    180deg,
    rgba(0,0,0,0),
    rgba(0,0,0,.55),
    rgba(0,0,0,1)
  );
  pointer-events:none;
  z-index: 1;
}

/* conteúdo do hero acima do background */
.heroPanel .heroGrid{
  position: relative;
  z-index: 2;
}

/* remove “linha/recorte” da próxima seção */
.section{
  border-top: 0;
  background: transparent;
}

/* dá um espaçamento suave sem criar faixa */
#quem.section{
  padding-top: 26px;
}

/* RESPONSIVO */
@media (max-width: 980px){
  .heroPanel{
    min-height: 0;
    padding: 18px;
  }
}
/* ================================
   CENTRALIZAÇÃO REAL DO HERO
================================ */

/* painel do hero vira "flex" */
.heroPanel{
  display: flex;
  align-items: center;     /* centraliza vertical */
}

/* grid ocupa largura total */
.heroGrid{
  width: 100%;
  align-self: center;
}

/* garante respiro correto */
.hero{
  padding-top: 24px;
  padding-bottom: 24px;
}

/* MOBILE */
@media (max-width: 900px){
  .heroPanel{
    align-items: flex-start;   /* em mobile fica natural */
  }

  .heroGrid{
    padding-top: 10px;
  }
}

/* =========================
   MOBILE: MENU BAR NO LUGAR (sem sobrepor a Hero)
   Seu HTML:
   <div class="menuBar"><div class="wrap">
     <nav class="menuNav">
       <a class="menuLink">...</a>
     </nav>
   </div></div>
========================= */

/* desktop ok */
.menuBar{ margin-top:10px; }

/* ===== STICKY + ESPAÇO NO MOBILE ===== */
@media (max-width: 900px){

  /* 1) menuBar sticky abaixo do header */
  .menuBar{
    position: sticky;
    top: 74px;                /* ✅ ajuste fino p/ altura do seu header no mobile */
    z-index: 49;
    padding: 10px 0 12px;
  }

  /* 2) cria “espaço” pra hero não ficar embaixo do menu */
  main{ padding-top: 12px; }
  .hero{ padding-top: 18px; }  /* ✅ garante que o topo da novidade fique abaixo */

  /* 3) barra cinza com glow */
  

  /* 4) 4 itens em cima + 3 embaixo (fixo) */
  .menuBar .menuNav > a.menuLink{
    flex: 0 0 calc(25% - 8px);   /* ✅ 4 por linha */
    max-width: calc(25% - 8px);

    display:inline-flex;
    align-items:center;
    justify-content:center;

    padding: 10px 10px;
    border-radius: 999px;

    font-family: Orbitron, Inter, system-ui;
    font-size: 10px;
    letter-spacing: .08em;
    text-transform: uppercase;

    background: rgba(0,0,0,.18);
    border: 1px solid rgba(255,255,255,.10);
    color: rgba(234,240,255,.92);

    text-align:center;
    min-width:0;
    transition:.2s;
  }

  .menuBar .menuNav > a.menuLink:hover{
    background: rgba(246,26,25,.92);
    border-color: rgba(246,26,25,.92);
    color:#0b0d10;
    box-shadow: 0 0 14px rgba(246,26,25,.22);
    transform: translateY(-1px);
  }
}

/* telas bem pequenas: só reduz tipografia/padding */
@media (max-width: 420px){
  .menuBar{ top: 70px; } /* um pouco menor */
  .menuBar .menuNav > a.menuLink{
    padding: 9px 8px;
    font-size: 9px;
    letter-spacing: .06em;
  }
}
/* =========================
   MOBILE: HEADER CENTRALIZADO + MENU FIXO 4/3
   (cole no FINAL do CSS)
========================= */
@media (max-width: 900px){

  /* ===== HEADER: tudo centralizado ===== */
  header .navrow{
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 12px;
    padding: 12px 0;
  }

  /* logo + texto central */
  header .brand{
    width: 100%;
    justify-content: center;
    gap: 10px;
  }
  header .brand img{ width: 34px; height: 34px; }
  header .brand strong{ font-size: 12px; letter-spacing: .10em; }

  /* ações centralizadas embaixo, com quebra */
  header .actions{
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
  }
}
/* =========================
   MENU MOBILE: corrigir "PATROCÍNIOS" e encaixe geral
========================= */
@media (max-width: 900px){

  /* garante que o texto não “vaze” */
  .menuBar .menuNav > a.menuLink{
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* ajuste específico p/ PATROCÍNIOS (deixa menor só nele) */
  .menuBar .menuNav > a.menuLink[href*="#patrocinadores"],
  .menuBar .menuNav > a.menuLink[href*="patrocinadores"]{
    font-size: 7px;            /* ✅ fica “direitinho” */
    letter-spacing: .04em;
    padding-left: 8px;
    padding-right: 8px;
  }
}
/* =========================
   TIME / TEAM CARDS - SIZE UPGRADE
========================= */

/* grid dos membros */
.teamGrid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap:22px;
}

/* card */
.teamCard{
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  border-radius:22px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:420px;              /* ✅ card mais alto */
  box-shadow: 0 12px 40px rgba(0,0,0,.55);
  transition:.25s;
}

.teamCard:hover{
  transform: translateY(-4px);
  border-color: rgba(246,26,25,.55);
  box-shadow: 0 0 26px rgba(246,26,25,.25);
}

/* área da imagem */
.teamPhoto{
  width:100%;
  height:300px;                  /* ✅ MAIS ALTO */
  overflow:hidden;
  background:#000;
}

/* imagem */
.teamPhoto img{
  width:100%;
  height:100%;
  object-fit:cover;              /* corta bonito */
  object-position: center top;   /* prioriza rosto */
}

/* área de texto */
.teamInfo{
  padding:18px;
  text-align:center;
}

.teamInfo h3{
  margin:0 0 6px;
  font-size:18px;
  font-weight:700;
}

.teamInfo span{
  font-size:14px;
  color:rgba(234,240,255,.75);
}

/* =========================
   MOBILE
========================= */
@media (max-width: 900px){

  .teamGrid{
    grid-template-columns:1fr;
  }

  .teamCard{
    min-height:380px;
  }

  .teamPhoto{
    height:260px;   /* continua grande no mobile */
  }
}
/* ============================
   MENU FIXO NO MOBILE
============================ */

.menuBar{
  position: static;
  top: 64px;
  left: 0;
  width: 100%;
  z-index: 60;
}
/* Gantt custom classes */
.gantt .bar.g-done { fill: rgba(0,255,120,.55); }
.gantt .bar.g-doing{ fill: rgba(246,26,25,.55); }
.gantt .bar.g-req  { fill: rgba(255,255,255,.25); }

/* badge "MINHA" */
.badgeMine{
  font-size:12px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(246,26,25,.18);
  border:1px solid rgba(246,26,25,.45);
  color:#fff;
}

/* =========================
   QUEM SOMOS — estilo "mosaico" (inspirado no exemplo)
   Fire Bird: dark + glow red (rgb(246,26,25))
   ========================= */
:root{
  --fb-red: rgb(246, 26, 25);
  --fb-red-glow: rgba(246,26,25,.22);
  --fb-panel: rgba(255,255,255,.04);
  --fb-stroke: rgba(255,255,255,.10);
}

/* seção inteira */
.aboutMosaic{
  position: relative;
  padding: 56px 0;
}

/* fundo sutil estilo textura (sem “linha dividindo”) */
.aboutMosaic::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.22;
  background:
    radial-gradient(900px 560px at 20% 20%, rgba(246,26,25,.18), transparent 60%),
    radial-gradient(900px 560px at 80% 70%, rgba(246,26,25,.10), transparent 62%);
}

/* layout 2 colunas */
.aboutMosaicGrid{
  position: relative;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 22px;
  align-items: start;
}

/* coluna texto */
.aboutLeft{
  padding: 10px 0;
}
.aboutTag{
  font-family: Orbitron, Inter, system-ui;
  letter-spacing: .10em;
  text-transform: uppercase;
  font-weight: 900;
  font-size: 34px;
  margin: 0;
}
.aboutTag span{
  color: var(--fb-red);
  text-shadow: 0 0 18px var(--fb-red-glow);
}
.aboutLine{
  width: 46px;
  height: 4px;
  border-radius: 999px;
  margin: 10px 0 18px;
  background: var(--fb-red);
  box-shadow: 0 0 18px var(--fb-red-glow);
}
.aboutText{
  color: rgba(234,240,255,.75);
  line-height: 1.75;
  font-size: 15.5px;
  max-width: 58ch;
}

/* botão */
.aboutBtn{
  margin-top: 18px;
  display: inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 18px;
  border-radius: 14px;
  font-weight: 900;
  letter-spacing: .04em;
  background: rgba(246,26,25,.16);
  border: 1px solid rgba(246,26,25,.55);
  box-shadow: 0 0 22px rgba(246,26,25,.18);
  color: #fff;
  transition: .2s;
}
.aboutBtn:hover{
  transform: translateY(-1px);
  background: rgba(246,26,25,.22);
  box-shadow: 0 0 26px rgba(246,26,25,.22);
}

/* coluna mosaico */
.mosaic{
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 150px;
  gap: 14px;
}

/* cards das imagens */
.mosaicCard{
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 14px 40px rgba(0,0,0,.55);
  transform: translateZ(0);
}
.mosaicCard::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.55));
}
.mosaicCard img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  filter: saturate(1.02) contrast(1.03);
}

/* variações de tamanho no mosaico (igual exemplo) */
.mosaicCard.bigRight{
  grid-row: span 2;
}
.mosaicCard.wideTop{
  grid-column: span 2;
}
.mosaicCard.tallLeft{
  grid-row: span 2;
}

/* hover bonito */
.mosaicCard:hover{
  border-color: rgba(246,26,25,.35);
  box-shadow: 0 0 0 1px rgba(246,26,25,.18), 0 18px 60px rgba(0,0,0,.65);
}

/* RESPONSIVO */
@media (max-width: 980px){
  .aboutMosaicGrid{
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .aboutTag{
    font-size: 30px;
  }
  .mosaic{
    grid-auto-rows: 130px;
  }
}

@media (max-width: 520px){
  .aboutMosaic{
    padding: 42px 0;
  }
  .aboutTag{
    font-size: 26px;
  }
  .aboutText{
    font-size: 14.5px;
  }
  .mosaic{
    grid-auto-rows: 120px;
    gap: 10px;
  }
  /* no mobile fica mais “compacto” */
  .mosaicCard.bigRight{ grid-row: span 2; }
  .mosaicCard.wideTop{ grid-column: span 2; }
}

/* Aumentar levemente título "Quem Somos?" */
#quem h2,
.aboutTag{
  font-family: Orbitron, Inter, system-ui;
  font-size: 32px;   /* antes devia estar ~26px */
  line-height: 1.1;
}

/* Mobile */
@media (max-width: 600px){
  #quem h2,
  .aboutTag{
    font-size: 26px;
  }
}

/* =========================
   ABOUT PAGE (Quem Somos)
========================= */
.aboutHero{ padding: 18px 0 10px; }
.aboutHeroGrid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:18px;
  align-items:start;
}

.aboutKicker{
  font-family: Orbitron, Inter, system-ui;
  letter-spacing:.14em;
  font-weight:900;
  font-size:12px;
  text-transform:uppercase;
  color: rgba(234,240,255,.92);
}

.aboutAccentLine{
  width:56px;
  height:4px;
  margin:10px 0 14px;
  border-radius:999px;
  background: rgb(246, 26, 25);
  box-shadow: 0 0 12px rgba(246,26,25,.18);
}

.aboutH1{
  margin:0 0 12px;
  font-size:38px;
  line-height:1.06;
}
.aboutH2{
  margin:0 0 10px;
  font-size:28px;
  line-height:1.12;
}

.aboutP{
  color: rgba(234,240,255,.72);
  line-height:1.7;
  font-size:14.5px;
  max-width: 64ch;
}

.aboutImgCard{
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.10);
  overflow:hidden;
  background: rgba(255,255,255,.03);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  min-height: 240px;
}
.aboutImgCard img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}

.aboutCards{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}

.aboutCard{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding:16px 16px 18px;
  text-align:center;
  transition:.2s;
}
.aboutCard:hover{
  transform: translateY(-2px);
  border-color: rgba(246,26,25,.35);
  box-shadow: 0 0 18px rgba(246,26,25,.10);
}

.aboutCardIcon{
  font-size:34px;
  line-height:1;
  margin-bottom:10px;
}
.aboutCardTitle{
  font-family: Orbitron, Inter, system-ui;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-size:13px;
}
.aboutCardLine{
  width:52px;
  height:3px;
  margin:10px auto 12px;
  border-radius:999px;
  background: rgb(246, 26, 25);
  opacity:.9;
}
.aboutCardText{
  color: rgba(234,240,255,.70);
  font-size:13px;
  line-height:1.6;
}

.aboutStory{ margin-top: 18px; padding-top: 10px; }
.aboutStoryGrid{
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  gap:18px;
  align-items:start;
}

/* Mobile */
@media (max-width: 900px){
  .aboutHeroGrid{ grid-template-columns: 1fr; }
  .aboutStoryGrid{ grid-template-columns: 1fr; }
  .aboutCards{ grid-template-columns: 1fr; }
  .aboutH1{ font-size:32px; }
}

/* ===== ABOUT PAGE (Quem Somos) ===== */
.aboutHero{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:22px;
  align-items:start;
}

.aboutTitle{
  margin:0;
  font-size:42px;
  line-height:1.05;
}

.aboutAccent{
  width:74px;
  height:5px;
  margin:12px 0 16px;
  border-radius:999px;
  background: rgb(246, 26, 25);
  box-shadow: 0 0 16px rgba(246,26,25,.20);
}
.aboutAccent.sm{ height:4px; width:56px; margin:10px 0 0; }

.aboutText{
  color: rgba(234,240,255,.78);
  line-height:1.75;
  max-width:60ch;
}

.aboutCta{ margin-top:14px; }

.aboutMosaic{
  display:grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 170px;
  gap:14px;
}

.aboutMosaic figure{
  margin:0;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  box-shadow: 0 16px 55px rgba(0,0,0,.45);
}

.aboutMosaic img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* mosaico parecido com o exemplo */
.aboutMosaic .m1{ grid-column:1 / span 2; grid-row:1; }
.aboutMosaic .m2{ grid-column:1; grid-row:2; }
.aboutMosaic .m3{ grid-column:2; grid-row:2 / span 2; }
.aboutMosaic .m4{ grid-column:1; grid-row:3; }

.aboutCards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}

.aboutCard{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  padding:18px;
  min-height:170px;
}

.aboutCard h3{
  margin:6px 0 8px;
  font-family: Orbitron, Inter, system-ui;
  letter-spacing:.08em;
  font-size:14px;
  text-transform:uppercase;
}

.aboutIcon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  background: rgba(246,26,25,.12);
  border:1px solid rgba(246,26,25,.28);
  box-shadow: 0 0 18px rgba(246,26,25,.12);
}

.aboutHistory{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  padding:18px;
}

.aboutH2{
  margin:0;
  font-size:26px;
}

/* MOBILE */
@media (max-width: 900px){
  .aboutHero{ grid-template-columns: 1fr; }
  .aboutTitle{ font-size:34px; }
  .aboutMosaic{ grid-auto-rows: 140px; }
  .aboutCards{ grid-template-columns: 1fr; }
}

/* =========================
   FIX: SEÇÃO "QUEM SOMOS" (id="quem")
   Cole NO FINAL do style.css
========================= */

/* 1) garante que a seção não estoure largura nem "ande" pro lado */
#quem{
  width:100%;
  max-width:100%;
  overflow:hidden;           /* impede mosaico/itens vazarem e empurrarem layout */
  padding: 54px 0;
}

/* 2) força o conteúdo do #quem a ficar centralizado no padrão do site
   (mesmo se você esqueceu de colocar .wrap dentro do HTML) */
#quem > *{
  max-width: var(--max);
  margin-left:auto;
  margin-right:auto;
  padding-left:18px;
  padding-right:18px;
}

/* 3) se você JÁ tem .wrap dentro do #quem, mantém tudo certinho */
#quem .wrap{
  width: min(var(--max), calc(100% - 36px));
  margin: 0 auto;
  padding: 0 18px;
}

/* 4) qualquer grid/flex dentro do quem: garante que não está "fit-content" nem alinhando errado */
#quem .quemGrid,
#quem .aboutGrid,
#quem .cards2{
  width:100%;
  max-width:100%;
  margin:0;
}

/* 5) padrão recomendado do layout: texto + mosaico (2 colunas) */
#quem .quemGrid,
#quem .aboutGrid{
  display:grid;
  grid-template-columns: 360px 1fr; /* texto esquerda + mosaico/direita */
  gap: 26px;
  align-items: start;
}

/* 6) se algum bloco estiver com position absolute/left/right, mata dentro do #quem */
#quem *{
  left:auto;
  right:auto;
  transform:none;
}

/* 7) mosaico/imagens: trava em uma caixa e centraliza */
#quem .mosaic,
#quem .quemMosaic,
#quem .aboutMosaic{
  width:100%;
  max-width: 520px;
  margin: 0 auto;           /* centraliza o mosaico na coluna */
}

/* Se suas imagens estão em cards, não deixa elas “vazarem” */
#quem img{
  max-width:100%;
  height:auto;
  display:block;
}

/* 8) MOBILE: vira 1 coluna e centraliza tudo */
@media (max-width: 900px){
  #quem > *{
    padding-left:16px;
    padding-right:16px;
  }

  #quem .quemGrid,
  #quem .aboutGrid{
    grid-template-columns: 1fr !important;
    gap: 16px;
    justify-items: center;
  }

  /* texto fica mais legível */
  #quem h2{ font-size: 28px; }
}

/* ===========================
   ABOUT MOSAIC — SEM SOBREPOR
   (layout solto, estilo home)
=========================== */

.aboutMosaic{
  width: 100%;
  max-width: 680px;            /* controla “respiro” sem virar moldura */
  margin-left: auto;           /* cola no lado direito do hero */
  display: grid;

  /* 2 colunas, direita um pouco maior p/ vertical */
  grid-template-columns: 1fr 1.05fr;

  /* alturas fluidas (não fica “caixão”) */
  grid-auto-rows: 180px;

  gap: 16px;
  align-content: start;
}

.aboutMosaic img{
  width: 100%;
  height: 100%;
  object-fit: cover;

  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);

  display: block;
  box-shadow: 0 18px 55px rgba(0,0,0,.55);
}

/* Topo (banner) ocupa 2 colunas e é mais alto */
.aboutMosaic .m1{
  grid-column: 1 / -1;
  grid-row: span 2;
  min-height: 320px;
}

/* Inferior esquerda */
.aboutMosaic .m2{
  grid-column: 1;
  grid-row: span 2;
  min-height: 260px;
}

/* Vertical direita (protagonista) */
.aboutMosaic .m3{
  grid-column: 2;
  grid-row: span 4;
  min-height: 520px;
}

/* Inferior extra (fica abaixo, NÃO sobrepõe) */
.aboutMosaic .m4{
  grid-column: 1;
  grid-row: span 2;
  min-height: 220px;
}

/* MOBILE: vira stack bonito */
@media (max-width: 900px){
  .aboutMosaic{
    max-width: 100%;
    margin: 0;
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }

  .aboutMosaic img{
    height: auto;
    aspect-ratio: 16/10;
  }

  .aboutMosaic .m3{
    aspect-ratio: 3/4; /* mantém vertical */
  }
}


.homeStem { margin-top: 18px; }
.homeStemCard{
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 18px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
  overflow: hidden;
}

.homeStemBanner{
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  min-height: 220px;
}
.homeStemBanner img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.homeStemText{ padding: 4px 2px; }
.homeStemTitle{
  margin: 0;
  font-weight: 900;
  font-size: 28px;
  letter-spacing: .2px;
}
.homeStemDesc{
  margin-top: 10px;
  color: rgba(255,255,255,.72);
  line-height: 1.65;
  max-width: 900px;
}
.homeStemActions{ margin-top: 14px; }

/* responsivo */
@media (max-width: 980px){
  .homeStemCard{ grid-template-columns: 1fr; }
  .homeStemBanner{ min-height: 200px; }
  .homeStemTitle{ font-size: 24px; }
}

/* STEM Home - alinhado com o resto */
.stemHomeCard{
  padding: 18px;
}

.stemHomeGrid{
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 18px;
  align-items: center; /* <- alinha verticalmente igual */
}

.stemHomeBanner{
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}

.stemHomeBanner img{
  width: 100%;
  height: 220px;
  display: block;
  object-fit: cover;
}

.stemHomeTitle{
  font-family: Orbitron, Inter, system-ui;
  margin: 0;
  font-weight: 900;
  font-size: 28px;
}

.stemHomeDesc{
  margin-top: 10px;
  color: rgba(255,255,255,.72);
  line-height: 1.65;
  max-width: 900px;
}

/* responsivo */
@media (max-width: 980px){
  .stemHomeGrid{ grid-template-columns: 1fr; }
  .stemHomeBanner img{ height: 200px; }
  .stemHomeTitle{ font-size: 24px; }
}

/* CONTATO */
.contactGrid{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 32px;
  align-items: flex-start;
}

.aboutLine{
  width: 46px;
  height: 4px;
  border-radius: 999px;
  margin: 10px 0 18px;
  background: var(--fb-red);
  box-shadow: 0 0 18px var(--fb-red-glow);
}

.contactText h2{
  margin: 0;
  font-size: 34px;
  font-weight: 900;
}

.contactAccent{
  width: 70px;
  height: 4px;
  margin-top: 10px;
  border-radius: 999px;
  background: rgba(246,26,25,.95);
  box-shadow: 0 0 22px rgba(246,26,25,.35);
}

.contactInfo{
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contactForm{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(6px);
  border-radius: 20px;
  padding: 18px;
}

.contactForm h3{
  font-weight: 800;
}

@media (max-width: 900px){
  .contactGrid{
    grid-template-columns: 1fr;
  }

  .contactText h2{
    font-size: 28px;
  }
}



.sponsorTierTitle{
  margin:0;
  font-weight:900;
  font-size:22px;
}

.sponsorCard{
  position:relative;
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  overflow:hidden;
}

.sponsorBadge{
  position:absolute;
  top:14px;
  right:14px;
  padding:8px 14px;
  border-radius:999px;
  font-weight:900;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
}

.sponsorLeft{
  min-width:0;
  flex:1;
}

.sponsorName{
  font-size:26px;
  font-weight:900;
  letter-spacing:.2px;
}

.sponsorDesc{
  margin-top:10px;
  line-height:1.65;
  max-width:680px;
}

.sponsorLinks{
  margin-top:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.sponsorLogoWrap{
  width:380px;
  max-width:40%;
  display:flex;
  justify-content:center;
  align-items:center;
  padding:10px;
}

.sponsorLogo{
  max-width:100%;
  max-height:160px;
  object-fit:contain;
  filter: drop-shadow(0 10px 26px rgba(0,0,0,.45));
}

@media (max-width: 900px){
  .sponsorCard{ flex-direction:column; align-items:flex-start; }
  .sponsorLogoWrap{ width:100%; max-width:100%; justify-content:flex-start; }
  .sponsorName{ font-size:22px; }
}

/* ===== Sponsors (cards) ===== */
.sponsorCard {
  position: relative;
  display: grid;
  grid-template-columns: 1.4fr 0.9fr;
  gap: 18px;
  align-items: center;
  overflow: hidden;
}

/* Lado esquerdo (texto/links) */
.sponsorLeft { min-width: 0; }
.sponsorName { font-weight: 900; font-size: 28px; line-height: 1.15; }
.sponsorDesc { margin-top: 10px; max-width: 62ch; line-height: 1.5; }

/* ===== Logo: cria um "espaço máximo" e impede estourar ===== */
.sponsorLogoWrap{
  justify-self: end;
  width: clamp(220px, 34vw, 520px);   /* largura máxima da área da logo */
  height: 150px;                      /* altura máxima da área da logo */
  padding: 18px 18px 18px 18px;       /* respiro geral */
  padding-top: 46px;                  /* reserva espaço pro badge não bater */
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  overflow: hidden;
}

.sponsorLogo{
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 10px 25px rgba(0,0,0,.25));
}

/* ===== Badge (selo de categoria) ===== */
.sponsorBadge{
  position: absolute;
  top: 14px;
  right: 14px;
  font-weight: 900;
  font-size: 14px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
}

/* cores por categoria (padrões) */
.sponsorCard[data-tier="Diamante"] .sponsorBadge{
  background: rgba(94,225,255,.18);
  border-color: rgba(94,225,255,.40);
  color: #bff6ff;
}
.sponsorCard[data-tier="Platina"] .sponsorBadge{
  background: rgba(229,228,226,.18);
  border-color: rgba(229,228,226,.40);
  color: #f3f3f2;
}
.sponsorCard[data-tier="Ouro"] .sponsorBadge{
  background: rgba(212,175,55,.20);
  border-color: rgba(212,175,55,.45);
  color: #ffe9a6;
}
.sponsorCard[data-tier="Prata"] .sponsorBadge{
  background: rgba(192,192,192,.18);
  border-color: rgba(192,192,192,.42);
  color: #f2f2f2;
}
.sponsorCard[data-tier="Bronze"] .sponsorBadge{
  background: rgba(205,127,50,.20);
  border-color: rgba(205,127,50,.45);
  color: #ffd2a8;
}

/* ===== Links como ícones ===== */
.sponsorLinks{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.iconBtn{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
}
.iconBtn:hover{
  transform: translateY(-1px);
  border-color: rgba(246,26,25,.55);
  background: rgba(246,26,25,.08);
}
.iconBtn svg{
  width: 18px;
  height: 18px;
  opacity: .95;
}

/* responsivo */
@media (max-width: 900px){
  .sponsorCard{ grid-template-columns: 1fr; }
  .sponsorLogoWrap{
    width: 100%;
    justify-self: stretch;
    justify-content: center;
  }
}
