
.historial {
  display: flex;
  flex-wrap: wrap; /* permite quebrar linha em telas pequenas */
  align-items: flex-start;
  justify-content: center; /* centraliza no celular */
  gap: 20px; /* espaçamento entre imagem e texto */
  padding: 20px;
}

.text_his {
  margin-top: 0;
  margin-right: 0;
  font-size: 14px;
  text-align: justify;
  font-family: sans-serif;
  max-width: 600px; /* limita largura no desktop */
}

.historial_box {
  background-color: #cfcfcf;
  padding: 20px;
  margin: 20px;
  border-radius: 10px;
}

.logotipo {
  width: 100%;
  max-width: 350px; /* nunca ultrapassa 350px */
  height: auto; /* mantém proporção */
  display: block;
  margin: 0 auto; /* centraliza imagem em telas pequenas */
}

/* Responsividade para celulares */
@media (max-width: 768px) {
  .historial {
    flex-direction: column; /* empilha imagem e texto */
    align-items: center;
  }

  .text_his {
    font-size: 12px; /* texto menor para celular */
    max-width: 90%; /* ocupa quase toda a tela */
    margin-top: 15px;
  }

  .logotipo {
    max-width: 80%; /* imagem menor e proporcional */
  }
}


/* Reset */
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:Arial,sans-serif;background:#fdfdfd;color:#333;line-height:1.6;}

/* Header animado */
.header-animado{
  position:sticky;
  top:0;
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:15px 50px;
  background:#000000;
  background-size:600% 600%;
  animation:gradientMove 15s ease infinite;
  box-shadow:0 4px 20px rgba(0,0,0,0.2);
  z-index:1000;
}
.header-animado .logo{font-size:2rem;font-weight:bold;color:#808080;cursor:default;transition:transform 0.3s ease;}
.header-animado .logo:hover{transform:scale(1.1); color:#fff;}
.header-animado nav a{color:#808080;margin-left:25px;text-decoration:none;font-weight:bold;position:relative;transition:color 0.3s ease;}
.header-animado nav a::after{content:'';position:absolute;width:0%;height:3px;bottom:-5px;left:0;background:#fff;transition:width 0.3s;}
.header-animado nav a:hover{color:#fff;}
.header-animado nav a:hover::after{width:100%;}
@keyframes gradientMove{0%{background-position:0% 50%;}50%{background-position:100% 50%;}100%{background-position:0% 50%;}}

/* Hero */
.hero-fullscreen {
  
  position: relative;
  width: 100vw;       /* ocupa toda a largura da janela */
  min-height: 100vh;  /* altura total */
  display: flex;
  justify-content: center;
  align-items: center;

  background: linear-gradient(to right, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.2) 20%, rgba(0,0,0,0.2) 80%, rgba(0,0,0,0.8) 100%),
  url('https://images.unsplash.com/photo-1507874457470-272b3c8d8ee2?auto=format&fit=crop&w=1600&q=80') 
              no-repeat center center;
  background-size: cover;
}

section.hero-fullscreen {
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.hero-content{text-align:center;color:#fff;text-shadow:2px 2px 5px rgba(0,0,0,0.7);}
.hero-content h2{font-size:3rem;margin-bottom:20px;}
.hero-content p{font-size:1.5rem;}
.hero-content .btn{
  display:inline-block;
  padding:15px 30px;
  background:#ff9900;
  color:#fff;
  border-radius:8px;
  text-decoration:none;
  font-size:1.2rem;
  margin-top:20px;
  transition:background 0.3s;
}
.hero-content .btn:hover{background:#ff4500;}

/* Grid e cards */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:20px;
  margin-top:20px;
  max-width:100%;
  padding:0 10px; /* evita overflow */
  margin:auto;
}
.card{
  background:#fff;
  border-radius:12px;
  box-shadow:0 2px 10px rgba(0,0,0,0.15);
  overflow:hidden;
  text-align:center;
  transition:transform 0.3s ease,box-shadow 0.3s ease;
}
.card:hover{
  transform:translateY(-5px);
  box-shadow:0 6px 20px rgba(0,0,0,0.3);
}
.card img{
  width:100%;
  height:auto;
  object-fit:contain; /* garante proporção e não corta */
  max-width:100%;
}
.card h3{margin:10px 0;}
.card p{font-size:1rem;color:#555;padding:0 10px;}
section{padding:50px 20px;max-width:1200px;margin:auto;}

/* Depoimentos */
.depoimentos-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:20px;
}
.depoimentos-grid blockquote{
  background:#ff9900;
  padding:20px;
  border-radius:12px;
  color:#fff;
  font-style:italic;
}

/* Formulário */
.form-contato{
  display:flex;
  flex-direction:column;
  gap:10px;
  max-width:500px;
  margin:auto;
}
.form-contato input,
.form-contato textarea{
  padding:15px;
  border:1px solid #ccc;
  border-radius:8px;
}
.form-contato input:focus,
.form-contato textarea:focus{
  border-color:#ff4500;
  outline:none;
}
.form-contato button{
  padding:15px;
  background:#ff0000;
  color:#fff;
  border:none;
  border-radius:8px;
  cursor:pointer;
  transition:background 0.3s;
}
.form-contato button:hover{background:#ff9900;}

/* Footer */
footer{background:#222;color:#fff;text-align:center;padding:20px;margin-top:30px;}

/* Responsividade */
@media (max-width: 1024px){
  .hero-content h2{font-size:2.5rem;}
  .hero-content p{font-size:1.2rem;}
  .depoimentos-grid{grid-template-columns:1fr 1fr;}
}

@media (max-width: 768px){
  .header-animado{
    flex-direction:column;
    padding:15px 20px;
  }
  .header-animado nav{
    display:flex;
    flex-direction:column;
    width:100%;
    margin-top:10px;
  }
  .header-animado nav a{margin:10px 0;}
  .hero-fullscreen{height:60vh; background-position:top;}
  .hero-content h2{font-size:1.8rem;}
  .hero-content p{font-size:1rem;}
  .grid{grid-template-columns:1fr; gap:15px;}
  .depoimentos-grid{grid-template-columns:1fr;}
  .card img{width:100%; height:auto; object-fit:contain;} /* ajusta totalmente para celular */
  .form-contato{max-width:100%; padding:0 10px;}
}
