/* =====================================================
   PUB — TRIPLABZ 2026
===================================================== */

:root {
  --bg: #000;
  --fg: #fff;
  --muted: rgba(255,255,255,.7);
  --gap: clamp(3rem, 6vw, 8rem);
}

* {
  box-sizing: border-box;
}

body.page-pub {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: 'Inter', sans-serif;
}

/* =====================================================
   TOPO
===================================================== */

.topbar{
  position:fixed;
  top:0;left:0;right:0;
  height:var(--header-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 22px;
  z-index:100;
}

.topbar img {
  height: 150px;
  pointer-events: auto;
}

/* =====================================================
   DEMOREEL
===================================================== */

.pub-demoreel {
  position: relative;
  height: 100vh;
  overflow: hidden;
}

.pub-demoreel-bg video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-vignette {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at center,
    rgba(0,0,0,.2),
    rgba(0,0,0,.8)
  );
}

.pub-demoreel-title {
  position: absolute;
  bottom: 8vh;
  left: 50%;
  transform: translateX(-50%);
  font-size: clamp(4rem, 10vw, 9rem);
  font-weight: 800;
  letter-spacing: .08em;
}

/* =====================================================
   CONTAINER
===================================================== */

.pub-page-content {
  width: 100%;
}

/* =====================================================
   PROJETOS (FULLPAGE)
===================================================== */

.media-block {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
  align-items: center;
  padding: 0 8vw;
}

/* alternância */
.media-block {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-areas: "video text";
  gap: var(--gap);
  align-items: center;
  padding: 0 8vw;
}

.media-block.reverse {
  grid-template-areas: "text video";
}

.media-video {
  grid-area: video;
}

.media-text {
  grid-area: text;
}


/* =====================================================
   TEXTO
===================================================== */

.media-text {
  max-width: 520px;
}

.media-text h3 {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 600;
  margin-bottom: 1rem;
}

.media-text p {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--muted);
}

/* centralização fina */
.media-block:not(.reverse) .media-text {
  justify-self: start;
}

.media-block.reverse .media-text {
  justify-self: end;
  text-align: right;
}

/* =====================================================
   VÍDEO
===================================================== */

.media-video {
  width: 100%;
}

.media-video video {
  width: 100%;
  max-height: 60vh;
  object-fit: contain;
  background: #000;
}

/* =====================================================
   FOOTER
===================================================== */

.footer {
  padding: 4rem 8vw;
  background: #000;
}

.footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.footer-copy {
  font-size: .85rem;
  color: var(--muted);
}

.social-mini {
  display: flex;
  gap: 1rem;
}

.social-mini img {
  height: 20px;
  opacity: .8;
}


/* =======================
   FOOTER – CONFIANÇA
======================= */

.footer{
  padding:48px 0 32px;
  text-align:center;
}

.footer-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
}

.footer-copy{
  font-size:13px;
  color:var(--muted);
  letter-spacing:.08em;
}

/* ÍCONES */
.footer .social-mini{
  display:flex;
  gap:26px;
}

.footer .social-mini img{
  width:20px;
  opacity:.6;
  transition:.25s;
}

.footer .social-mini img:hover{
  opacity:1;
  transform:scale(1.15);
}
/* =======================
   FOOTER – FONT AWESOME
======================= */

.footer .social-mini a{
  color:#fff;                 /* branco puro */
  font-size:22px;             /* tamanho visível */
  opacity:.75;
  transition:.25s;
}

.footer .social-mini a:hover{
  opacity:1;
  transform:scale(1.2);
}
/* =======================
   FOOTER – IMAGEM (WHATSAPP)
======================= */

.footer{
  padding:64px 0 48px;
  text-align:center;
}

.footer-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:22px;
}

.footer-copy{
  font-size:13px;
  color:var(--muted);
  letter-spacing:.08em;
}

/* ÍCONE COM IMAGEM */
.footer .social-mini{
  display:flex;
  justify-content:center;
  align-items:center;
}

.footer .social-mini a{
  display:flex;
  align-items:center;
  justify-content:center;
}

.footer .social-mini img{
  width:42px;          /* tamanho ideal */
  height:auto;
  opacity:.75;
  transition:.3s ease;
}

.footer .social-mini img:hover{
  opacity:1;
  transform:scale(1.15);
}


/* =======================
   AJUSTE FINAL – SOBRE + FOOTER
   (NÃO REMOVE NADA)
======================= */

/* reduz o espaço inferior do Sobre */
#sobre{
  padding-bottom:20px;   /* antes estava “infinito” visualmente */
}

/* puxa o footer levemente para cima */
.footer{
  margin-top:-200px;
}

/* =========================================
   BOTÃO VOLTAR — ESTILO SAIBA MAIS
========================================= */

.back-home{
  position: fixed;
  top: 17vh;        /* <<< AJUSTE AQUI (60~75vh) */
  left: 42px;

  text-decoration: none;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;

  color: #fff;
  opacity: .85;
  z-index: 30;
  pointer-events: auto;
}


.back-home:hover{
  opacity: 1;
}

/* =========================================
   MOBILE — AJUSTE DEMOREELS (SEM QUEBRAR)
========================================= */

@media (max-width: 900px) {

  /* =====================
     PRIMEIRO DEMOREEL
     (visual inicial igual index)
  ===================== */

  .pub-demoreel {
    height: 100svh;
    min-height: 100svh;
  }

  .pub-demoreel-bg video {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* =====================
     DEMAIS BLOCOS
  ===================== */

  .media-block {
    flex-direction: column;
    gap: 20px;
    padding: 56px 20px;
  }

  /* mantém a ordem lógica (não inverte) */
  .media-block.reverse {
    flex-direction: column;
  }

  /* =====================
     VÍDEO MAIOR
  ===================== */

  .media-video {
    width: 100%;
  }

  .media-video video {
    width: 100%;
    height: auto;
    max-height: 65svh;
    object-fit: cover;
  }

  /* =====================
     TEXTO EMBAIXO
  ===================== */

  .media-text {
    max-width: 100%;
    text-align: left; /* mantém identidade */
  }

  .media-text h3 {
    font-size: 17px;
    margin-bottom: 6px;
    letter-spacing: .08em;
  }

  .media-text p {
    font-size: 15px;
    line-height: 1.6;
  }

}

/* =========================================
   MOBILE — DEMOREEL 100% PRIMEIRA VISÃO
========================================= */

@media (max-width: 900px) {

  html, body {
    height: 100%;
  }

  body {
    overflow-x: hidden;
  }

  /* container principal */
  .pub-demoreel {
    position: relative;
    height: 100vh;        /* fallback */
    height: 100svh;       /* mobile moderno */
    min-height: 100vh;
    padding: 0;
    margin: 0;
  }

  /* vídeo colado na viewport */
  .pub-demoreel-bg,
  .pub-demoreel-bg video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }

  .pub-demoreel-bg video {
    object-fit: cover;
  }

}
/* =========================================
   AJUSTE MEDIA TEXT <p>
========================================= */

.media-text p{
  color: #fff;          /* branco puro */
  text-align: center;  /* justificado */
  font-size: 1.50rem;   /* levemente maior */
  line-height: 3.0;    /* melhora leitura */
  letter-spacing: .02em;
  font-weight: 500;
}

/* mantém proporção no mobile */
@media (max-width: 900px){
  .media-text p{
    font-size: 0.95rem;
    line-height: 2.0;
  }
}
