:root{
  --bg-dark:#05070a;
  --panel:#0b0f12;
  --cyan:#10c1d9;
  --cyan-2:#0fb4ff;
  --accent-yellow:#ffcf2b;
  --accent-yellow-dark:#f0b91a;
  --purple:#8a3df5;
  --blue:#1e94ff;
  --muted:rgba(255,255,255,0.75);
  --max-width:1200px;
  --container-padding:28px;
  font-synthesis: none;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:"Poppins",system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial;background:linear-gradient(180deg,#04060a 0%, #07121a 60%);color:#e6f0f8;-webkit-font-smoothing:antialiased}
.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--container-padding);}

/* Header */
.site-header{
  position:fixed;top:0;left:0;right:0;height:74px;z-index:60;
  background:linear-gradient(180deg, rgba(2,8,12,0.9), rgba(2,8,12,0.3));
  display:flex;align-items:center;backdrop-filter: blur(4px);
  border-bottom:1px solid rgba(255,255,255,0.02)
}
.header-inner{display:flex;align-items:center;gap:18px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.logo-mark{width:44px;height:44px;border-radius:6px;background:linear-gradient(135deg,#05c0f0,#1a6cff);display:grid;place-items:center;color:white;font-weight:900;font-family:Montserrat}
.logo-text{font-weight:800;color:#dfeffb;font-family:Montserrat}
.main-nav{display:flex;gap:18px;margin-left:22px}
.main-nav a{color:rgba(255,255,255,0.75);text-decoration:none;font-weight:500;font-size:14px}
.btn-enter{margin-left:auto;background:var(--accent-yellow);color:#081014;padding:10px 16px;font-weight:700;border-radius:10px;border:4px solid rgba(0,0,0,0.06);cursor:pointer; width:150px}

/* HERO */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;overflow:hidden;
  padding-top:74px
}
.hero-overlay{
  position:absolute;inset:0;
  background-image:url('images/hero-bg.jpg'); 
  background-position:center top;
  background-size:cover;
  filter:brightness(0.70) saturate(0.95) contrast(0.85);
  z-index:1
}
.hero-content{position:relative;z-index:5;display:flex;align-items:center;justify-content:center;width:100%}
.hero-left{width:60%;text-align:center;padding:40px 10px;display:flex;flex-direction:column;gap:14px;align-items:center}
.brand{display:flex;align-items:center;gap:12px;justify-content:center}
.big-n{font-family:Montserrat;font-weight:900;font-size:84px;line-height:0.85;color:transparent;background:linear-gradient(90deg,#1bc3ff,#0f84e6 50%, #b6f0ff 100%);-webkit-background-clip:text}
.neo{font-family:Montserrat;font-weight:900;font-size:56px;color:#e9f6ff}

/* Estilos para o Carrossel de Texto Vertical */
.hero-title-container{
  max-width: 600px;
  margin: 0;
  height: 86px; 
  overflow: hidden;
}

.hero-text-rotator{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  transition: transform 1s ease-in-out; 
}

.hero-title-text{
  font-family:Montserrat;
  font-size:46px;
  margin:0;
  height: 86px; 
  color:transparent;
  background:linear-gradient(90deg, #8a690a 10%, #ffcf2b 60%);
  -webkit-background-clip:text;
  white-space: nowrap; 
}
/* FIM Estilos Carrossel */

.hero-desc{max-width:520px;color:rgba(255,255,255,0.75);font-size:15px}
.cta-wrap{margin-top:18px}
.btn-cta{
    background:linear-gradient(180deg,var(--accent-yellow),var(--accent-yellow-dark));
    border-radius:28px;padding:16px 34px;font-weight:800;color:#081014;
    border:4px solid rgba(0,0,0,0.08);cursor:pointer;
    /* Efeito Elástico do botão CTA */
    overflow: visible; 
    animation: pulse-elastic 2s infinite ease-in-out;
}
.btn-cta:hover {
    animation: none; 
    transform: scale(1.05);
}
@keyframes pulse-elastic {
    0% {
        transform: scale(1); 
        box-shadow: 0 0 0 0 rgba(255, 207, 43, 0.4); 
    }
    50% {
        transform: scale(1.03); 
        box-shadow: 0 0 20px 0 rgba(255, 207, 43, 0.8); 
    }
    70% {
        transform: scale(0.98); 
    }
    100% {
        transform: scale(1); 
        box-shadow: 0 0 0 0 rgba(255, 207, 43, 0.4);
    }
}

.socials{display:flex;gap:14px;margin-top:12px}
.socials .s{display:inline-block;padding:6px 8px;border-radius:6px;background:rgba(255,255,255,0.02);font-weight:700;color:rgba(255,255,255,0.8)}

/* character */
.hero-character{
  position:absolute;
  right:-25%; 
  bottom:-196; 
  z-index:6;
  width:120%; 
  max-width:850px; 
  filter:drop-shadow(0 18px 60px rgba(20,120,220,0.12));
}

.hero-character-left{
  position:absolute;
  left:-17%; 
  bottom:-196; 
  z-index:6;
  max-width:850px; 
  filter:drop-shadow(0 18px 60px rgba(20,120,220,0.12));
 
}

/* lines / decorative */
.lines{position:absolute;inset:0;z-index:3;pointer-events:none}

/* SECTIONS */
.section{
  padding:64px 0;
  background:transparent;
  min-height: 100vh; 
  position: relative;
  /* CORREÇÃO DE ANCORAGEM */
  scroll-margin-top: 74px; 
}
.section-title{font-family:Montserrat;font-weight:900;font-size:56px;text-align:center;margin:0 0 8px}
.section-title em{color:var(--cyan-2)}
.section-sub{text-align:center;color:rgba(255,255,255,0.6);margin-bottom:28px}

/* NOTÍCIAS */
.news-card.primary{
  border:2px solid rgba(255,255,255,0.02);
  border-radius:12px;
  padding:0;
  overflow:hidden;
  position:relative; 
  min-height:425px;
  background:linear-gradient(180deg, rgba(0,0,0,0.5), rgba(0,0,0,0.6));
  border-color: #ffcf2b;
}
.news-media{
  position:absolute;
  inset:0; 
  width:100%;
  height:100%;
  background-size:cover;
  background-position:center;
  border-radius:0; 
  filter:brightness(0.7)
}
.news-content{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  z-index:10;
  padding:18px;
  background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.8)); 
  color:rgba(255,255,255,0.9)
}
.news-content h3{font-size:26px;margin:0 0 6px}

.news-grid{display:flex;gap:20px;margin-top:20px}
.news-mini{
  flex:1;height:180px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-weight:700;
  
  /* BASE STYLES FOR IMAGE BACKGROUNDS */
  background-size: cover;
  background-position: center;
  position: relative;
  color: white; 
  text-shadow: 0 0 4px rgba(0,0,0,0.8);
  overflow: hidden;
  border: 2px solid var(--accent-yellow);
}

/* OVERLAY para o news-mini para melhor leitura */
.news-mini::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 12px;
    background: rgba(0, 0, 0, 0.4); 
    z-index: 1;
}
.news-mini > * {
    position: relative; 
    z-index: 2; /* Garante que o texto fique acima do overlay */
}

/* Imagens de fundo específicas */
.mini-halloween {
  background-image: url('images/hallo.webp');
}

.mini-soulstrider {
  background-image: url('images/soul.webp');
}

.mini-inverno {
  background-image: url('images/inverno.webp');
}

/* RANKING */
.section-ranking{
  padding-top:42px;
  background-image: url('images/ranking-bg.jpg');
  background-size: cover;
  background-position: center center;
  background-attachment: fixed; 
  position: relative;
}
.section-ranking::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.4); 
    z-index: 1;
}
.section-ranking > * {
    position: relative;
    z-index: 2; 
}
.section-ranking .yellow{color:var(--accent-yellow)}
.ranking-controls{display:flex;justify-content:space-between;align-items:center;margin:22px 0}

/* NOVO: Esconde o conteúdo de ranking inativo */
.ranking-mode-content.inactive {
    display: none;
}

.chip{padding:8px 14px;border-radius:12px;border:2px solid rgba(255,255,255,0.04);background:transparent;color:rgba(255,255,255,0.9);cursor:pointer}
.chip.purple
 {
    background: linear-gradient(90deg, #10c1d9, #1e94ff);
    color: white;
    width: 130px;
}
.modes{display:flex;gap:12px}
.mode{padding:8px 18px;border-radius:10px;border:2px solid rgba(255,255,255,0.04);background: rgb(255 255 255);;cursor:pointer;width: 130px;}
.mode.active{background:var(--accent-yellow);color:#081014;border-color:rgba(0,0,0,0.06)}

/* Tabela de Ranking - DESTAQUE APLICADO */
.ranking-table {
    margin-top: 20px;
    /* Fundo destacado, com cantos arredondados e sombra */
    background: rgba(11, 15, 18, 0.85); /* var(--panel) com leve transparência */
    border-radius: 12px;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.4);
    overflow: hidden; /* Garante que os filhos respeitem o border-radius */
    border: 1px solid rgba(255, 255, 255, 0.05); /* Borda sutil */
}

/* Definição de colunas */
.table-head, .table-row {
    display: grid;
    grid-template-columns: 60px 1fr 260px 1fr 10px 160px;;
    padding: 16px 18px; /* Mais padding */
    align-items: center;
}

/* Cabeçalho */
.table-head {
    font-weight: 800;
    color: var(--bg-dark); /* Texto escuro */
    background: var(--accent-yellow); /* Fundo amarelo */
    border-bottom: 2px solid var(--accent-yellow-dark);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-size: 15px;
}

/* Linhas do corpo da tabela */
.table-row {
    /* Alterna cor de fundo para "zebra striping" */
    background-color: transparent; 
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    transition: background-color 0.2s, transform 0.2s; 
}

.table-row:nth-child(even) {
     background-color: rgba(255, 255, 255, 0.02); /* Cor mais clara para linhas pares */
}

/* Efeito Hover */
.table-row:hover {
    background-color: rgba(140, 61, 245, 0.2); /* Fundo roxo suave no hover */
    cursor: pointer;
    transform: scale(1.005); /* Leve crescimento no hover */
}

/* Destaque para o 1º Colocado */
.ranking-table .table-row:first-of-type {
    background: linear-gradient(90deg, rgba(255, 207, 43, 0.2) 0%, rgba(11, 15, 18, 0.85) 100%);
    border-left: 5px solid var(--accent-yellow); /* Borda dourada à esquerda */
    font-size: 1.05em;
    font-weight: 700;
}

/* Ajuste para o 1º Colocado no hover */
.ranking-table .table-row:first-of-type:hover {
    background: linear-gradient(90deg, rgba(255, 207, 43, 0.3) 0%, rgba(140, 61, 245, 0.25) 100%);
}

/* Cor da coluna de pontuação (última coluna) */
.table-row .col:last-child {
    font-weight: 700;
    color: var(--cyan);
}

/* Destaque do nome */
.table-row .name {
    font-weight: 700;
    color: #fff;
}

/* Estilo e animação para o Badge de Coroa (👑) */
.badge.crown {
    margin-left: 5px;
    font-size: 1.2em;
    vertical-align: middle;
    display: inline-block;
    animation: glow 1.5s infinite alternate; /* Adiciona uma animação */
}

@keyframes glow {
    from {
        text-shadow: 0 0 5px rgba(255, 207, 43, 0.5), 0 0 10px rgba(255, 207, 43, 0.3);
    }
    to {
        text-shadow: 0 0 10px var(--accent-yellow), 0 0 20px rgba(255, 207, 43, 0.8);
    }
}
/* FIM NOVO DESTAQUE DE FORMATAÇÃO */

/* PORTADORES */
.section-portadores .portadores-row{display:flex;gap:40px;justify-content:center;align-items:stretch}
/* CORREÇÃO: Removido overflow:hidden para que o badge possa sair da caixa */
.port-card{flex:1;border-radius:24px;padding:0;background:linear-gradient(180deg, rgba(0,0,0,0.75), rgba(0,0,0,0.85));position:relative;min-height:420px;border:3px solid rgba(255,255,255,0.02)}

/* O posicionamento do badge com top: -20px e z-index já está correto */
.port-card .port-badge{
  position:absolute;
  top:-20px; 
  left:50%;
  transform:translateX(-50%);
  padding:10px 36px;
  border-radius:36px;
  background:rgba(255,255,255,0.02);
  font-weight:700;
  z-index: 10; 
}
.port-card.purple .port-badge{background:linear-gradient(90deg,var(--purple),#b35bff);color:white}
.port-card.blue .port-badge{background:linear-gradient(90deg,var(--blue),#63b8ff);color:white}
.port-media{height:390px;background-size:cover;background-position:center}
.port-info{padding:20px;color:rgba(255,255,255,0.95);display:flex;align-items:center;justify-content:space-between;gap:10px}
.port-info h3{margin:0;color:var(--accent-yellow);font-size:28px}
.port-info .guild{color:rgba(255,255,255,0.85)}
.port-info .points{color:var(--accent-yellow);font-weight:700}
.port-icon{width:52px;height:52px;border-radius:999px;border:4px solid rgba(255,255,255,0.06);display:grid;place-items:center;background:rgba(0,0,0,0.25)}

/* DOWNLOAD SECTION */
.section-download{
  padding-top: 42px;
  min-height: 80vh;
  /* CAMINHO DA IMAGEM DE FUNDO */
  background-image: url('images/download-bg.jpg'); 
  background-size: cover;
  background-position: center top;
  position: relative;
  /* Efeito de Parallax */
  background-attachment: fixed;
}
.section-download::before {
    content: '';
    position: absolute;
    inset: 0;
    /* Overlay escuro e azulado como na imagem de referência */
    background: rgba(0, 0, 0, 0.7); 
    z-index: 1;
}
.section-download > .container {
    position: relative;
    z-index: 2; 
}
.section-download .section-title{
    color: var(--accent-yellow);
}

.download-grid{
    display: flex;
    gap: 40px;
    margin-top: 40px;
    align-items: flex-start;
}

.download-left{
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.download-card{
    background: var(--panel); 
    border-radius: 12px;
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}
.download-card h3{
    margin: 0 0 4px;
    font-size: 20px;
    font-weight: 700;
}
.download-card p{
    margin: 0 0 16px;
    color: var(--muted);
    font-size: 14px;
}
.download-card .download-btn{
    /* TRANSFORMA O LINK EM UM BLOCO VISUAL DE BOTÃO */
    display: block; 
    text-align: center;
    text-decoration: none; 
    cursor: pointer;
    padding: 12px;
    background: var(--accent-yellow);
    border: none;
    border-radius: 8px;
    font-weight: 700;
    color: #081014;
    transition: background-color 0.2s;
    margin-top: 15px; 
}

.download-card .download-btn:hover{
    background: var(--accent-yellow-dark);
}

.requirements-table{
    flex: 1;
    background: var(--panel); 
    border-radius: 12px;
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, 0.05);
	height: 360px;
}
.requirements-table h3{
    margin: 0 0 16px;
    font-size: 20px;
    font-weight: 700;
}
.req-row{
    display: flex;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.req-row:last-child{
    border-bottom: none;
}
.req-label{
    color: var(--muted);
}
.req-value{
    font-weight: 600;
    color: rgba(255, 255, 255, 0.9);
}

.download-support{
    text-align: center;
    margin-top: 40px;
    font-size: 14px;
    color: var(--muted);
}
.download-support a{
    color: var(--cyan-2);
    text-decoration: none;
    font-weight: 600;
}
/* FIM DOWNLOAD SECTION */

/* RODAPÉ */
.site-footer{padding:36px 0;background:#0b0f12;border-top:1px solid rgba(255,255,255,0.02)}
.footer-inner{display:flex;justify-content:space-between;align-items:center}
.footer-left p{color:rgba(255,255,255,0.6)}
.footer-right .s{margin-left:8px;padding:8px 10px;border-radius:8px;background:rgba(255,255,255,0.02)}

/* floating action & rail */
.float-action{position:fixed;right:22px;bottom:20px;z-index:80;width:54px;height:54px;border-radius:999px;background:var(--accent-yellow);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,0.2)}
.right-rail{position:fixed;right:0;top:0;height:100%;width:8px;background:linear-gradient(180deg,var(--accent-yellow),#ffd45a 55%, #f6d068 100%);z-index:20}

/* MODAL STYLES */
.modal-backdrop{
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(5px);
    z-index: 100;
    display: none; 
    place-items: center; 
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}
.modal-backdrop.active{
    display: grid; 
    opacity: 1;
}
.modal{
    width: 90%;
    max-width: 440px;
    background: var(--bg-dark); 
    border-radius: 12px;
    padding: 30px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    position: relative;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4);
    transform: scale(0.95) translateY(-20px); 
    opacity: 0;
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
}
.modal-backdrop.active .modal{
    transform: scale(1) translateY(0);
    opacity: 1;
}
.modal-header{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}
.modal-header .close-btn{
    background: none;
    border: none;
    color: var(--muted);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    padding: 0;
}
.modal-header .close-btn:hover{
    color: var(--cyan-2);
}
.modal h2{
    font-size: 26px;
    font-weight: 700;
    margin: 0;
}
.modal p{
    font-size: 14px;
    color: var(--muted);
    margin-bottom: 24px;
}
.form-group{
    margin-bottom: 20px;
}
.form-group label{
    display: block;
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 6px;
}
.input-field-wrap{
    position: relative;
}
.input-field{
    width: 100%;
    padding: 12px 16px;
    background: var(--bg-dark);
    border: 2px solid rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    color: white;
    font-size: 16px;
    outline: none;
    transition: border-color 0.2s;
}
.input-field:focus{
    border-color: var(--accent-yellow);
}
.input-field::placeholder{
    color: rgba(255, 255, 255, 0.4);
}
.password-toggle{
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--muted);
    cursor: pointer;
    /* Adicionando z-index para garantir que esteja acima do input */
    z-index: 5; 
}
.forgot-password{
    display: block;
    text-align: right;
    font-size: 14px;
    color: var(--accent-yellow);
    text-decoration: none;
    margin-top: -10px;
    margin-bottom: 24px;
    font-weight: 500;
}
.forgot-password:hover{
    text-decoration: underline;
}
.btn-modal-login{
    width: 100%;
    padding: 14px;
    background: linear-gradient(180deg, #d4ae3f, #a78832);
    color: #081014;
    font-weight: 800;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
    transition: background 0.2s;
}
.btn-modal-login:hover{
    background: linear-gradient(180deg, #e3c054, #b99a41);
}
.modal-footer{
    text-align: center;
    margin-top: 24px;
    font-size: 14px;
    color: var(--muted);
}
.modal-footer a{
    color: var(--accent-yellow);
    text-decoration: none;
    font-weight: 600;
}
.modal-footer a:hover{
    text-decoration: underline;
}
.modal-form-content {
    display: none;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}
.modal-form-content.active {
    display: block;
    opacity: 1;
}


/* responsive */
@media (max-width:1000px){
  .hero-left{width:68%}
  .hero-character{width:40%; max-width: 520px;} 
  .port-card{min-height:380px}
}
@media (max-width:720px){
  .hero-title-text{
    font-size: 40px; 
    height: 40px;
  }
  .hero-title-container{
    height: 40px;
  }
  .main-nav{display:none}
  .btn-enter{padding:8px 12px}
  .hero{min-height:620px}
  .hero-left{width:100%}
  .hero-character{display:none}
  .portadores-row{flex-direction:column}
  .news-grid{flex-direction:column}
  .download-grid{flex-direction:column}
  .container{padding:0 18px}
  
  /* Ajuste no ranking para evitar cortes em 720px */
  .table-head, .table-row{
      grid-template-columns: 40px 1fr 100px 100px; 
      font-size: 14px;
      padding: 10px 8px;
  }
  .table-row .name {
      white-space: nowrap; 
      overflow: hidden;
      text-overflow: ellipsis;
  }
  .ranking-controls {
      flex-direction: column;
      gap: 15px;
      align-items: stretch;
  }
  .modes, .servers {
      justify-content: center;
      flex-wrap: wrap; 
  }
  .modes button, .servers button {
      flex-grow: 1;
      text-align: center;
      min-width: 80px;
  }
  /* FIM Ajuste no ranking */

  /* Ajuste no Rodapé */
  .footer-inner {
      flex-direction: column;
      gap: 20px;
      text-align: center;
  }
  .footer-right .socials-inline {
      margin-top: 10px;
  }
  /* FIM Ajuste no Rodapé */

  /* Melhoria de legibilidade no Modal em telas muito pequenas */
    .modal h2 {
        font-size: 22px;
    }
    .modal p, .modal-footer {
        font-size: 13px;
    }
}
/* Media Query extra para telas muito estreitas (opcional) */
@media (max-width: 480px){
    .table-head, .table-row{
        /* Simplificação máxima para telas muito pequenas */
        /* Oculta Classe (3ª) e Clan (4ª) colunas */
        grid-template-columns: 30px 1fr 80px; 
    }
    /* Oculta as colunas menos essenciais no modo mobile extremo */
    .table-head div:nth-child(3), .table-row div:nth-child(3) {
        display: none; /* Classe */
    }
    .table-head div:nth-child(4), .table-row div:nth-child(4) {
        display: none; /* Clan */
    }
    /* Reajuste para a coluna de pontuação (PKILL/EXP/DUEL) */
    .table-head div:nth-child(5), .table-row div:nth-child(5) {
         grid-column: 3; /* Move a coluna de pontuação para a 3ª posição visível */
    }
    /* Mantém a nova formatação, mas ajusta a coroa no mobile */
    .badge.crown {
         font-size: 1em;
    }
}

.brand {
    display: flex;
    justify-content: center;
    align-items: center;
}

.logo-img {
    display: block; 
    margin-left: auto;
    margin-right: auto;
	max-width: 400px;
	filter:drop-shadow(0 18px 60px rgba(20,120,220,0.12));
}

/* 1. Torna a seção hero o contêiner de referência para o vídeo */
.hero {
  position: relative; /* Crucial para o position: absolute do vídeo */
  height: 100vh;      /* Exemplo: Define a altura total da viewport. Ajuste conforme sua necessidade */
  overflow: hidden;   /* Esconde partes do vídeo que excedam o tamanho da seção */
}

/* 2. Estiliza o vídeo de fundo para cobrir todo o espaço */
#background-video {
  position: absolute; /* Posiciona em relação ao .hero */
  top: 0;
  left: 0;
  min-width: 100%;    /* Garante que ocupe a largura total */
  min-height: 100%;   /* Garante que ocupe a altura total */
  width: auto;
  height: auto;
  
  /* Mantém a proporção e cobre todo o espaço, cortando o excesso */
  object-fit: cover;
  
  /* Coloca o vídeo na camada mais baixa, atrás de tudo */
  z-index: -2; 
}

/* 3. Ajuste o Z-Index do Overlay e Conteúdo */

	