:root {
  --bg-dark: #2e3d4f;
  --bg-mid: #364759;
  --bg-light: #3d5268;
  --silver: #a8b2bc;
  --silver-light: #c8d0d8;
  --silver-dim: #7a8896;
  --white: #eef1f4;
}
* { margin:0; padding:0; box-sizing:border-box; }
body {
  background: var(--bg-dark);
  color: var(--silver-light);
  font-family: 'Jost', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
  min-height: 100vh;
}

/* ── NAV ── */
nav {
  position: fixed; top:0; width:100%; z-index:200;
  background: rgba(46,61,79,0.92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(168,178,188,0.15);
}
.nav-inner {
  display:flex; justify-content:space-between; align-items:center;
  padding: 1.1rem 5vw;
}
.nav-logo {
  display:flex; align-items:center; gap:.7rem;
  text-decoration:none; cursor:pointer;
}
.nav-logo svg { width:34px; height:34px; }
.nav-logo span {
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem; font-weight:600; letter-spacing:.18em;
  color:var(--silver-light); text-transform:uppercase;
}

/* ── TAB BAR ── */
.tab-bar {
  display:flex; border-top: 1px solid rgba(168,178,188,0.1);
  overflow-x: auto; scrollbar-width:none;
}
.tab-bar::-webkit-scrollbar { display:none; }
.tab-btn {
  flex: 1; min-width: max-content;
  padding: .7rem 1.8rem;
  background: transparent;
  border: none;
  color: var(--silver-dim);
  font-family:'Jost',sans-serif;
  font-size: .72rem; letter-spacing:.18em; text-transform:uppercase;
  cursor:pointer;
  position:relative;
  transition: color .25s;
  white-space:nowrap;
}
.tab-btn::after {
  content:'';
  position:absolute; bottom:0; left:0; right:0;
  height:2px;
  background: var(--silver-light);
  transform: scaleX(0);
  transition: transform .25s;
}
.tab-btn:hover { color: var(--silver-light); }
.tab-btn.active {
  color: var(--white);
}
.tab-btn.active::after { transform: scaleX(1); }

/* ── PAGES ── */
.page { display:none; min-height:100vh; padding-top:90px; }
.page.active { display:block; }

/* ── SHARED ── */
.page-wrap { max-width:1100px; margin:0 auto; padding: 4rem 5vw; }
.section-label {
  font-size:.68rem; letter-spacing:.3em; text-transform:uppercase;
  color:var(--silver-dim); margin-bottom:.5rem;
}
.section-title {
  font-family:'Cormorant Garamond',serif;
  font-size: clamp(2rem,4vw,3.2rem);
  font-weight:300; color:var(--white); line-height:1.15;
  margin-bottom:1rem;
}
.divider { width:48px; height:1px; background:var(--silver-dim); margin:1.4rem 0; }
.body-text { font-size:.9rem; line-height:1.95; color:var(--silver-dim); margin-bottom:1rem; }
.btn-primary {
  display:inline-block; padding:.9rem 2.2rem;
  background:transparent; border:1px solid var(--silver);
  color:var(--silver-light); text-decoration:none;
  font-size:.78rem; letter-spacing:.15em; text-transform:uppercase;
  transition: background .3s, color .3s; cursor:pointer;
  font-family:'Jost',sans-serif;
}
.btn-primary:hover { background:var(--silver); color:var(--bg-dark); }

/* ── HERO PAGE ── */
#page-home {
  display:block;
  background:
    radial-gradient(ellipse 70% 60% at 65% 50%, rgba(90,110,130,0.2) 0%, transparent 70%),
    var(--bg-dark);
  position:relative;
  overflow:hidden;
}

#page-home::after {
  content:'';
  position:absolute; inset:0;
  background-image: repeating-linear-gradient(
    -45deg, transparent, transparent 40px,
    rgba(168,178,188,0.025) 40px, rgba(168,178,188,0.025) 41px
  );
  pointer-events:none;
}

.hero-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
  max-width:1100px;
  margin:0 auto;
  padding: 6rem 5vw 4rem;
  position:relative;
  z-index:1;
}

.hero-tag {
  display:inline-block;
  font-size:.68rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--silver-dim);
  margin-bottom:1.2rem;
  padding-bottom:.4rem;
  border-bottom:1px solid rgba(168,178,188,0.3);
}

.hero-title {
  font-family:'Cormorant Garamond',serif;
  font-size: clamp(1.8rem,3.2vw,2.8rem);
  font-weight:300;
  line-height:1.1;
  color:var(--white);
  margin-bottom:1.4rem;
}

.hero-title em {
  font-style:italic;
  color:var(--silver);
}

.hero-desc {
  font-size:.88rem;
  line-height:1.95;
  color:var(--silver-dim);
  margin-bottom:2rem;
  max-width:420px;
}

/* ── LOGO AJUSTADA ── */
.hero-logo-big{
  display:flex;
  justify-content:flex-end;
  align-items:center;
}

.hero-logo-big svg{
  width:min(360px,42vw);
  height:auto;
}

/* ── SOBRE ── */
.sobre-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:center;
}
.stats-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:1.5rem;
}
.stat {
  padding:1.8rem;
  border:1px solid rgba(168,178,188,0.15);
  background:rgba(46,61,79,0.5);
  transition:border-color .3s;
}
.stat:hover { border-color:rgba(168,178,188,0.4); }
.stat-num {
  font-family:'Cormorant Garamond',serif;
  font-size:2.6rem; font-weight:300;
  color:var(--silver-light); line-height:1; margin-bottom:.3rem;
}
.stat-label {
  font-size:.7rem; letter-spacing:.15em;
  text-transform:uppercase; color:var(--silver-dim);
}

/* ── SERVIÇOS ── */
.services-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1.5px; margin-top:3rem;
  background:rgba(168,178,188,0.12);
}
.service-card {
  background:var(--bg-dark); padding:2.2rem 1.8rem;
  transition:background .3s; position:relative; overflow:hidden;
}
.service-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--silver-dim),transparent);
  transform:scaleX(0); transition:transform .4s;
}
.service-card:hover { background:var(--bg-mid); }
.service-card:hover::after { transform:scaleX(1); }
.service-icon { width:42px; height:42px; margin-bottom:1.2rem; color:var(--silver-dim); }
.service-name {
  font-family:'Cormorant Garamond',serif;
  font-size:1.25rem; color:var(--white); margin-bottom:.6rem;
}
.service-desc { font-size:.82rem; line-height:1.8; color:var(--silver-dim); }

/* ── GALERIA ── */
.gallery-filter {
  display:flex; gap:.8rem; margin-bottom:2.5rem; flex-wrap:wrap;
}
.filter-btn {
  padding:.45rem 1.2rem;
  background:transparent;
  border:1px solid rgba(168,178,188,0.2);
  color:var(--silver-dim);
  font-family:'Jost',sans-serif;
  font-size:.7rem; letter-spacing:.15em; text-transform:uppercase;
  cursor:pointer; transition: all .25s;
}
.filter-btn:hover, .filter-btn.active {
  border-color:var(--silver); color:var(--white);
}
.gallery-grid {
  display:grid;
  grid-template-columns: repeat(3,1fr);
  grid-auto-rows:280px;
  gap:4px;
}
.gallery-item {
  position:relative; overflow:hidden; cursor:pointer;
}
.gallery-item img {
  width:100%; height:100%; object-fit:cover;
  transition: transform .5s;
}
.gallery-item:hover img { transform:scale(1.05); }
.gallery-overlay {
  position:absolute; inset:0;
  background:linear-gradient(transparent 40%, rgba(46,61,79,0.9));
  opacity:0; transition:opacity .35s;
  display:flex; align-items:flex-end; padding:1.2rem;
  color:var(--silver-light);
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
}
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-item.wide { grid-column: span 2; }

/* Lightbox */
.lightbox {
  display:none; position:fixed; inset:0; z-index:500;
  background:rgba(20,28,38,0.97);
  align-items:center; justify-content:center;
}
.lightbox.open { display:flex; }
.lightbox img {
  max-width:90vw; max-height:88vh;
  object-fit:contain; border:1px solid rgba(168,178,188,0.15);
}
.lightbox-close {
  position:absolute; top:1.5rem; right:2rem;
  background:none; border:none; color:var(--silver-dim);
  font-size:2rem; cursor:pointer; line-height:1;
  transition:color .2s;
}
.lightbox-close:hover { color:var(--white); }
.lightbox-caption {
  position:absolute; bottom:2rem;
  font-size:.72rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--silver-dim);
}

/* ── PROCESSO ── */
.steps {
  display:grid; grid-template-columns:repeat(4,1fr);
  border:1px solid rgba(168,178,188,0.12);
  margin-top:3rem;
}
.step {
  padding:2.5rem 1.8rem;
  border-right:1px solid rgba(168,178,188,0.12);
}
.step:last-child { border-right:none; }
.step-num {
  font-family:'Cormorant Garamond',serif;
  font-size:3.2rem; font-weight:300;
  color:rgba(168,178,188,0.12); line-height:1; margin-bottom:.8rem;
}
.step-name {
  font-family:'Cormorant Garamond',serif;
  font-size:1.1rem; color:var(--white); margin-bottom:.5rem;
}
.step-desc { font-size:.8rem; line-height:1.8; color:var(--silver-dim); }

/* ── CONTATO ── */
.contato-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:start;
}
.contact-item {
  display:flex; align-items:flex-start; gap:1rem;
  margin-bottom:1.8rem; padding-bottom:1.8rem;
  border-bottom:1px solid rgba(168,178,188,0.1);
}
.contact-item:last-child { border-bottom:none; }
.contact-icon { width:20px; min-width:20px; color:var(--silver-dim); margin-top:3px; }
.contact-label {
  font-size:.65rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--silver-dim); margin-bottom:.3rem;
}
.contact-value { font-size:.9rem; color:var(--silver-light); }
.contact-value a { color:inherit; text-decoration:none; }
.contact-value a:hover { color:var(--white); }
.form-group { margin-bottom:1.2rem; }
.form-group label {
  display:block; font-size:.65rem;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--silver-dim); margin-bottom:.4rem;
}
.form-group input, .form-group textarea, .form-group select {
  width:100%; padding:.8rem 1rem;
  background:rgba(46,61,79,0.7);
  border:1px solid rgba(168,178,188,0.2);
  color:var(--silver-light); font-family:'Jost',sans-serif;
  font-size:.85rem; outline:none; transition:border-color .3s;
  resize:none; appearance:none;
}
.form-group input:focus,
.form-group textarea:focus { border-color:rgba(168,178,188,0.5); }
.form-group textarea { height:120px; }

/* ── NOVOS PROJETOS ───────────────────────────────────────────────────────── */
.novos-foto-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  margin-top: 2rem;
}

.novos-foto-item {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  cursor: pointer;
}

.novos-foto-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}
.novos-foto-item:hover img { transform: scale(1.05); }

.novos-foto-placeholder {
  width: 100%;
  height: 100%;
  background: var(--bg-mid);
  display: flex;
  align-items: center;
  justify-content: center;
}
.novos-foto-placeholder svg {
  width: 64px;
  opacity: .2;
  color: var(--silver);
}

@media (max-width: 760px) {
  .novos-foto-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .novos-foto-grid { grid-template-columns: 1fr; }
}

/* ── FOOTER ── */
footer {
  padding:2rem 5vw;
  border-top:1px solid rgba(168,178,188,0.1);
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:1rem;
  background:var(--bg-dark);
}
.footer-logo {
  font-family:'Cormorant Garamond',serif;
  font-size:.85rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver-dim);
}
.footer-copy { font-size:.7rem; color:var(--silver-dim); }

/* ── WA FLOAT ── */
.wa-btn {
  position:fixed; bottom:2rem; right:2rem; z-index:300;
  width:52px; height:52px; border-radius:50%;
  background:var(--bg-mid); border:1px solid rgba(168,178,188,0.3);
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; color:var(--silver-light);
  box-shadow:0 4px 20px rgba(0,0,0,0.3);
  transition:transform .2s, border-color .2s;
}
.wa-btn:hover { transform:scale(1.08); border-color:var(--silver); }
.wa-btn svg { width:24px; }

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hero-grid { grid-template-columns:1fr; }
  .hero-logo-big { display:none; }
  .sobre-grid { grid-template-columns:1fr; gap:2.5rem; }
  .services-grid { grid-template-columns:1fr 1fr; }
  .steps { grid-template-columns:1fr 1fr; }
  .step { border-bottom:1px solid rgba(168,178,188,0.12); }
  .contato-grid { grid-template-columns:1fr; gap:2.5rem; }
  .gallery-grid { grid-template-columns:1fr 1fr; }
  .gallery-item.wide { grid-column:span 1; }
}
@media(max-width:600px){
  .services-grid { grid-template-columns:1fr; }
  .steps { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .gallery-grid { grid-template-columns:1fr; }
  .tab-btn { padding:.7rem 1.1rem; font-size:.66rem; }
}

/* ── CAROUSEL ────────────────────────────────────────────────────────────── */
.carousel-wrap {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 2.5rem;
}

.carousel-track-outer {
  flex: 1;
  overflow: hidden;
  border: 1px solid rgba(168,178,188,0.15);
}

.carousel-track {
  display: flex;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}

.carousel-slide {
  min-width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 520px;
}

.slide-img-wrap {
  overflow: hidden;
  position: relative;
}

.slide-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s ease;
}
.carousel-slide:hover .slide-img-wrap img { transform: scale(1.03); }

.slide-info {
  background: var(--bg-mid);
  padding: 2.8rem 2.4rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.slide-tag {
  font-size: .65rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--silver-dim);
  margin-bottom: .8rem;
}

.slide-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.6rem;
  font-weight: 300;
  color: var(--white);
  line-height: 1.2;
  margin-bottom: .5rem;
}

.slide-divider {
  width: 36px;
  height: 1px;
  background: var(--silver-dim);
  margin: 1rem 0;
}

.slide-specs {
  list-style: none;
  margin-bottom: 1.4rem;
}

.slide-specs li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: .5rem 0;
  border-bottom: 1px solid rgba(168,178,188,0.08);
  font-size: .8rem;
}

.spec-label {
  color: var(--silver-dim);
  letter-spacing: .08em;
  white-space: nowrap;
  flex-shrink: 0;
}

.spec-val {
  color: var(--silver-light);
  text-align: right;
}

.slide-desc {
  font-size: .82rem;
  line-height: 1.8;
  color: var(--silver-dim);
}

/* Arrow buttons */
.carousel-arrow {
  width: 46px;
  height: 46px;
  min-width: 46px;
  border-radius: 50%;
  background: var(--bg-mid);
  border: 1px solid rgba(168,178,188,0.25);
  color: var(--silver-light);
  font-size: 1.1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .25s, border-color .25s, transform .15s;
  flex-shrink: 0;
}
.carousel-arrow:hover {
  background: var(--bg-light);
  border-color: var(--silver);
  transform: scale(1.08);
}

/* Dots */
.carousel-dots {
  display: flex;
  justify-content: center;
  gap: .6rem;
  margin-top: 1.6rem;
}

.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(168,178,188,0.25);
  border: none;
  cursor: pointer;
  transition: background .25s, transform .25s;
  padding: 0;
}

.dot.active {
  background: var(--silver-light);
  transform: scale(1.3);
}

/* Responsive carousel */
@media (max-width: 800px) {
  .carousel-slide {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .slide-img-wrap { height: 260px; }
  .slide-info { padding: 1.8rem 1.4rem; }
  .carousel-wrap { gap: .5rem; }
  .carousel-arrow { width: 36px; height: 36px; min-width: 36px; font-size: .9rem; }
}

/* ── QUEM SOMOS / TEAM ───────────────────────────────────────────────────── */
.team-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5px;
  background: rgba(168,178,188,0.1);
  margin-top: 1rem;
}

.team-card {
  background: var(--bg-dark);
  display: flex;
  gap: 1.8rem;
  padding: 2.4rem 2rem;
  transition: background .3s;
  align-items: flex-start;
}
.team-card:hover { background: var(--bg-mid); }

.team-photo-wrap {
  flex-shrink: 0;
}

/* If you have a real photo: replace .team-photo-placeholder with <img> */
.team-photo-placeholder {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background: var(--bg-mid);
  border: 1px solid rgba(168,178,188,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.team-photo-placeholder svg { width: 54px; opacity: .5; }

/* Real photo style — add class="team-photo-real" to <img> */
img.team-photo-real {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid rgba(168,178,188,0.25);
  display: block;
}

.team-info { flex: 1; }

.team-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.35rem;
  font-weight: 400;
  color: var(--white);
  margin-bottom: .2rem;
}

.team-role {
  font-size: .7rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--silver-dim);
}

.team-divider {
  width: 30px;
  height: 1px;
  background: rgba(168,178,188,0.3);
  margin: .9rem 0;
}

.team-bio {
  font-size: .84rem;
  line-height: 1.85;
  color: var(--silver-dim);
}

@media (max-width: 700px) {
  .team-grid { grid-template-columns: 1fr; }
  .team-card { flex-direction: column; align-items: center; text-align: center; }
  .team-divider { margin: .9rem auto; }
}
.mapa-local{
  margin-top: 25px;
  width: 100%;
  height: 420px;
  overflow: hidden;
  border-radius: 18px;
}

.mapa-local iframe{
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}