/* =============================== BASE / RESET / VARIÁVEIS =============================== */
body{box-sizing:border-box}
:root{
  --sage-dark:#37362F;--sage-medium:#766756;--sage-light:#f5f3f0;--sage-accent:#766756;
  --warm-white:#fdfbf7;--charcoal:#37362F;--gold:#BFB4A6;--soft-gray:#f7f5f2;
  --beige-dark:#6B6559;--beige-medium:#8B8575;--beige-light:#A19F91;
  --dark-sage:var(--sage-dark);--dark-brown:var(--sage-medium);--primary:var(--gold)
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;width:100%}
body{font-family:'Outfit',sans-serif;background:var(--warm-white);color:var(--charcoal);line-height:1.7;overflow-x:hidden}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:600;line-height:1.3}

/* =============================== HERO =============================== */
.hero{
  text-align:center;padding:120px 5% 100px;
  background:linear-gradient(180deg,var(--sage-light) 0%,var(--warm-white) 100%);
  position:relative;overflow:hidden;background-attachment:fixed
}
.hero::before{
  content:'';position:absolute;top:-50%;right:-10%;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(107,157,136,.45) 0%,transparent 70%);
  animation:float 20s ease-in-out infinite
}
.hero::after{
  content:'';position:absolute;bottom:-30%;left:-5%;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(191,180,166,.38) 0%,transparent 70%);
  animation:float 25s ease-in-out infinite 2s
}
.hero h1{
  color:var(--sage-dark);font-size:56px;max-width:900px;margin:0 auto 24px;
  position:relative;z-index:1;animation:fadeInUp .8s ease
}
.hero p{
  font-size:20px;color:var(--sage-medium);margin-bottom:40px;font-weight:300;
  position:relative;z-index:1;animation:fadeInUp .8s ease .2s backwards
}

/* =============================== BOTÕES =============================== */
.btn-primary{
  background:#37362F;color:#fff;padding:18px 40px;border-radius:50px;text-decoration:none;display:inline-block;
  font-weight:500;font-size:16px;box-shadow:0 8px 25px rgba(55,54,47,.25);
  transition:all .4s ease;position:relative;z-index:1;animation:fadeInUp .8s ease .4s backwards;overflow:hidden
}
.btn-primary::before{
  content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;
  background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s
}
.btn-primary:active::before{width:300px;height:300px}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 35px rgba(55,54,47,.35);background:#766756}

/* =============================== SOBRE =============================== */
.sobre{padding:100px 5%;display:flex;flex-direction:column;align-items:center;background:var(--warm-white)}
.sobre-card{
  background:#fff;max-width:1100px;width:100%;display:flex;gap:50px;padding:50px;border-radius:24px;
  box-shadow:0 20px 60px rgba(0,0,0,.08);margin-bottom:60px;transition:transform .4s ease;
  opacity:0;animation:fadeInUp .8s ease forwards
}
.sobre-card:hover{transform:translateY(-5px)}
.sobre img{
  width:280px;height:350px;object-fit:cover;border-radius:20px;box-shadow:0 15px 40px rgba(45,90,74,.2)
}
.sobre-texto h2{color:var(--sage-dark);font-size:38px;margin-bottom:8px}
.sobre-texto h3{
  color:var(--sage-accent);font-size:20px;font-weight:400;margin-bottom:24px;
  font-family:'Outfit',sans-serif
}
.sobre-texto p{color:var(--charcoal);margin-bottom:18px;font-size:16px;line-height:1.8}

/* =============================== TRUST CARDS =============================== */
.trust-cards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:20px;max-width:1100px;width:100%
}
.trust-card{
  background:linear-gradient(135deg,var(--sage-light) 0%,#f0f7f3 100%);
  padding:24px;border-radius:16px;font-size:15px;font-weight:500;color:var(--sage-dark);
  box-shadow:0 4px 15px rgba(45,90,74,.08);transition:all .3s ease;
  border:1px solid rgba(107,157,136,.15);opacity:0;animation:fadeInUp .8s ease .2s forwards
}
.trust-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px rgba(45,90,74,.15)}

/* =============================== SERVIÇOS =============================== */
.servicos{padding:100px 5%;text-align:center;background:var(--warm-white)}
.servicos h2{
  color:var(--sage-dark);font-size:48px;margin-bottom:60px;position:relative;display:inline-block
}
.servicos h2::after{
  content:'';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);
  width:0;height:3px;background:var(--gold);border-radius:10px;animation:expandWidth .8s ease forwards
}
.cards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:30px;max-width:1200px;margin:0 auto
}
.card{
  background:#BFB4A6;padding:40px 30px;border-radius:20px;
  box-shadow:0 10px 35px rgba(191,180,166,.35);
  transition:all .5s cubic-bezier(.23,1,.320,1);
  text-align:left;opacity:0;transform:translateY(40px);border:1px solid rgba(255,255,255,.35)
}
.card.reveal-active{
  opacity:1;animation:cardRevealAnimation .8s cubic-bezier(.23,1,.320,1) forwards
}
.card:hover{transform:translateY(-12px);box-shadow:0 30px 80px rgba(0,0,0,.2)}
.card h3{color:var(--sage-dark);font-size:24px;margin-bottom:16px}
.card p{color:var(--charcoal);font-size:15px;line-height:1.8}

/* =============================== CONTATO =============================== */
.contato{padding:100px 5%;text-align:center;background:var(--warm-white)}
.contato h2{
  color:var(--sage-dark);font-size:48px;margin-bottom:16px;position:relative;display:inline-block
}
.contato h2::after{
  content:'';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);
  width:0;height:3px;background:var(--gold);border-radius:10px;animation:expandWidth .8s ease forwards
}
.contato-subtitle{color:var(--sage-medium);font-size:18px;margin-bottom:60px;font-weight:300}
.contato-container{
  max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;
  gap:60px;align-items:start
}
.contato-form{
  background:#fff;padding:50px;border-radius:24px;box-shadow:0 20px 60px rgba(0,0,0,.08);
  text-align:left;opacity:0;animation:fadeInUp .8s ease forwards
}
.form-group{margin-bottom:24px}
.form-group label{
  display:block;color:var(--sage-dark,#37362F);font-weight:500;margin-bottom:8px;font-size:15px
}
.form-group input,.form-group textarea{
  width:100%;padding:14px 18px;border:2px solid var(--sage-light);border-radius:12px;
  font-family:'Outfit',sans-serif;font-size:15px;transition:all .3s ease;background:var(--soft-gray)
}
.form-group input:focus,.form-group textarea:focus{
  outline:none;border-color:var(--sage-accent);background:#fff;box-shadow:0 0 0 4px rgba(107,157,136,.1)
}
.form-group textarea{resize:vertical;min-height:120px}
.btn-submit{
  width:100%;background:#37362F;color:#fff;padding:16px;border:none;border-radius:50px;
  font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:'Outfit',sans-serif;
  box-shadow:0 8px 25px rgba(55,54,47,.25);position:relative;overflow:hidden
}
.btn-submit::before{
  content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;
  background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s
}
.btn-submit:active::before{width:300px;height:300px}
.btn-submit:hover{background:#766756;transform:translateY(-2px);box-shadow:0 12px 35px rgba(55,54,47,.35)}
.btn-submit:active{transform:translateY(0)}
.form-message{margin-top:20px;padding:14px;border-radius:12px;font-size:14px;font-weight:500;text-align:center;display:none}
.form-message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb;display:block}
.form-message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;display:block}

.contato-info{
  background:linear-gradient(135deg,#37362F 0%,#4a4941 100%);padding:50px 40px;border-radius:24px;color:#fff;
  text-align:left;box-shadow:0 20px 60px rgba(55,54,47,.4);border:2px solid rgba(166,153,134,.3);
  opacity:0;animation:fadeInUp .8s ease .2s forwards
}
.contato-info h3{font-size:32px;margin-bottom:40px;color:#fff;font-weight:700}
.info-item{display:flex;gap:20px;margin-bottom:32px;align-items:start}
.info-item:last-child{margin-bottom:0}
.info-item strong{display:block;font-size:16px;margin-bottom:6px;color:#D4AF9E;font-weight:700}
.info-item p{font-size:15px;color:#f5f3f0;line-height:1.6;font-weight:300}

/* =============================== FOOTER =============================== */
.footer{
  background:linear-gradient(135deg,var(--dark-sage) 0%,var(--dark-brown) 100%);
  color:var(--sage-light);text-align:center;padding:40px 5% 30px;font-size:14px;font-weight:300;
  letter-spacing:.5px;position:relative;overflow:hidden
}
.footer::before{
  content:'';position:absolute;top:-40%;right:-10%;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(191,180,166,.35) 0%,transparent 70%);
  animation:float 22s ease-in-out infinite;z-index:0
}
.footer::after{
  content:'';position:absolute;bottom:-20%;left:-8%;width:350px;height:350px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,175,158,.28) 0%,transparent 70%);
  animation:float 28s ease-in-out infinite 1s;z-index:0
}
.social-links{display:flex;justify-content:center;gap:20px;margin-bottom:20px;position:relative;z-index:1}
.social-links a{
  width:45px;height:45px;background:rgba(255,255,255,.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:all .3s ease;
  backdrop-filter:blur(10px);position:relative;overflow:hidden
}
.social-links a::before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:var(--gold);transition:left .3s ease;z-index:-1
}
.social-links a:hover::before{left:0}
.social-links a:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(201,169,110,.4)}
.social-links img{width:22px;height:22px;filter:brightness(0) invert(1);transition:filter .3s ease}
.social-links a:hover img{filter:brightness(0) invert(1)}

/* =============================== WHATSAPP FLOAT =============================== */
.whatsapp-float{
  position:fixed;bottom:30px;right:30px;background:#25d366;width:65px;height:65px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;box-shadow:0 10px 35px rgba(37,211,102,.4);
  animation:pulse 2.5s infinite;z-index:999;transition:all .3s ease;cursor:pointer
}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 15px 45px rgba(37,211,102,.5)}
.whatsapp-float img{width:35px}
.whatsapp-tooltip{
  position:absolute;right:80px;background:#fff;color:var(--charcoal);padding:12px 18px;border-radius:12px;
  font-size:14px;box-shadow:0 8px 25px rgba(0,0,0,.15);white-space:nowrap;opacity:0;
  transform:translateY(10px);transition:all .4s ease;font-weight:500
}
.whatsapp-tooltip.show{opacity:1;transform:translateY(0)}

/* =============================== CAROUSEL =============================== */
.carousel-section{
  padding:40px 5%;background:linear-gradient(135deg,#C9D6CF 0%,#BFCFC6 100%);
  position:relative;overflow:hidden;min-height:320px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;transition:background .8s ease
}
.carousel-section.tab-0,.carousel-section.tab-1{background:linear-gradient(135deg,rgba(161,159,145,.9),rgba(161,159,145,.9))}
.carousel-section.tab-2,.carousel-section.tab-3{background:linear-gradient(135deg,rgba(161,159,145,.85),rgba(161,159,145,.85))}
.carousel-section::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 50%,rgba(255,255,255,.05) 0%,transparent 50%),
    radial-gradient(circle at 80% 80%,rgba(255,255,255,.05) 0%,transparent 50%);
  pointer-events:none;z-index:1
}
.carousel-tabs{display:flex;gap:12px;justify-content:center;margin-bottom:40px;flex-wrap:wrap;position:relative;z-index:3}
.tab-button{
  background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.3);color:#fff;
  padding:12px 24px;border-radius:50px;cursor:pointer;font-size:14px;font-weight:500;
  font-family:'Outfit',sans-serif;transition:all .3s ease;backdrop-filter:blur(10px)
}
.tab-button:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
.tab-button.active{
  background:#37362F;color:#fff;border-color:#37362F;box-shadow:0 8px 25px rgba(55,54,47,.3);font-weight:600
}
.carousel-container{position:relative;z-index:2;text-align:center;max-width:900px;width:100%}
.carousel-text h2{
  font-family:'Cormorant Garamond',serif;font-size:42px;color:#fff;margin-bottom:40px;line-height:1.3;
  font-weight:600;animation:carouselFade .8s ease;min-height:120px;display:flex;align-items:center;justify-content:center
}
.carousel-dots{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.dot{
  width:16px;height:16px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;
  transition:all .3s ease;border:2px solid transparent
}
.dot:hover{background:rgba(255,255,255,.6);transform:scale(1.15)}
.dot.active{background:#fff;box-shadow:0 0 15px rgba(255,255,255,.5);transform:scale(1.2)}

/* =============================== LOADING =============================== */
.loading-screen{
  position:fixed;inset:0;background:linear-gradient(135deg,var(--dark-sage) 0%,var(--dark-brown) 50%,var(--primary) 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;
  transition:opacity .8s ease,visibility .8s ease
}
.loading-screen.hidden{opacity:0;visibility:hidden}
.loading-logo{
  font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:700;color:#fff;margin-bottom:30px;
  opacity:0;animation:fadeInScale 1s ease forwards
}
.loading-text{
  font-family:'Outfit',sans-serif;font-size:16px;color:var(--sage-light);font-weight:300;letter-spacing:2px;
  opacity:0;animation:fadeInScale 1s ease .3s forwards
}
.loading-spinner{
  margin-top:40px;width:60px;height:60px;border:4px solid rgba(255,255,255,.2);border-top-color:var(--gold);
  border-radius:50%;opacity:0;animation:fadeInScale 1s ease .6s forwards,spin 1s linear .6s infinite
}
body.loading{overflow:hidden}
.page-content{opacity:0;animation:pageReveal 1s ease 1.5s forwards}
body.loaded .page-content{opacity:1}

/* =============================== HEADER / MENU =============================== */
.header{
  background:linear-gradient(135deg,var(--sage-dark) 0%,var(--sage-medium) 100%);
  padding:24px 5%;display:flex;justify-content:space-between;align-items:center;
  box-shadow:0 4px 20px rgba(45,90,74,.15);position:sticky;top:0;z-index:100;backdrop-filter:blur(10px)
}
.logo strong{
  color:#fff;font-size:22px;font-family:'Outfit',sans-serif;letter-spacing:.8px;display:block;font-weight:500
}
header nav{display:flex;align-items:center;gap:32px}
header nav a{
  color:#fff;text-decoration:none;font-weight:400;font-size:15px;transition:all .3s ease;position:relative
}
header nav a:not(.btn-whatsapp):hover{color:var(--beige-light)}
header nav a:not(.btn-whatsapp)::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--beige-light);transition:width .3s ease
}
header nav a:not(.btn-whatsapp):hover::after{width:100%}
.btn-whatsapp{
  background:#37362F;padding:12px 24px;border-radius:50px;font-weight:500;box-shadow:0 4px 15px rgba(55,54,47,.3);
  transition:all .3s ease;color:#fff
}
.btn-whatsapp:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(55,54,47,.4);background:#766756}

/* WhatsApp dentro do card "Informações de Contato" */
.whatsapp-link{
  color:var(--sage-light);text-decoration:none;display:inline-flex;align-items:center;gap:10px;transition:all .3s ease
}
.whatsapp-link:hover{opacity:.9;transform:translateX(2px)}
.contato-info .whatsapp-link img{
  width:18px;height:18px;max-width:18px;flex:0 0 auto;display:block;filter:brightness(0) invert(1)
}

/* =============================== KEYFRAMES =============================== */
@keyframes expandWidth{to{width:80px}}
@keyframes cardRevealAnimation{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.6)}70%{box-shadow:0 0 0 20px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{
  0%,100%{transform:translateY(0) translateX(0)}
  25%{transform:translateY(-20px) translateX(15px)}
  50%{transform:translateY(-40px) translateX(-10px)}
  75%{transform:translateY(-15px) translateX(25px)}
}
@keyframes carouselFade{0%{opacity:0;transform:translateY(20px)}100%{opacity:1;transform:translateY(0)}}
@keyframes fadeInScale{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pageReveal{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* =============================== RESPONSIVO =============================== */
@media (max-width:968px){.contato-container{grid-template-columns:1fr;gap:40px}}
@media (max-width:768px){
  .carousel-section{padding:50px 5%;min-height:450px}
  .carousel-text h2{font-size:32px;margin-bottom:30px;min-height:100px}
  .dot{width:14px;height:14px}
  .carousel-tabs{margin-bottom:30px;gap:8px}
  .tab-button{padding:10px 16px;font-size:12px}
  .header{flex-direction:column;gap:20px;padding:20px 5%}
  nav{flex-wrap:wrap;justify-content:center;gap:16px}
  .hero h1{font-size:36px}
  .hero p{font-size:18px}
  .sobre-card{flex-direction:column;padding:30px;gap:30px}
  .sobre img{width:100%;height:auto}
  .sobre-texto h2{font-size:32px}
  .servicos h2,.contato h2{font-size:36px}
  .cards,.trust-cards{grid-template-columns:1fr}
  .contato-form,.contato-info{padding:30px}
}
