/* style.css (refatorado – mesmo visual, menos repetição) */
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:wght@500;600;700;800&display=swap');

/* Reset */
*,*::before,*::after{box-sizing:border-box}

/* Variáveis */
:root{
  --color-black:#0F0F0F;
  --color-graphite:#1A1A1A;
  --color-gray:#2C2C2C;
  --color-gold:#C6A75E;
  --color-white:#F4F4F4;
  --font-main:"EB Garamond",serif;
}

/* Base / Tipografia */
body{
  margin:0;
  font-family:var(--font-main);
  color:var(--color-white);
  background:var(--color-black);
  line-height:1.7;
  letter-spacing:.3px;
  overflow-x:hidden;
  font-size:17px; /* mobile first */
}
h1,h2,h3,h4,h5{
  font-family:var(--font-main);
  margin:0 0 1rem;
  color:var(--color-white);
  font-weight:700;
  letter-spacing:.5px;
}
h1{font-size:2.2rem}
h2{font-size:2rem}
h3{font-size:1.5rem}
p{margin:0 0 1rem;font-size:1.2rem}

/* Links (sem underline no site todo) */
a{text-decoration:none}
a:hover{text-decoration:none}

/* Container */
.container{max-width:1200px;margin:0 auto;padding:0 20px;width:100%}

/* Header */
.site-header{
  position:fixed;top:0;width:100%;
  height:68px; /* mobile first */
  background:var(--color-black);
  z-index:1000;
  border-bottom:1px solid var(--color-graphite);
}
.header-container{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;
  gap:18px;
}
.logo{font-size:1.5rem;font-weight:700;flex-shrink:0}

.logo-wrap{
  width: 46px;          /* largura do “quadradinho” do logo */
  height: 46px;         /* altura */
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;     /* corta o que sobrar */
  border-radius: 6px;   /* opcional: arredondado */
}

.logo-img{
  width: 100%;
  height: 100%;
  object-fit: contain;  /* mantém proporção e encaixa */
  display: block;
}
/* Nav */
.main-nav{
  display:flex;align-items:center;flex:1 1 auto;justify-content:center;white-space:nowrap;
}
.main-nav ul{
  list-style:none;
  display:flex;
  gap:1.25rem;
  margin:0;padding:0;
}
.main-nav a{
  color:var(--color-white);
  font-weight:600;
  opacity:.9;
  transition:color .2s ease,opacity .2s ease;
}
.main-nav a:hover{color:var(--color-gold);opacity:1}

/* Hamburger */
.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  flex-shrink:0;
  z-index:1100;
}
.hamburger span{display:block;width:25px;height:3px;background:var(--color-white)}
@keyframes slideDown{from{max-height:0;opacity:0}to{max-height:500px;opacity:1}}

/* Botões */
.btn-outline{
  border:2px solid var(--color-gold);
  background:transparent;
  color:var(--color-gold);
  padding:.75rem 1.5rem;
  display:inline-block;
  transition:all .3s ease;
}
.btn-outline:hover{background:var(--color-gold);color:var(--color-black);transform:scale(1.05)}

.btn-cta{
  height:44px;
  padding:0 18px;
  border:1px solid rgba(198,167,94,.9);
  background:transparent;
  color:var(--color-gold);
  text-transform:uppercase;
  letter-spacing:.9px;
  font-weight:700;
  font-size:.95rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  white-space:nowrap;
  line-height:1;
  border-radius:2px;
  transition:background .2s ease,color .2s ease,transform .2s ease,border-color .2s ease;
}
.btn-cta:hover{background:var(--color-gold);color:var(--color-black);border-color:var(--color-gold);transform:translateY(-1px)}
.btn-cta::after{content:none!important}

/* Hero */
.hero-section{
  position:relative;
  padding-top:68px; /* compensa header */
  min-height:100vh;
  overflow:hidden;
  display:flex;
  align-items:center;
}
.video-container{position:absolute;inset:0;overflow:hidden;z-index:0}
.video-container video.video-bg{width:100%;height:100%;object-fit:cover}
.video-container iframe{position:absolute;inset:0;pointer-events:none}
.hero-section .overlay{position:absolute;inset:0;background:rgba(15,15,15,.7);z-index:1}

.hero-content{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  padding:3rem 16px; /* mobile first */
}
.hero-text{flex:1 1 500px;max-width:700px}

/* Seções (mobile first) */
.institutional-section,
.areas-section,
.differentials-section,
.team-section,
.blog-section,
.contact-section{padding:4.5rem 0}

.areas-section,.blog-section{background:var(--color-graphite)}
.areas-section{padding:4.5rem 0}

/* Institucional */
.mission-vision-values{display:flex;gap:2rem;flex-wrap:wrap}
.mvv-box{flex:1 1 300px;border-left:4px solid var(--color-gold);padding-left:1rem}
.years-experience{font-size:2rem;margin-top:2rem;font-weight:700}
.years-experience span{color:var(--color-gold);margin-right:.35rem}

/* Áreas */
.areas-grid{
  display:grid;
  gap:1.25rem;
  grid-template-columns:1fr; /* mobile */
  justify-items:center;
}
.area-card{
  background:var(--color-black);
  border:2px solid var(--color-gold);
  height:180px;
  width:100%;
  max-width:300px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:1rem;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.area-card h3{font-size:1.6rem;font-weight:600;line-height:1.3;margin:0}
.area-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.45)}
.area-card.active:hover{transform:none}

.area-card .card-content{
  position:absolute;inset:0;
  padding:1rem 1rem 1.1rem;
  background:linear-gradient(180deg,rgba(26,26,26,.98),rgba(26,26,26,.92));
  color:var(--color-white);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
  overflow-y:auto;
  text-align:left;
  font-size:.95rem;
}
.area-card.active{background:var(--color-graphite);box-shadow:0 10px 22px rgba(0,0,0,.55)}
.area-card.active .card-content{opacity:1;pointer-events:auto}

/* Conteúdo interno dos cards */
.area-card .card-content .content-header{
  font-family:inherit;
  font-weight:700;
  font-size:.85rem;
  letter-spacing:.8px;
  text-transform:uppercase;
  color:var(--color-gold);
  margin:.1rem 0 .75rem;
}
.area-card .card-content ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.area-card .card-content li{
  position:relative;
  padding-left:1.05rem;
  line-height:1.35;
  opacity:.95;
}
.area-card .card-content li::before{
  content:"";
  position:absolute;left:0;top:.55rem;
  width:.45rem;height:.45rem;border-radius:50%;
  background:var(--color-gold);
  box-shadow:0 0 0 3px rgba(198,167,94,.12);
}
.area-card .card-content::-webkit-scrollbar{width:8px}
.area-card .card-content::-webkit-scrollbar-thumb{background:rgba(198,167,94,.35);border-radius:10px}
.area-card .card-content::-webkit-scrollbar-track{background:rgba(255,255,255,.04)}

/* Diferenciais */
.differentials-list{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:2rem;
  margin:20px;
  padding:10px;
}
.differentials-list li{
  display:flex;
  align-items:flex-start;
  gap:14px;
  font-size:1.1rem;
  line-height:1.5;
  font-weight:500;
}
.differentials-list .icon{
  width:10px;height:10px;
  margin-top:8px;
  background:var(--color-gold);
  border-radius:50%;
  flex-shrink:0;
  box-shadow:0 0 0 6px rgba(198,167,94,.08);
}

/* Autoridade */
.authority-section{background:var(--color-gray);text-align:center;padding:4rem 0}
.authority-quote{font-size:1.5rem;font-style:italic;margin-bottom:1rem}

/* Equipe */
.team-grid{
  display:grid;
  grid-template-columns:1fr; /* mobile first */
  gap:2rem;
}
.team-member{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}
.team-member .photo{
  width:150px;height:150px;
  background:var(--color-graphite);
  border-radius:50%;
  margin:0 0 1rem;
  border:1px solid rgba(198,167,94,.25);
  background-size:cover;
  background-position:center 20%;
  background-repeat:no-repeat;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,filter .25s ease;
  will-change:transform;
}
.team-member .photo.p1{background-image:url("assets/p1.jpg")}
.team-member .photo.p2{background-image:url("assets/p2.jpg")}
.team-member .photo.p3{background-image:url("assets/p3.jpg")}
.team-member .photo.p4{background-image:url("assets/p4.jpg")}
.team-member .photo.p5{background-image:url("assets/p5.jpg")}
.team-member .photo.p6{background-image:url("assets/p6.jpg")}
.team-member .photo.p7{background-image:url("assets/p7.jpg")}
.team-member .photo.p8{background-image:url("assets/p8.jpg")}

.team-member:hover .photo{
  transform:translateY(-4px) scale(1.03);
  border-color:rgba(198,167,94,.75);
  box-shadow:0 16px 32px rgba(0,0,0,.55);
  filter:contrast(1.05) brightness(1.03);
}
.team-member h3{
  margin:0;
  min-height:3.2em;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  line-height:1.2;
  transition:transform .25s ease,color .25s ease;
}
.team-member:hover h3{transform:translateY(-1px);color:var(--color-gold)}
.team-member p{
  margin-top:.8rem;
  min-height:3.2em;
  text-align:center;
  line-height:1.35;
  opacity:.92;
}

/* Blog */
.blog-grid{
  display:grid;
  grid-template-columns:1fr; /* mobile first */
  gap:1.5rem;
}
.blog-card{
  background:var(--color-black);
  padding:2rem;
  border:1px solid var(--color-graphite);
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}
.blog-card:hover{transform:translateY(-2px);border-color:rgba(198,167,94,.45);box-shadow:0 10px 22px rgba(0,0,0,.45)}
.blog-card .read-more{color:var(--color-gold);font-weight:700}
.blog-card .read-more:hover{text-decoration:underline}

/* Contato */
.contact-form{display:grid;gap:1.5rem;max-width:600px;margin-bottom:2rem}
.form-group label{display:block;margin-bottom:.5rem}
.form-group input,.form-group textarea{
  width:100%;
  padding:.75rem;
  border:2px solid var(--color-gold);
  background:var(--color-black);
  color:var(--color-white);
}
.contact-form .btn-cta{width:100%;height:52px}
.contact-info p{margin:.5rem 0}

/* Footer */
.site-footer{
  background:#0b0b0b;
  padding:4rem 0;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-container{
  display:flex;
  flex-wrap:wrap;
  gap:2rem;
  justify-content:space-between;
}
.footer-links a,.footer-social a{
  color:rgba(244,244,244,.88);
  font-weight:600;
  margin:0 5px;
}
.footer-copy p{
  color:rgba(244,244,244,.72);
  font-size:.98rem;
  letter-spacing:.2px;
  margin:0 0 .5rem;
}
.footer-copy a{
  color:rgba(244,244,244,.82);
  font-weight:700;
  margin:0 5px;
}
.footer-links a:hover,.footer-social a:hover,.footer-copy a:hover{color:var(--color-gold)}

/* =========================
   Responsivo
========================= */

/* Nav + header (mobile) */
@media (max-width:992px){
  .site-header .btn-cta{display:none!important}
  .hamburger{display:flex!important}
  .main-nav{display:none}
  .main-nav.open{display:flex}

  .main-nav{
    position:absolute;
    top:68px;
    left:0;
    width:100%;
    background:rgba(15,15,15,.98);
    flex-direction:column;
    max-height:0;
    overflow:hidden;
    border-bottom:1px solid rgba(255,255,255,.06);
    padding:.5rem 0 1rem;
    z-index:1200;
  }
  .main-nav.open{animation:slideDown .3s forwards}
  .main-nav ul{
    width:100%;
    flex-direction:column;
    gap:.35rem;
    padding:.75rem 0 1rem;
    text-align:center;
  }
  .main-nav a{
    display:block;
    width:100%;
    padding:.95rem 1.2rem;
    text-align:center;
    font-size:1.05rem;
  }
}

/* Áreas grid */
@media (min-width:600px){.areas-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:992px){
  body{font-size:18px}
  h1{font-size:3.2rem}
  h2{font-size:2.6rem}
  h3{font-size:1.9rem}
  .site-header{height:80px}
  .hero-section{padding-top:80px}
  .hero-content{padding:4rem 20px}
  .institutional-section,.areas-section,.differentials-section,.team-section,.blog-section,.contact-section{padding:6rem 0}
  .areas-grid{grid-template-columns:repeat(3,1fr)}
}
@media (min-width:1200px){.areas-grid{grid-template-columns:repeat(6,1fr)}}

/* Team / Blog grid */
@media (min-width:700px){
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr);gap:2rem}
}
@media (min-width:1100px){
  .team-grid{grid-template-columns:repeat(4,1fr)}
  .blog-grid{grid-template-columns:repeat(3,1fr)}
}

/* Hero mobile */
@media (max-width:768px){
  .video-container video.video-bg{filter:contrast(1.05) brightness(.75)}
  .hero-content{flex-direction:column}
  .hero-text{text-align:center}
}
@media (max-width:576px){
  .hero-content{padding:2.5rem 16px;justify-content:center}
  .hero-text{max-width:520px;text-align:center}
  .hero-text h1{font-size:2.05rem;line-height:1.15;letter-spacing:.4px;margin-bottom:1rem}
  .hero-text p{font-size:1rem;line-height:1.55;opacity:.9;margin-bottom:1.35rem}
  .hero-buttons{display:flex;flex-direction:column;gap:.75rem;align-items:center}
  .hero-buttons .btn-outline{
    width:100%;
    max-width:320px;
    margin-right:0!important;
    height:48px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
  .contact-form{max-width:100%}
  .contact-form .btn-cta{height:54px}
}

/* Footer mobile */
@media (max-width:768px){
  .footer-container{flex-direction:column;align-items:center;text-align:center;gap:1.25rem}
}/* Espaçamento entre os botões do HERO (desktop/tablet) */
.hero-buttons{
  display:flex;
  gap: 14px;      /* aumenta o espaço entre eles */
  flex-wrap: wrap;
}

.hero-buttons .btn-outline{
  margin-right: 0; /* remove o margin antigo pra não somar */
}