/* =========================================================
   VARIÁVEIS
========================================================= */
:root{
  --clr-primary:#b71118;
  --clr-dark:#111111;
  --clr-light:#f2f2f2;
  --clr-white:#ffffff;
  --clr-text:#222222;

  --ff-title:'Poppins','Segoe UI',Arial,sans-serif;
  --ff-base:'Inter','Segoe UI',Arial,sans-serif;
}

/* =========================================================
   RESET & BASE
========================================================= */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--ff-base);
  background:var(--clr-light);
  color:var(--clr-text);
  line-height:1.5;
}
.container{width:100%;max-width:1240px;margin:auto;padding-inline:1rem}

/* =========================================================
   TOP BAR - Adicionando estilos para a barra superior
========================================================= */
.top-bar {
  background: var(--clr-dark);
  color: var(--clr-white);
  padding: 0.5rem 0;
}

.top-bar .container {
  display: flex;
  justify-content: flex-end;
  gap: 1rem;
}

.top-bar a {
  color: var(--clr-white);
  text-decoration: none;
  font-size: 1rem;
  transition: .25s;
}

.top-bar a:hover {
  color: var(--clr-primary);
}

/* =========================================================
   HEADER
========================================================= */
.header-wrapper{
  position:sticky;top:0;z-index:1000;background:var(--clr-white);
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  min-height:80px;padding-block:.25rem;
}
.logo img{height:60px}

.main-nav{display:flex;align-items:center}
.main-nav ul{display:flex;gap:1.5rem;list-style:none;font-weight:600}
.main-nav a{color:var(--clr-dark);text-decoration:none;position:relative;padding:.2rem 0}
.main-nav a::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:2px;
             background:var(--clr-primary);transition:.25s}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}

/* ícone hambúrguer */
.mobile-menu-toggle{
  display:none;
  background:none;
  border:none;
  font-size:1.7rem;
  color:var(--clr-dark);
  cursor:pointer;
  z-index:1002;
}

/* overlay para fechar menu */
.nav-overlay{display:none}

@media (max-width:991px){
  .mobile-menu-toggle{
    display:block;
  }

  /* esconde menu horizontal */
  .main-nav ul{
    flex-direction:column;
    gap:1.25rem;
    font-size:1.05rem;
  }

  .main-nav{
    position:fixed;
    top:0;
    right:0;
    bottom:0;
    width:280px;
    background:var(--clr-white);
    flex-direction:column;
    align-items:flex-start;
    padding:5rem 2rem 2rem;
    transform:translateX(100%);
    transition:transform .3s ease;
    box-shadow:-3px 0 8px rgba(0,0,0,.08);
    z-index:1001;
  }
  
  .main-nav.active{
    transform:translateX(0);
  }

  .nav-overlay{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.5);
    z-index:1000;
    opacity:0;
    pointer-events:none;
    transition:opacity .3s ease;
  }
  
  .nav-overlay.active{
    opacity:1;
    pointer-events:all;
  }
}

/* =========================================================
   BANNER / HERO
========================================================= */
.banner{position:relative;height:100vh;background:var(--clr-dark);overflow:hidden}
#banner-slider{height:100%}
.banner-slide{position:absolute;inset:0;opacity:0;transition:.9s}
.banner-slide.current{opacity:1}
.banner-slide img{width:100%;height:100%;object-fit:cover}
.banner-content{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  text-align:center;
  background:rgba(0,0,0,.45);
  color:var(--clr-white);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:2rem;
}
.banner-content h2{
  font-family:var(--ff-title);
  font-weight:700;
  letter-spacing:-.5px;
  font-size:clamp(2.1rem,4vw+1rem,3.8rem);
  margin-bottom:1rem;
}
.banner-content p{
  max-width:650px;
  margin:0 auto 2rem auto;
  font-size:clamp(1rem,1.2vw+.6rem,1.3rem);
}
.btn{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-weight:600;
  text-decoration:none;
  border-radius:40px;
  padding:.8rem 1.8rem;
  transition:.25s;
  margin-top:1rem;
}
.banner-content .btn{
  background:var(--clr-primary);
  color:var(--clr-white);
}
.banner-content .btn:hover{
  background:#991016;
}
.banner-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:2rem;color:var(--clr-white);
            background:rgba(0,0,0,.4);border:none;width:48px;height:48px;display:grid;
            place-content:center;cursor:pointer;transition:.25s;z-index:1}
.banner-nav:hover{background:rgba(0,0,0,.6)}
.banner-nav.prev{left:1rem}.banner-nav.next{right:1rem}
@media(max-width:576px){
  .banner-nav.prev{left:.5rem}
  .banner-nav.next{right:.5rem}
  
  .banner-content h2 {
    font-size: clamp(1.8rem, 3vw + 0.8rem, 3rem);
  }
  
  .banner-content p {
    font-size: clamp(0.9rem, 1vw + 0.5rem, 1.1rem);
  }
  
  .btn {
    padding: 0.6rem 1.4rem;
    font-size: 0.9rem;
  }
}

/* =========================================================
   SEÇÕES GENÉRICAS
========================================================= */
section{padding:4rem 0;background:var(--clr-light);scroll-margin-top:100px}
.section-title{
  text-align:center;font-family:var(--ff-title);font-weight:700;letter-spacing:-.4px;
  font-size:clamp(2.1rem,2.5vw+1rem,3rem);margin-bottom:2rem;color:var(--clr-dark)
}

/* =========================================================
   SERVIÇOS
========================================================= */
.servicos-grid{display:grid;gap:2rem;grid-template-columns:repeat(3,1fr)}
@media(max-width:992px){.servicos-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.servicos-grid{grid-template-columns:1fr}}

.servico-item{
  background:var(--clr-white);border-radius:12px;padding:2.2rem 1.6rem;text-align:center;
  box-shadow:0 4px 14px rgba(0,0,0,.05);display:flex;flex-direction:column;height:100%;
  transition:.25s
}
.servico-item:hover{transform:translateY(-6px);box-shadow:0 6px 18px rgba(0,0,0,.08)}
.servico-icon img{
  width:110px;height:110px;border-radius:50%;object-fit:cover;margin:0 auto 1.25rem;
}
.servico-item h3{
  font-family:var(--ff-title);font-weight:700;font-size:1.1rem;margin-bottom:.65rem
}
.servico-item p{
  font-size:.95rem;line-height:1.4;color:#555;max-width:250px;margin:0 auto
}
.servicos .btn-servico{display:none}

/* =========================================================
   TRABALHOS
========================================================= */
.trabalhos-subtitle{max-width:800px;margin:0 auto 2rem;text-align:center;color:#555}
.trabalhos-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(270px,1fr))}
.trabalho-item{
  background:var(--clr-white);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 4px 14px rgba(0,0,0,.05);transition:.25s
}
.trabalho-item:hover{transform:translateY(-6px)}
.trabalho-image img{width:100%;height:180px;object-fit:cover;display:block}
.trabalho-content{flex:1 1 auto;display:flex;flex-direction:column;padding:1.25rem 1rem 2rem;text-align:center}
.trabalho-content h3{
  font-family:var(--ff-title);font-weight:600;font-size:1.15rem;line-height:1.35;margin-bottom:1rem
}
.trabalhos .btn-servico{
  margin-top:auto;align-self:center;padding:.6rem 1.6rem;font-weight:600;
  color:var(--clr-white);background:var(--clr-primary);
  border-radius:30px;text-decoration:none;transition:.25s
}
.trabalhos .btn-servico:hover{background:#991016}

/* botão "Ver todos" */
.btn-todos-trabalhos{
  display:flex;width:max-content;margin:3rem auto 0;align-items:center;gap:.6rem;
  padding:.8rem 1.8rem;font-weight:700;font-size:1.05rem;color:var(--clr-white);
  background:var(--clr-primary);border-radius:40px;text-decoration:none;transition:.25s
}
.btn-todos-trabalhos i{transition:transform .25s}
.btn-todos-trabalhos:hover{background:#991016}
.btn-todos-trabalhos:hover i{transform:translateX(4px)}

@media (max-width: 576px) {
  .btn-todos-trabalhos {
    padding: 0.7rem 1.5rem;
    font-size: 0.95rem;
    margin-top: 2rem;
  }
}

/* =========================================================
   SEÇÃO DE DEPOIMENTOS
========================================================= */
.section-depoimentos {
  padding: 80px 0;
  background-color: var(--clr-light);
}

.depoimentos-carousel {
  max-width: 800px;
  margin: 30px auto;
  position: relative;
}

.depoimento-atual {
  background: var(--clr-white);
  border-radius: 8px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
  padding: 30px;
  min-height: 200px;
  display: flex;
  flex-direction: column;
}

.depoimento-header {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
}

.depoimento-avatar {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  object-fit: cover;
  margin-right: 15px;
  border: 3px solid var(--clr-primary);
}

.depoimento-info h3 {
  font-family: var(--ff-title);
  font-weight: 600;
  font-size: 1.1rem;
  margin-bottom: 5px;
}

.depoimento-info p {
  font-size: 0.9rem;
  color: #666;
}

.depoimento-texto {
  font-size: 0.95rem;
  line-height: 1.6;
  color: #333;
  font-style: italic;
  position: relative;
  flex-grow: 1;
  margin-bottom: 15px;
}

.depoimento-rating {
  display: flex;
  margin-top: auto;
}

.depoimento-rating i {
  color: #FFD700;
  margin-right: 3px;
}

.depoimentos-controles {
  display: flex;
  justify-content: center;
  margin-top: 20px;
  gap: 10px;
}

.depoimento-nav {
  background: var(--clr-primary);
  color: var(--clr-white);
  border: none;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s ease;
  font-size: 0.8rem;
}

.depoimento-nav:hover {
  background: #991016;
}

.depoimentos-botao-container {
  text-align: center;
  margin-top: 30px;
}

.depoimentos-botao {
  display: flex;
  width: max-content;
  margin: 0 auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.8rem 1.8rem;
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--clr-white);
  background: var(--clr-primary);
  border-radius: 30px;
  text-decoration: none;
  transition: 0.25s;
}

.depoimentos-botao i {
  transition: transform 0.3s ease;
}

.depoimentos-botao:hover {
  background: #991016;
}

.depoimentos-botao:hover i {
  transform: translateX(5px);
}

@media (max-width: 768px) {
  .section-depoimentos {
    padding: 60px 0;
  }
  
  .depoimento-atual {
    padding: 20px;
  }
}

/* =========================================================
   PÁGINA DE TRABALHO INDIVIDUAL
========================================================= */
.trabalho-detalhes {
  padding: 60px 0;
}

.trabalho-title {
  font-size: 2.5rem;
  margin-bottom: 20px;
  color: var(--clr-primary);
  text-align: center;
}

.social-share {
  display: flex;
  justify-content: center;
  margin-bottom: 30px;
  gap: 15px;
}

.social-btn {
  display: inline-flex;
  align-items: center;
  padding: 8px 15px;
  border-radius: 5px;
  color: #fff;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.3s ease;
}

.social-btn i {
  margin-right: 8px;
}

.social-btn.telegram {
  background-color: #0088cc;
}

.social-btn.instagram {
  background-color: #e1306c;
}

.social-btn.youtube {
  background-color: #ff0000;
}

.social-btn:hover {
  opacity: 0.9;
  transform: translateY(-2px);
}

.trabalho-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 1000px;
  margin: 0 auto;
}

.trabalho-image-container {
  width: 100%;
  max-width: 600px;
  margin-bottom: 30px;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}

.trabalho-image-full {
  width: 100%;
  height: auto;
  display: block;
}

.trabalho-description {
  width: 100%;
  line-height: 1.8;
  font-size: 1.1rem;
  color: #333;
  margin-bottom: 30px;
  white-space: pre-line;
}

.trabalho-actions {
  margin-top: 30px;
  text-align: center;
}

.btn-voltar {
  display: inline-flex;
  align-items: center;
  padding: 12px 25px;
  background-color: var(--clr-primary);
  color: #fff;
  border-radius: 5px;
  text-decoration: none;
  font-weight: 600;
  transition: all 0.3s ease;
}

.btn-voltar i {
  margin-right: 8px;
}

.btn-voltar:hover {
  background-color: #991016;
  transform: translateY(-2px);
}

/* Responsividade */
@media (max-width: 768px) {
  .trabalho-title {
    font-size: 2rem;
  }
  
  .social-share {
    flex-wrap: wrap;
  }
  
  .trabalho-image-container {
    max-width: 100%;
  }
  
  .trabalho-description {
    font-size: 1rem;
  }
}

/* =========================================================
   FOOTER
========================================================= */
footer{background:var(--clr-primary);color:var(--clr-white)}
.footer-content{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
                padding:4rem 0 2rem}
.footer-logo img{width:140px;filter:brightness(0) invert(1)}
.footer-links h3,.footer-contact h3{
  font-size:1.125rem;margin-bottom:1rem;font-family:var(--ff-title);font-weight:600
}
.footer-links ul{list-style:none;display:grid;gap:.5rem}
.footer-links a{color:var(--clr-white);text-decoration:none;font-size:.95rem;transition:.25s}
.footer-links a:hover{opacity:.7}
.footer-contact p{font-size:.95rem;margin-bottom:.5rem}
.footer-contact i{margin-right:.5rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.2);text-align:center;font-size:.875rem;padding:1rem 0}

/* Ajuste para telas menores e dispositivos móveis */
@media (max-width: 992px) {
  .footer-content {
    padding: 4rem 20px 2rem;
  }
  
  .footer-bottom {
    padding: 1rem 20px;
  }
}

@media (max-width: 768px) {
  .footer-content {
    padding: 3.5rem 25px 2rem;
  }
}

@media (max-width: 576px) {
  .footer-content {
    padding: 3rem 30px 1.5rem;
    gap: 1.5rem;
  }
  
  .footer-bottom {
    padding: 1rem 30px;
  }
}

/* =========================================================
   SEÇÃO SOBRE O AUTOR
========================================================= */
.autor-section {
  background-color: var(--clr-dark);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  color: var(--clr-white);
  padding: 8rem 0; /* Aumentado o espaçamento vertical */
}

.autor-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  z-index: 1;
}

.autor-container {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 3rem;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.autor-text {
  flex: 1;
  min-width: 300px;
  text-align: left;
}

.autor-photo {
  flex: 0 0 300px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.autor-photo-wrapper {
  width: 300px;
  height: 300px;
  border-radius: 50%;
  overflow: hidden;
  border: 5px solid var(--clr-primary);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
}

.autor-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.autor-photo-wrapper:hover .autor-img {
  transform: scale(1.05);
}

.autor-text h2 {
  font-family: var(--ff-title);
  font-size: clamp(2rem, 3vw + 1rem, 2.8rem);
  margin-bottom: 2rem;
  color: var(--clr-white);
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
}

.autor-text p {
  font-size: 1.15rem;
  line-height: 1.8;
  margin-bottom: 2.5rem;
  color: var(--clr-white);
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5);
}

.autor-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  background-color: var(--clr-primary);
  color: var(--clr-white);
  padding: 0.9rem 2.5rem;
  border-radius: 50px;
  font-weight: 700;
  font-size: 1.05rem;
  text-decoration: none;
  transition: all 0.3s ease;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
}

.autor-btn:hover {
  background-color: #991016;
  transform: translateY(-3px);
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.4);
}

.autor-btn i {
  transition: transform 0.3s ease;
}

.autor-btn:hover i {
  transform: translateX(4px);
}

/* Responsividade */
@media (max-width: 992px) {
  .autor-container {
    flex-direction: column-reverse;
    text-align: center;
    gap: 2.5rem;
  }
  
  .autor-text {
    text-align: center; /* min-width: 300px; ainda se aplica aqui */
  }
  
  .autor-photo {
    margin: 0 auto;
  }
  
  .autor-photo-wrapper {
    width: 250px;
    height: 250px;
  }
}

@media (max-width: 768px) {
  .autor-section {
    padding: 6rem 0;
  }
  
  .autor-text p {
    font-size: 1.05rem;
    padding: 0 15px;
  }
  
  .autor-photo-wrapper {
    width: 200px;
    height: 200px;
  }
}

@media (max-width: 576px) {
  .autor-container {
    padding: 0 30px;
  }
  
  .autor-photo-wrapper {
    width: 180px;
    height: 180px;
  }

  /* ADICIONADO PARA CORRIGIR O ESPAÇAMENTO DO TEXTO DO AUTOR EM TELAS MUITO PEQUENAS */
  .autor-text {
    min-width: 0; /* Permite que o texto do autor encolha e respeite os paddings do container pai */
  }
}

/* Estilização para links no contato do rodapé */
footer .footer-contact a {
  color: var(--clr-white); /* Usa a variável de cor branca já definida */
  text-decoration: none;   /* Remove o sublinhado padrão dos links */
}

footer .footer-contact a:hover {
  opacity: 0.8; /* Leve efeito de transparência ao passar o mouse, opcional */
  /* ou você pode adicionar um sublinhado no hover se preferir: */
  /* text-decoration: underline; */
}