/* ========================================
   AMARO STUDIO - PÁGINAS INTERNAS V2
   Sobre / Serviços / Portfolio / Blog / Contato
   ======================================== */

/* RESET / BASE PARA TODAS AS PAGINAS INTERNAS */
.page-sobre,
.page-servicos,
.page-portfolio,
.page-blog,
.page-contato{
  background:#050505;
  color:#fff;
  min-height:100vh;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}

.page-sobre *,
.page-servicos *,
.page-portfolio *,
.page-blog *,
.page-contato *{
  box-sizing:border-box;
}

/* HERO SECTIONS */
.sobre-hero,
.servicos-hero,
.portfolio-page-hero,
.blog-hero,
.contato-hero{
  position:relative;
  padding:140px 0 100px;
  overflow:hidden;
  text-align:center;
  background:linear-gradient(180deg,#050505 0%,#0a0a0a 100%);
}

.sobre-hero .bg-glow,
.servicos-hero .bg-glow,
.portfolio-page-hero .bg-glow,
.blog-hero .bg-glow,
.contato-hero .bg-glow{
  position:absolute;
  top:-20%;
  left:50%;
  transform:translateX(-50%);
  width:900px;
  height:600px;
  background:radial-gradient(ellipse,rgba(212,175,55,.15) 0%,transparent 70%);
  filter:blur(80px);
  pointer-events:none;
  z-index:0;
}

.page-sobre .container,
.page-servicos .container,
.page-portfolio .container,
.page-blog .container,
.page-contato .container{
  position:relative;
  z-index:2;
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
}

/* ELEMENTOS COMUNS */
.page-sobre .eyebrow-gold,
.page-servicos .eyebrow-gold,
.page-portfolio .eyebrow-gold,
.page-blog .eyebrow-gold,
.page-contato .eyebrow-gold{
  color:#d4af37;
  font-size:13px;
  letter-spacing:4px;
  font-weight:600;
  display:block;
  margin-bottom:24px;
  text-transform:uppercase;
}

.page-sobre .text-gold,
.page-servicos .text-gold,
.page-portfolio .text-gold,
.page-blog .text-gold,
.page-contato .text-gold{
  background:linear-gradient(135deg,#f5d97e 0%,#d4af37 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.page-sobre .hero-title,
.page-servicos .hero-title,
.page-portfolio .hero-title,
.page-blog .hero-title,
.page-contato .hero-title{
  font-size:clamp(40px,6vw,72px);
  line-height:1;
  font-weight:800;
  letter-spacing:-2px;
  margin:0 0 24px;
  color:#fff;
}

.page-sobre .hero-sub,
.page-servicos .hero-sub,
.page-portfolio .hero-sub,
.page-blog .hero-sub,
.page-contato .hero-sub{
  color:#999;
  font-size:18px;
  line-height:1.7;
  max-width:700px;
  margin:0 auto;
}

/* SEÇÃO HEAD CENTRALIZADA */
.section-head-center{
  text-align:center;
  margin-bottom:60px;
}
.section-head-center h2{
  font-size:clamp(32px,4vw,52px);
  font-weight:800;
  margin:0 0 16px;
  line-height:1.1;
  color:#fff;
}
.section-head-center p{
  color:#999;
  font-size:17px;
  max-width:600px;
  margin:0 auto;
}

/* ============================================
   PAGE SOBRE
   ============================================ */
.sobre-mvv{padding:100px 0;background:#050505}

.mvv-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}

.mvv-card{
  background:linear-gradient(180deg,#0a0a0a,#050505);
  border:1px solid rgba(212,175,55,.15);
  border-radius:20px;
  padding:40px 32px;
  transition:all .4s ease;
}

.mvv-card:hover{
  border-color:rgba(212,175,55,.5);
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(212,175,55,.15);
}

.mvv-icon{
  width:70px;
  height:70px;
  background:rgba(212,175,55,.1);
  border:1px solid rgba(212,175,55,.3);
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#d4af37;
  margin-bottom:24px;
}

.mvv-card h3{
  color:#fff;
  font-size:24px;
  font-weight:800;
  margin:0 0 14px;
}

.mvv-card p{
  color:#999;
  line-height:1.7;
  margin:0;
  font-size:15px;
}

/* HISTÓRIA */
.sobre-historia{
  padding:100px 0;
  background:#080808;
  border-top:1px solid rgba(212,175,55,.08);
}

.historia-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:60px;
  align-items:center;
}

.historia-text h2{
  font-size:clamp(32px,4vw,52px);
  font-weight:800;
  margin:0 0 24px;
  line-height:1.1;
  color:#fff;
}

.historia-text p{
  color:#999;
  font-size:16px;
  line-height:1.8;
  margin:0 0 18px;
}

.historia-text strong{color:#d4af37}

.historia-stats{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  margin-top:40px;
  padding-top:30px;
  border-top:1px solid rgba(212,175,55,.15);
}

.hs-num{
  display:block;
  font-size:42px;
  font-weight:800;
  color:#d4af37;
  line-height:1;
  margin-bottom:8px;
}

.hs-label{
  display:block;
  color:#888;
  font-size:13px;
  letter-spacing:1.5px;
  text-transform:uppercase;
}

.historia-visual{
  position:relative;
  aspect-ratio:1;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:400px;
}

.visual-card{
  width:200px;
  height:200px;
  background:linear-gradient(135deg,#d4af37 0%,#b8941f 100%);
  border-radius:50%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#000;
  z-index:2;
  box-shadow:0 30px 80px rgba(212,175,55,.4);
  position:relative;
}

.card-num{
  display:block;
  font-size:48px;
  font-weight:800;
  line-height:1;
}

.card-label{
  display:block;
  font-size:11px;
  letter-spacing:2px;
  font-weight:600;
  text-transform:uppercase;
  margin-top:8px;
}

.visual-orbit{
  position:absolute;
  inset:0;
  border:1px dashed rgba(212,175,55,.3);
  border-radius:50%;
  animation:orbit 30s linear infinite;
}

@keyframes orbit{
  to{transform:rotate(360deg)}
}

/* DIFERENCIAIS */
.sobre-diferenciais{padding:100px 0;background:#050505}

.dif-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}

.dif-item{
  background:linear-gradient(180deg,rgba(212,175,55,.04),transparent);
  border:1px solid rgba(212,175,55,.1);
  border-radius:16px;
  padding:32px;
  transition:all .4s ease;
}

.dif-item:hover{
  border-color:rgba(212,175,55,.4);
  transform:translateY(-6px);
}

.dif-num{
  display:inline-block;
  color:#d4af37;
  font-size:13px;
  font-weight:700;
  letter-spacing:3px;
  margin-bottom:16px;
  padding:6px 14px;
  border:1px solid rgba(212,175,55,.3);
  border-radius:30px;
}

.dif-item h4{
  color:#fff;
  font-size:20px;
  font-weight:700;
  margin:0 0 12px;
}

.dif-item p{
  color:#999;
  font-size:15px;
  line-height:1.6;
  margin:0;
}

/* CTA */
.sobre-cta{padding:100px 0;background:#050505}

.cta-box{
  background:linear-gradient(135deg,rgba(212,175,55,.08) 0%,transparent 100%);
  border:1px solid rgba(212,175,55,.3);
  border-radius:30px;
  padding:80px 40px;
  text-align:center;
}

.cta-box h2{
  font-size:clamp(32px,4vw,56px);
  font-weight:800;
  margin:0 0 20px;
  line-height:1.1;
  color:#fff;
}

.cta-box p{
  color:#999;
  font-size:18px;
  margin:0 0 36px;
}

.btn-gold-large{
  display:inline-flex;
  align-items:center;
  gap:12px;
  background:linear-gradient(135deg,#d4af37 0%,#b8941f 100%);
  color:#000;
  padding:18px 40px;
  border-radius:60px;
  font-weight:800;
  font-size:14px;
  letter-spacing:2px;
  text-decoration:none;
  text-transform:uppercase;
  transition:all .3s ease;
  box-shadow:0 10px 40px rgba(212,175,55,.3);
  border:none;
  cursor:pointer;
}

.btn-gold-large:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 50px rgba(212,175,55,.5);
  gap:18px;
}

/* ============================================
   PAGE SERVIÇOS
   ============================================ */
.servicos-lista{padding:80px 0;background:#050505}

.servicos-lista .container{
  display:flex;
  flex-direction:column;
  gap:30px;
}

.servico-card{
  display:grid;
  grid-template-columns:80px 100px 1fr;
  gap:30px;
  background:linear-gradient(135deg,#0a0a0a,#050505);
  border:1px solid rgba(212,175,55,.1);
  border-radius:24px;
  padding:50px;
  transition:all .5s ease;
  align-items:start;
}

.servico-card:hover{
  border-color:rgba(212,175,55,.4);
  transform:translateY(-4px);
  box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 60px rgba(212,175,55,.1);
}

.servico-num{
  font-size:48px;
  font-weight:800;
  color:rgba(212,175,55,.3);
  line-height:1;
}

.servico-icon{
  width:80px;
  height:80px;
  background:rgba(212,175,55,.1);
  border:1px solid rgba(212,175,55,.3);
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#d4af37;
}

.servico-content h3{
  color:#fff;
  font-size:32px;
  font-weight:800;
  margin:0 0 8px;
  line-height:1.2;
}

.servico-sub{
  display:block;
  color:#d4af37;
  font-size:13px;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:16px;
  font-weight:600;
}

.servico-content p{
  color:#999;
  line-height:1.7;
  font-size:16px;
  margin:0 0 24px;
}

.servico-features{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
  list-style:none !important;
  padding:0 !important;
  margin:0 0 28px !important;
}

.servico-features li{
  display:flex;
  align-items:center;
  gap:10px;
  color:#bbb;
  font-size:14px;
  list-style:none !important;
}

.servico-features li::before{
  content:none !important;
}

.servico-features li svg{
  color:#d4af37;
  flex-shrink:0;
  width:16px;
  height:16px;
}

.servico-cta{
  display:inline-block;
  color:#d4af37;
  font-weight:700;
  font-size:13px;
  letter-spacing:2px;
  text-decoration:none;
  border-bottom:1px solid #d4af37;
  padding-bottom:4px;
  transition:all .3s ease;
}

.servico-cta:hover{
  color:#fff;
  border-color:#fff;
}

/* PROCESSO */
.servicos-processo{padding:100px 0;background:#080808}

.processo-steps{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:20px;
  position:relative;
}

.processo-steps::before{
  content:"";
  position:absolute;
  top:30px;
  left:5%;
  right:5%;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,175,55,.3),transparent);
  z-index:0;
}

.step{
  background:#0a0a0a;
  border:1px solid rgba(212,175,55,.15);
  border-radius:20px;
  padding:30px 20px;
  text-align:center;
  position:relative;
  z-index:1;
  transition:all .3s ease;
}

.step:hover{
  border-color:rgba(212,175,55,.5);
  transform:translateY(-4px);
}

.step-num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:60px;
  height:60px;
  background:linear-gradient(135deg,#d4af37,#b8941f);
  color:#000;
  border-radius:50%;
  font-size:18px;
  font-weight:800;
  margin-bottom:18px;
}

.step h4{
  color:#fff;
  font-size:18px;
  font-weight:700;
  margin:0 0 10px;
}

.step p{
  color:#999;
  font-size:14px;
  line-height:1.6;
  margin:0;
}

/* ============================================
   PAGE BLOG
   ============================================ */
.blog-featured{padding:60px 0;background:#080808}

.featured-post{
  background:#0a0a0a;
  border:1px solid rgba(212,175,55,.2);
  border-radius:24px;
  overflow:hidden;
  transition:all .4s ease;
}

.featured-post:hover{
  transform:translateY(-6px);
  box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 60px rgba(212,175,55,.15);
  border-color:rgba(212,175,55,.5);
}

.featured-link{
  display:grid;
  grid-template-columns:1fr 1fr;
  text-decoration:none;
  color:inherit;
}

.featured-image{
  position:relative;
  aspect-ratio:16/10;
  overflow:hidden;
}

.featured-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s ease;
  display:block;
}

.featured-post:hover .featured-image img{
  transform:scale(1.06);
}

.featured-badge{
  position:absolute;
  top:20px;
  left:20px;
  background:#d4af37;
  color:#000;
  padding:8px 16px;
  border-radius:30px;
  font-size:11px;
  font-weight:800;
  letter-spacing:2px;
  z-index:2;
}

.featured-content{
  padding:50px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.post-date{
  color:#d4af37;
  font-size:13px;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:14px;
  display:block;
  font-weight:600;
}

.featured-content h2{
  color:#fff;
  font-size:32px;
  font-weight:800;
  margin:0 0 16px;
  line-height:1.2;
}

.featured-content p{
  color:#999;
  font-size:16px;
  line-height:1.7;
  margin:0 0 24px;
}

.read-more{
  color:#d4af37;
  font-weight:700;
  font-size:13px;
  letter-spacing:2px;
}

.blog-grid-section{padding:80px 0;background:#050505}

.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}

.blog-card{
  background:#0a0a0a;
  border:1px solid rgba(212,175,55,.1);
  border-radius:20px;
  overflow:hidden;
  transition:all .4s ease;
}

.blog-card:hover{
  transform:translateY(-6px);
  border-color:rgba(212,175,55,.4);
}

.blog-card a{
  text-decoration:none;
  color:inherit;
  display:block;
}

.card-image{
  aspect-ratio:16/10;
  overflow:hidden;
  position:relative;
}

.card-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s ease;
  display:block;
}

.blog-card:hover .card-image img{
  transform:scale(1.06);
}

.post-placeholder{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,rgba(212,175,55,.1),#0a0a0a);
  color:#d4af37;
  font-weight:700;
  padding:20px;
  text-align:center;
}

.card-content{padding:28px}

.card-content h3{
  color:#fff;
  font-size:20px;
  font-weight:700;
  margin:8px 0 12px;
  line-height:1.3;
}

.card-content p{
  color:#999;
  font-size:14px;
  line-height:1.6;
  margin:0 0 18px;
}

.blog-empty{
  text-align:center;
  padding:80px 20px;
}

.blog-empty h3{
  color:#fff;
  font-size:28px;
  margin:0 0 12px;
}

.blog-empty p{color:#999}

/* NEWSLETTER */
.blog-newsletter{padding:80px 0;background:#080808}

.blog-newsletter .container{max-width:800px}

.news-box{
  background:linear-gradient(135deg,rgba(212,175,55,.08),transparent);
  border:1px solid rgba(212,175,55,.3);
  border-radius:24px;
  padding:60px 40px;
  text-align:center;
}

.news-box h2{
  font-size:36px;
  font-weight:800;
  margin:0 0 14px;
  color:#fff;
}

.news-box p{
  color:#999;
  margin:0 0 30px;
}

.news-form{
  display:flex;
  gap:10px;
  max-width:500px;
  margin:0 auto;
}

.news-form input{
  flex:1;
  background:#000;
  border:1px solid rgba(212,175,55,.3);
  color:#fff;
  padding:16px 20px;
  border-radius:50px;
  font-size:15px;
  font-family:inherit;
}

.news-form input:focus{
  outline:none;
  border-color:#d4af37;
}

.news-form button{
  background:linear-gradient(135deg,#d4af37,#b8941f);
  color:#000;
  border:none;
  padding:16px 28px;
  border-radius:50px;
  font-weight:800;
  font-size:13px;
  letter-spacing:2px;
  cursor:pointer;
  transition:all .3s ease;
}

.news-form button:hover{
  transform:translateY(-2px);
}

/* ============================================
   PAGE CONTATO
   ============================================ */
.contato-grid-section{padding:80px 0;background:#050505}

.contato-grid-section .container{max-width:1300px}

.contato-grid{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:50px;
  align-items:start;
}

/* INFO LATERAL */
.contato-info h2{
  font-size:36px;
  font-weight:800;
  margin:0 0 14px;
  color:#fff;
}

.info-desc{
  color:#999;
  font-size:16px;
  line-height:1.6;
  margin:0 0 30px;
}

.info-card{
  display:flex;
  align-items:center;
  gap:18px;
  background:#0a0a0a;
  border:1px solid rgba(212,175,55,.1);
  border-radius:16px;
  padding:20px 24px;
  margin-bottom:14px;
  text-decoration:none;
  color:inherit;
  transition:all .3s ease;
}

.info-card:hover{
  border-color:rgba(212,175,55,.4);
  transform:translateX(4px);
}

.info-icon{
  width:50px;
  height:50px;
  background:rgba(212,175,55,.1);
  border:1px solid rgba(212,175,55,.3);
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#d4af37;
  flex-shrink:0;
}

.info-label{
  display:block;
  color:#d4af37;
  font-size:11px;
  letter-spacing:2px;
  font-weight:700;
  text-transform:uppercase;
  margin-bottom:4px;
}

.info-value{
  display:block;
  color:#fff;
  font-size:15px;
  font-weight:600;
}

.info-social{
  display:flex;
  gap:16px;
  align-items:center;
  margin-top:30px;
  padding-top:24px;
  border-top:1px solid rgba(212,175,55,.15);
}

.info-social span{color:#999;font-size:14px}

.info-social a{
  color:#d4af37;
  text-decoration:none;
  font-size:14px;
  font-weight:600;
}

.info-social a:hover{color:#fff}

/* FORMULÁRIO */
.contato-form-wrap{
  background:linear-gradient(180deg,#0a0a0a,#050505);
  border:1px solid rgba(212,175,55,.2);
  border-radius:24px;
  padding:48px;
}

.contato-form h3{
  color:#fff;
  font-size:28px;
  font-weight:800;
  margin:0 0 8px;
}

.form-desc{
  color:#999;
  font-size:15px;
  margin:0 0 30px;
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:18px;
}

.form-field{margin-bottom:18px}

.form-field label{
  display:block;
  color:#d4af37;
  font-size:12px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:8px;
}

.form-field input,
.form-field select,
.form-field textarea{
  width:100%;
  background:#000;
  border:1px solid rgba(212,175,55,.2);
  color:#fff;
  padding:14px 18px;
  border-radius:12px;
  font-size:15px;
  font-family:inherit;
  transition:all .3s ease;
  display:block;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;
  border-color:#d4af37;
  box-shadow:0 0 0 3px rgba(212,175,55,.1);
}

.form-field textarea{
  resize:vertical;
  min-height:120px;
}

.form-submit{
  display:inline-flex;
  align-items:center;
  gap:12px;
  background:linear-gradient(135deg,#d4af37,#b8941f);
  color:#000;
  border:none;
  padding:18px 36px;
  border-radius:60px;
  font-weight:800;
  font-size:13px;
  letter-spacing:2px;
  cursor:pointer;
  transition:all .3s ease;
  width:100%;
  justify-content:center;
  text-transform:uppercase;
  margin-top:8px;
  font-family:inherit;
}

.form-submit:hover{
  transform:translateY(-2px);
  box-shadow:0 15px 40px rgba(212,175,55,.4);
}

.form-disclaimer{
  text-align:center;
  color:#666;
  font-size:13px;
  margin-top:18px;
}

/* WHATSAPP CTA */
.contato-whatsapp-cta{padding:80px 0;background:#080808}

.contato-whatsapp-cta .container{max-width:1000px}

.wcta-box{
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  border-radius:30px;
  padding:60px 40px;
  text-align:center;
  position:relative;
  overflow:hidden;
}

.wcta-box h2{
  color:#fff;
  font-size:36px;
  font-weight:800;
  margin:0 0 12px;
}

.wcta-box p{
  color:rgba(255,255,255,.9);
  margin:0 0 28px;
  font-size:17px;
}

.btn-whatsapp{
  display:inline-flex;
  align-items:center;
  gap:12px;
  background:#fff;
  color:#128C7E;
  padding:18px 36px;
  border-radius:60px;
  font-weight:800;
  font-size:14px;
  letter-spacing:2px;
  text-decoration:none;
  transition:all .3s ease;
}

.btn-whatsapp:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 40px rgba(0,0,0,.3);
}

/* ============================================
   RESPONSIVO
   ============================================ */
@media(max-width:1024px){
  .mvv-grid,
  .dif-grid,
  .blog-grid{
    grid-template-columns:repeat(2,1fr);
  }
  .historia-grid,
  .featured-link,
  .contato-grid{
    grid-template-columns:1fr;
    gap:40px;
  }
  .servico-card{
    grid-template-columns:60px 60px 1fr;
    padding:32px;
    gap:20px;
  }
  .processo-steps{
    grid-template-columns:repeat(3,1fr);
  }
  .processo-steps::before{display:none}
}

@media(max-width:768px){
  .sobre-hero,
  .servicos-hero,
  .portfolio-page-hero,
  .blog-hero,
  .contato-hero{
    padding:100px 0 50px;
  }
  .mvv-grid,
  .dif-grid,
  .blog-grid,
  .processo-steps,
  .servico-features{
    grid-template-columns:1fr;
  }
  .historia-stats{grid-template-columns:1fr 1fr}
  .servico-card{
    grid-template-columns:1fr;
    text-align:center;
    padding:32px 24px;
  }
  .servico-icon{margin:0 auto}
  .form-row{grid-template-columns:1fr}
  .contato-form-wrap{padding:30px 24px}
  .news-form{flex-direction:column}
  .news-form button{width:100%}
  .featured-content{padding:30px}
  .visual-card{width:140px;height:140px}
  .card-num{font-size:32px}
  .cta-box,.wcta-box{padding:50px 24px}
  .cta-box h2,.wcta-box h2{font-size:28px}
  .historia-visual{min-height:280px}
}