
:root {
  --navy:    #0B1D35;
  --navy2:   #0f2540;
  --navy3:   #14304f;
  --blue:    #1a5fa0;
  --blue-l:  #2a7de1;
  --sky:     #5ba3f5;
  --slate:   #7898b8;
  --cloud:   #c8d8ea;
  --gray:    #f0f4f8;
  --white:   #ffffff;
  --orange:  #d97b38;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Poppins',sans-serif;
  font-size:15px;
  line-height:1.6;
  color:var(--navy);
  background:var(--white);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  padding:9px 48px;
  transition:background .35s,padding .35s,box-shadow .35s;
}
nav.solid{
  background:rgba(11,29,53,.97);
  backdrop-filter:blur(16px);
  padding:6px 48px;
  box-shadow:0 1px 0 rgba(255,255,255,.06);
}
.nav-logo{
  display:flex;align-items:center;
  flex-shrink:0;
  text-decoration:none;
}
.nav-logo img{
  height:36px;width:auto;display:block;
  transition:height .35s;
}
nav.solid .nav-logo img{ height:32px; }
.logo{
  font-family:'Poppins',sans-serif;
  font-size:22px;
  color:#fff;
  text-decoration:none;
  letter-spacing:.5px;
}
.logo b{color:var(--sky);font-style:italic;}
.nav-menu{display:flex;align-items:center;gap:30px;list-style:none;justify-content:center;flex:1;}
.nav-menu a{
  font-size:13px;font-weight:500;
  letter-spacing:.8px;text-transform:uppercase;
  color:rgba(255,255,255,.85);text-decoration:none;
  transition:color .25s;
}
.nav-menu a:hover{color:#fff;}
.nav-btn{
  font-size:12px!important;font-weight:600!important;
  background:var(--blue-l);color:#fff!important;
  padding:8px 20px;border-radius:5px;
  transition:background .25s!important;
}
.nav-btn:hover{background:var(--sky)!important;}

/* HERO */
#hero{
  background:var(--navy);
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:54vh;
  padding:84px 72px 44px;
  position:relative;
  overflow:hidden;
}
.hero-content{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:72px;
  position:relative;
  z-index:2;
  width:100%;
  max-width:1240px;
  margin:0 auto;
}
.hero-left{ max-width:600px; }
.hero-photo{
  position:relative;
  justify-self:end;
  align-self:center;
  flex-shrink:0;
}
.hero-photo::before,
.hero-photo::after{
  content:'';
  position:absolute;
  width:40px;height:40px;
  border:1px solid rgba(91,163,245,.4);
  z-index:0;
}
.hero-photo::before{
  top:-14px;left:-14px;
  border-right:none;border-bottom:none;
}
.hero-photo::after{
  bottom:-14px;right:-14px;
  border-left:none;border-top:none;
}
.hero-photo-circle{
  position:relative;
  z-index:1;
  width:230px;height:230px;
  border-radius:50%;
  overflow:hidden;
  border:3px solid #fff;
  box-shadow:0 0 0 6px rgba(42,125,225,.18), 0 24px 52px rgba(0,0,0,.4);
  background:#ffffff;
  display:flex;align-items:center;justify-content:center;
  animation: heroPulse 4s ease-in-out infinite;
}
@keyframes heroPulse{
  0%,100%{box-shadow:0 0 0 6px rgba(42,125,225,.18),0 24px 52px rgba(0,0,0,.4);}
  50%{box-shadow:0 0 0 12px rgba(42,125,225,.25),0 24px 52px rgba(0,0,0,.4);}
}
.hero-photo-circle img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 85%;
  filter:none;
}
.hero-grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(42,125,225,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(42,125,225,.05) 1px,transparent 1px);
  background-size:48px 48px;
}
.hero-glow{
  position:absolute;
  width:700px;height:700px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(42,125,225,.1) 0%,transparent 65%);
  top:-200px;left:-200px;
  animation:glowPulse 7s ease-in-out infinite;
}
@keyframes glowPulse{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}

.hero-left{
  position:relative;z-index:2;
  max-width:600px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:7px;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--sky);margin-bottom:20px;
}
.hero-eyebrow i{
  width:5px;height:5px;border-radius:50%;
  background:var(--sky);
  animation:blink 2s infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
h1{
  font-family:'Poppins',sans-serif;
  font-size:clamp(52px,7vw,92px);
  font-weight:800;
  line-height:1;
  color:#fff;
  letter-spacing:-2.5px;
  margin-bottom:18px;
}
.hero-title{
  margin:-30px 0 -70px -30px;
  line-height:0;
  overflow:hidden;
}
.hero-title img{
  display:block;
  width:clamp(340px,46vw,560px);
  height:auto;
  transform:scale(1.22);
  transform-origin:center center;
}
.hero-sub{
  font-size:15px;
  color:rgba(255,255,255,.8);
  max-width:480px;
  margin:0 0 28px;
  line-height:1.75;
}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap;}
.btn{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13px;font-weight:600;
  letter-spacing:.6px;text-transform:uppercase;
  padding:10px 22px;border-radius:5px;
  text-decoration:none;
  transition:all .25s;cursor:pointer;border:none;
}
.btn-primary{background:var(--blue-l);color:#fff;}
.btn-primary:hover{background:var(--sky);transform:translateY(-2px);box-shadow:0 8px 22px rgba(42,125,225,.3);}
.btn-wa{background:#25D366;color:#fff;}
.btn-wa:hover{background:#1fb558;transform:translateY(-2px);box-shadow:0 8px 22px rgba(37,211,102,.35);}
.btn-outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4);}
.btn-outline:hover{color:#fff;border-color:#fff;background:rgba(255,255,255,.08);}

/* hero right — photo */
.hero-right{ display:none; }
.hero-photo-wrap{
  position:relative;
  width:360px;
  margin:0 auto;
  align-self:flex-end;
}
.hero-photo-wrap img{
  width:100%;
  display:block;
  filter:drop-shadow(0 20px 40px rgba(0,0,0,.5));
}
.hero-photo-card{
  position:absolute;
  bottom:90px;left:-24px;
  background:var(--blue-l);
  border-radius:8px;
  padding:12px 16px;
  color:#fff;
  box-shadow:0 12px 32px rgba(42,125,225,.35);
}
.hpc-num{font-family:'Poppins',sans-serif;font-size:30px;line-height:1;}
.hpc-lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;opacity:.8;margin-top:2px;}

/* STATS BAR */
.stats-bar{
  background:var(--blue);
  display:flex;justify-content:space-around;align-items:center;
  padding:16px 48px;
  gap:20px;
}
.stat{text-align:center;}
.stat-n{
  font-family:'Poppins',sans-serif;
  font-size:36px;color:#fff;line-height:1;
}
.stat-l{
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.9);margin-top:4px;
}
.stat-div{width:1px;height:44px;background:rgba(255,255,255,.15);}

/* SECTION */
.section{padding:52px 48px;}
.section > *:not(.svc-grid):not(.sobre-grid):not(.contact-grid):not(.carousel-wrap):not(.proj-grid){max-width:900px;margin-left:auto;margin-right:auto;}
.section-inner{max-width:900px;margin:0 auto;}
/* projetos section uses full width carousel */
#projetos{padding:36px 48px 32px;}
#projetos .sec-header{max-width:900px;margin-left:auto;margin-right:auto;margin-bottom:24px;}
.section-light{background:var(--gray);}
.section-dark{background:var(--navy);}
.eyebrow{
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--blue-l);margin-bottom:10px;
  text-align:center;
}
.section-dark .eyebrow{color:var(--sky);}
h2{
  font-family:'Poppins',sans-serif;
  font-size:clamp(26px,3vw,38px);
  line-height:1.1;letter-spacing:-.3px;
  color:var(--navy);margin-bottom:8px;
  text-align:center;
}
.section-dark h2{color:#fff;}
.section-intro{
  font-size:15px;color:#5a7a98;
  max-width:520px;line-height:1.65;
  margin:0 auto;
}
.section-dark .section-intro{color:var(--slate);}
.sec-header{margin-bottom:48px;text-align:center;}

/* SERVICES */


.svc{
  display:flex;align-items:center;gap:16px;
  padding:18px 22px;
  background:#fff;
  border:1px solid var(--cloud);
  cursor:default;
  transition:all .3s;
  position:relative;overflow:hidden;
}
.svc::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--blue-l);
  transform:scaleY(0);transform-origin:bottom;
  transition:transform .3s;
}
.svc:hover{background:var(--navy);border-color:var(--navy);}
.svc:hover .svc-name{color:#fff;}
.svc:hover .svc-tag{color:var(--sky);}
.svc:hover .svc-arr{color:var(--sky);transform:translateX(4px);}
.svc:hover::before{transform:scaleY(1);}
.svc-ico{
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;
  background:var(--gray);border-radius:6px;flex-shrink:0;
}
.svc-info{flex:1;}
.svc-name{font-size:14px;font-weight:600;color:var(--navy);transition:color .3s;}
.svc-tag{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--slate);margin-top:2px;transition:color .3s;}
.svc-arr{font-size:16px;color:var(--cloud);transition:all .3s;}

/* PROJECTS */
.proj-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;margin-top:0;
}
.proj{
  background:var(--navy2);border-radius:8px;
  overflow:hidden;transition:transform .3s;cursor:default;
}
.proj:hover{transform:translateY(-6px);}
.proj-thumb{
  height:160px;display:flex;align-items:center;justify-content:center;
  font-size:48px;position:relative;
}
.t1{background:linear-gradient(135deg,#0a1e3d,#1a3a6a);}
.t2{background:linear-gradient(135deg,#0f2640,#1a3d70);}
.t3{background:linear-gradient(135deg,#0d2235,#163860);}
.proj-chip{
  position:absolute;top:12px;left:12px;
  background:var(--blue-l);color:#fff;
  font-size:9px;letter-spacing:2px;text-transform:uppercase;
  padding:3px 10px;border-radius:2px;
}
.proj-body{padding:20px 18px;}
.proj-title{
  font-family:'Poppins',sans-serif;
  font-size:16px;color:#fff;line-height:1.25;margin-bottom:8px;
}
.proj-desc{font-size:13px;color:rgba(255,255,255,.45);line-height:1.55;margin-bottom:12px;}
.proj-result{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--orange);}

/* SOBRE */
.sobre-grid{
  display:grid;
  grid-template-columns:1fr 300px;
  gap:48px;
  align-items:center;
  max-width:900px;margin:0 auto;
}
.sobre-grid p{
  font-size:15px;line-height:1.85;
  color:#3a4a5e;
  margin:0 0 18px;
}
.sobre-grid p:last-child{ margin-bottom:0; }
.sobre-brand{
  display:flex;
  align-items:center;
  justify-content:center;
}
.sobre-brand img{
  width:100%;
  max-width:240px;
  height:auto;
  display:block;
}
.sobre-grid p strong{ color:var(--navy); font-weight:600; }
.sobre-lead{
  /* unified with .sobre-grid p */
}
.sobre-tags{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-top:28px;
  padding-top:24px;
  border-top:1px solid rgba(11,29,53,.08);
}
.sobre-tag{
  font-size:11px;
  font-weight:600;
  letter-spacing:1px;
  text-transform:uppercase;
  padding:7px 14px;
  background:#fff;
  border:1px solid rgba(42,125,225,.25);
  color:var(--blue);
  border-radius:6px;
  transition:all .25s;
}
.sobre-tag:hover{
  background:var(--blue-l);
  color:#fff;
  border-color:var(--blue-l);
  transform:translateY(-2px);
}
.sobre-photo-wrap{
  position:relative;
}
.sobre-photo-bg{
  width:100%;
  aspect-ratio:3/4;
  background:linear-gradient(160deg,#0d2545,#0a1e3a);
  border-radius:10px;
  overflow:hidden;
  display:flex;align-items:flex-end;justify-content:center;
  position:relative;
}
.sobre-photo-bg::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 55%,rgba(9,24,46,.5) 100%);
  pointer-events:none;
}
.sobre-photo-bg img{
  width:auto;
  height:100%;
  max-width:100%;
  object-fit:contain;
  object-position:bottom center;
  display:block;
}
.sobre-badge{
  position:absolute;
  bottom:-16px;right:-16px;
  background:var(--blue-l);
  border-radius:8px;
  padding:16px 20px;
  color:#fff;
  box-shadow:0 10px 28px rgba(42,125,225,.35);
}
.sb-num{font-family:'Poppins',sans-serif;font-size:28px;line-height:1;}
.sb-lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;opacity:.8;margin-top:3px;}

.sobre-text p{font-size:15px;color:#4a6480;line-height:1.75;margin-top:16px;}
.creds{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px;}
.cred{
  display:flex;align-items:center;gap:6px;
  background:var(--gray);border-radius:4px;
  padding:7px 13px;font-size:13px;font-weight:500;color:var(--navy);
}

/* CONTATO */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:start;
  max-width:900px;margin:0 auto;
}
.c-headline{
  font-family:'Poppins',sans-serif;
  font-size:clamp(22px,2.5vw,32px);
  color:#fff;line-height:1.15;
  margin-top:14px;margin-bottom:28px;
}
.c-item{
  display:flex;gap:14px;
  padding:16px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
  align-items:center;
}
.c-item:first-of-type{border-top:1px solid rgba(255,255,255,.06);}
.c-ico{
  width:38px;height:38px;flex-shrink:0;
  background:rgba(42,125,225,.15);
  border:1px solid rgba(42,125,225,.25);
  border-radius:6px;
  display:flex;align-items:center;justify-content:center;font-size:16px;
}
.c-lbl{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--sky);}
.c-val{font-size:14px;color:rgba(255,255,255,.7);margin-top:2px;}

.c-form{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:10px;padding:36px 32px;
}
.field{margin-bottom:16px;}
.field label{
  display:block;font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--slate);margin-bottom:7px;
}
.field input,.field textarea,.field select{
  width:100%;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:5px;padding:11px 15px;
  font-family:'Poppins',sans-serif;font-size:14px;
  color:#fff;outline:none;
  transition:border-color .25s;
}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--blue-l);}
.field textarea{height:95px;resize:none;}
.field select{appearance:none;cursor:pointer;}
.field select option{background:#fff;color:var(--navy);}.field select option:checked{background:var(--blue-l);color:#fff;}
.form-btns{display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.btn-submit{
  width:100%;padding:12px;
  background:var(--blue-l);color:#fff;border:none;
  border-radius:5px;
  font-family:'Poppins',sans-serif;font-size:13px;font-weight:600;
  letter-spacing:1.5px;text-transform:uppercase;
  cursor:pointer;transition:all .25s;
}
.btn-submit:hover{background:var(--sky);transform:translateY(-2px);}
.btn-wa-form{
  width:100%;padding:12px;
  background:#25D366;color:#fff;border:none;
  border-radius:5px;
  font-family:'Poppins',sans-serif;font-size:13px;font-weight:600;
  letter-spacing:1.5px;text-transform:uppercase;
  cursor:pointer;transition:all .25s;
  display:flex;align-items:center;justify-content:center;gap:8px;
  text-decoration:none;
}
.btn-wa-form:hover{background:#1fb558;transform:translateY(-2px);}

/* WA FLOAT */
.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:300;
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:#25D366;color:#fff;text-decoration:none;
  box-shadow:0 6px 20px rgba(37,211,102,.4);
  transition:all .25s;
}
.wa-float:hover{background:#1fb558;transform:translateY(-3px) scale(1.08);box-shadow:0 10px 28px rgba(37,211,102,.5);}


/* ── NORMAS E ENTIDADES ── */
.normas-section{
  padding: 52px 48px;
}
.normas-inner{ max-width: 820px; margin: 0 auto; }
.normas-header{ text-align: center; margin-bottom: 28px; }
.normas-sub{
  font-size: 15px; color: var(--slate);
  max-width: 520px; margin: 12px auto 0;
  line-height: 1.6;
}
.normas-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.nc{
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  padding: 12px 12px;
  text-decoration: none;
  transition: all .3s;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}
.nc::before{
  content:'';
  position:absolute;
  left:0;top:0;bottom:0;width:3px;
  background:var(--blue-l);
  transform:scaleY(0);transform-origin:bottom;
  transition:transform .3s;
}
.nc:hover{
  border-color: rgba(42,125,225,.5);
  box-shadow: 0 8px 28px rgba(0,0,0,.3);
  transform: translateY(-3px);
  background: rgba(255,255,255,.1);
}
.nc:hover::before{ transform:scaleY(1); }
.nc:hover .nc-arrow{ color: var(--blue-l); transform: translateX(4px); }

.nc-icon{
  flex-shrink: 0;
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 6px;
  overflow: hidden;
  background: #fff;
  padding: 3px;
}
.nc-icon img{
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
}
.nc-body{ flex:1; min-width:0; }
.nc-name{
  font-family: 'DM Serif Display', serif;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 3px;
}
.nc-full{
  font-size: 9px;
  color: rgba(255,255,255,.5);
  margin-bottom: 4px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .8px;
}
.nc-desc{
  font-size: 11px;
  color: rgba(255,255,255,.45);
  line-height: 1.4;
}
.nc-arrow{
  font-size: 16px;
  color: rgba(255,255,255,.25);
  transition: all .3s;
  flex-shrink: 0;
}

@media(max-width:900px){
  .normas-section{ padding: 60px 20px; }
  .normas-grid{
    grid-template-columns: 1fr;
    gap: 12px;
  }

}

/* FOOTER NEW */
.footer-new {
  background: var(--navy);
}
.footer-inner {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr;
  gap: 48px;
  padding: 52px 48px 36px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.footer-brand {}
.footer-logo {
  font-family: 'DM Serif Display', serif;
  font-size: 20px;
  color: #fff;
  text-decoration: none;
  display: inline-block;
  margin-bottom: 12px;
}
.footer-logo b { color: var(--sky); font-style: italic; }
.footer-logo img{
  display:block;
  height:108px;
  width:auto;
}
.footer-tagline {
  font-size: 13px;
  color: rgba(255,255,255,.4);
  line-height: 1.65;
  max-width: 280px;
  margin-bottom: 20px;
}
.footer-socials {
  display: flex;
  gap: 8px;
}
.soc {
  width: 34px; height: 34px;
  border-radius: 6px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.5);
  display: flex; align-items: center; justify-content: center;
  text-decoration: none;
  transition: all .25s;
}
.soc:hover { background: var(--blue-l); border-color: var(--blue-l); color: #fff; }
.soc-wa:hover { background: #25D366; border-color: #25D366; color: #fff; }

.footer-col-title {
  font-family: 'Poppins', sans-serif;
  font-size: 15px;
  color: #fff;
  margin-bottom: 18px;
}
.footer-info {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.footer-info li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: rgba(255,255,255,.5);
}
.footer-info li svg { flex-shrink: 0; color: var(--sky); }
.footer-nav-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-nav-links a {
  font-size: 13px;
  color: rgba(255,255,255,.45);
  text-decoration: none;
  transition: color .25s;
}
.footer-nav-links a:hover { color: var(--sky); }
.footer-bottom {
  padding: 18px 48px;
  text-align: center;
}
.footer-bottom p {
  font-size: 11px;
  color: rgba(255,255,255,.25);
  letter-spacing: .5px;
}

@media(max-width:900px) {
  .section-creds { padding: 40px 20px; }
  .creds-logos { gap: 20px; }
  .footer-inner { grid-template-columns: 1fr; gap: 32px; padding: 40px 20px 28px; }
  .footer-bottom { padding: 16px 20px; }
}

/* FOOTER (old — keep for reference overridden) */
footer p{font-size:12px;color:rgba(255,255,255,.3);}
.footer-links{display:flex;gap:24px;list-style:none;}
.footer-links a{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.3);text-decoration:none;transition:color .25s;}
.footer-links a:hover{color:var(--sky);}



/* Show 3 cards at once, active in center */
.pc-card {
  flex: 0 0 calc(33.333%);
  background: var(--navy2);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  overflow: hidden;
  transition: border-color .3s, box-shadow .3s;
  opacity: 1;
  cursor: pointer;
}
.pc-card.active {
  border-color: rgba(42,125,225,.5);
  box-shadow: 0 8px 28px rgba(42,125,225,.15);
}
.pc-img {
  position: relative;
  background: #cdd8e8;
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.pc-img img {
  max-height: 140px;
  max-width: 90%;
  object-fit: contain;
  filter: none;
  transition: transform .3s;
}
.pc-card.active .pc-img img { transform: scale(1.04); }
.pc-chip {
  position: absolute;
  top: 10px; left: 10px;
  background: var(--blue-l);
  color: #fff;
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
}
.pc-body {
  padding: 16px 16px 18px;
}
.pc-cat {
  font-family: 'DM Serif Display', serif;
  font-size: 15px;
  color: #fff !important;
  line-height: 1.2;
  margin-bottom: 7px;
}
.pc-desc {
  font-size: 12px;
  color: rgba(255,255,255,.45);
  line-height: 1.55;
}

/* arrows for proj-carousel */
.proj-carousel .cs-arrow {
  top: 40%;
}
.proj-carousel .cs-prev { left: -20px; }
.proj-carousel .cs-next { right: -20px; }

@media(max-width:900px){
  .pc-card { flex: 0 0 80%; }
}

/* ── PROJ CAROUSEL ── */
.proj-carousel {
  position: relative;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 8px;
}
.pc-viewport {
  overflow: hidden;
  border-radius: 10px;
}
.pc-track {
  display: flex;
  gap: 12px;
  transition: transform .45s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.pc-card {
  flex: 0 0 calc(33.333% - 8px);
  background: var(--navy2);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 10px;
  overflow: hidden;
  transition: border-color .3s, box-shadow .3s;
  cursor: pointer;
}
.pc-card:hover {
  border-color: rgba(42,125,225,.4);
  box-shadow: 0 8px 28px rgba(0,0,0,.35);
}
.pc-img {
  position: relative;
  background: #d0daea;
  height: 168px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.pc-img img {
  max-height: 136px;
  max-width: 88%;
  object-fit: contain;
  filter: none;
  transition: transform .3s;
}
.pc-card:hover .pc-img img { transform: scale(1.05); }
.pc-chip {
  position: absolute;
  top: 10px; left: 10px;
  background: var(--blue-l);
  color: #fff;
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 2px;
}
.pc-body {
  padding: 16px 16px 18px;
}
.pc-cat {
  font-family: 'DM Serif Display', serif;
  font-size: 15px;
  color: #fff;
  line-height: 1.25;
  margin-bottom: 7px;
}
.pc-desc {
  font-size: 12px;
  color: rgba(255,255,255,.42);
  line-height: 1.55;
}

/* Floating transparent arrows */
.pc-arrow {
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(11,29,53,.55);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.8);
  font-size: 16px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .25s;
  z-index: 10;
}
.pc-arrow:hover {
  background: rgba(42,125,225,.7);
  border-color: rgba(42,125,225,.6);
  color: #fff;
}
.pc-prev { left: -14px; }
.pc-next { right: -14px; }

.cs-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 14px;
}
.cs-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,.2);
  cursor: pointer;
  transition: all .25s;
  padding: 0;
}
.cs-dot.active { background: var(--blue-l); transform: scale(1.3); }

@media(max-width:900px){
  .pc-card { flex: 0 0 calc(50% - 6px); }
}
@media(max-width:540px){
  .pc-card { flex: 0 0 85%; }
}

/* ── SECTION SVC ── */
.section-svc {
  background: var(--white);
  padding: 52px 48px;
}
.section-svc .eyebrow { color: var(--blue-l); }
.section-svc h2 { color: var(--navy); text-align:center; }
.svc-header { text-align: center; margin-bottom: 28px; }
.svc-intro {
  font-size: 15px; color: var(--slate);
  max-width: 500px; margin: 10px auto 0; line-height: 1.6;
}

/* ── SVC CARDS ── */
.svc-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  max-width: 1040px;
  margin: 0 auto;
}
.svc-card {
  background: var(--gray);
  border: 1px solid var(--cloud);
  border-radius: 10px;
  padding: 20px 18px;
  cursor: default;
  transition: all .3s;
  position: relative;
  overflow: hidden;
}
.svc-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--blue-l);
  transform: scaleY(0); transform-origin: bottom;
  transition: transform .3s;
}
.svc-card:hover {
  border-color: var(--blue-l);
  background: #fff;
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(42,125,225,.12);
}
.svc-card-img {
  margin: -20px -18px 14px;
  height: 130px;
  overflow: hidden;
}
.svc-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}
.svc-card:hover .svc-card-img img { transform: scale(1.04); }
.svc-card:hover::before { transform: scaleY(1); }
.svc-card-ico {
  width: 42px; height: 42px;
  border-radius: 8px;
  background: rgba(42,125,225,.1);
  border: 1px solid rgba(42,125,225,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--blue-l);
  margin-bottom: 14px;
  transition: background .3s;
}
.svc-card:hover .svc-card-ico { background: rgba(42,125,225,.18); }
.svc-card-name {
  font-family: 'Poppins', sans-serif;
  font-size: 18px; color: var(--navy); margin-bottom: 8px; line-height: 1.2;
}
.svc-card-desc {
  font-size: 13px; color: var(--slate); line-height: 1.6; margin-bottom: 12px;
}
.svc-card-tag {
  font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--blue-l); opacity: .75;
}
@media(max-width:900px) { .svc-cards { grid-template-columns: 1fr 1fr; } }
@media(max-width:540px) { .svc-cards { grid-template-columns: 1fr; } }
/* Menu lateral aberto no celular: esconde as imagens dos cards para não poluir */
@media(max-width:900px) { body.menu-open .svc-card-img { display: none; } }

.section-contato{background:#fff;}
.section-contato .eyebrow{color:var(--blue-l);}
.section-contato .c-headline{color:var(--navy);}
.section-contato .c-lbl{color:var(--blue-l);}
.section-contato .c-val{color:var(--text-mid,#4a6480);}
.section-contato .c-item{border-bottom:1px solid var(--cloud);}
.section-contato .c-item:first-of-type{border-top:1px solid var(--cloud);}
.section-contato .c-ico{background:rgba(42,125,225,.08);border:1px solid rgba(42,125,225,.2);}
.section-contato .field input,
.section-contato .field textarea,
.section-contato .field select{
  background:#f5f7fa;border:1px solid var(--cloud);color:var(--navy);
}
.section-contato .field label{color:var(--slate);}
.section-contato .c-form{
  background:#f5f7fa;border:1px solid var(--cloud);
}

.hero-brand{
  font-family:'Poppins',sans-serif;
  font-size:clamp(52px,6.5vw,88px);
  font-weight:700;
  line-height:1;
  color:#fff;
  letter-spacing:-2px;
  margin-bottom:14px;
}
.hero-brand span{color:var(--sky);font-style:italic;}
.hero-role{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--sky);
  background:rgba(42,125,225,.1);
  border:1px solid rgba(42,125,225,.25);
  padding:6px 14px;border-radius:20px;
  margin-bottom:20px;
}
.hero-role i{
  width:5px;height:5px;border-radius:50%;
  background:var(--sky);animation:blink 2s infinite;flex-shrink:0;
}


.nav-cv{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12px;font-weight:600;
  letter-spacing:.8px;text-transform:uppercase;
  color:#fff;text-decoration:none;
  background:rgba(42,125,225,.15);
  border:1px solid rgba(42,125,225,.4);
  padding:8px 18px;border-radius:5px;
  transition:all .25s;
  white-space:nowrap;
}
.nav-cv:hover{
  background:var(--blue-l);
  border-color:var(--blue-l);
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(42,125,225,.3);
}
.nav-cv svg{flex-shrink:0;}


section[id]{scroll-margin-top:64px;}


/* Smooth scroll + section fade-in transitions */
html { scroll-behavior: smooth; }
body { overflow-x: hidden; }

/* Enhanced reveal: fade + slight translateY */
[data-r] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .75s cubic-bezier(.4,0,.2,1), transform .75s cubic-bezier(.4,0,.2,1);
}
[data-r].in {
  opacity: 1;
  transform: translateY(0);
}


/* MOBILE */
/* Hamburger button (hidden on desktop) */
.nav-burger{
  display:none;
  background:transparent;border:none;
  width:44px;height:44px;
  cursor:pointer;
  padding:0;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
  z-index:210;
}
.nav-burger span{
  display:block;
  width:24px;height:2px;
  background:#fff;
  border-radius:2px;
  transition:transform .3s, opacity .3s;
}
.nav-burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-burger.open span:nth-child(2){ opacity:0; }
.nav-burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* Mobile menu overlay backdrop */
.nav-backdrop{
  display:none;
  position:fixed;inset:0;
  background:rgba(11,29,53,.6);
  backdrop-filter:blur(4px);
  z-index:195;
  opacity:0;
  transition:opacity .3s;
}
.nav-backdrop.show{ display:block; opacity:1; }

/* ── HERO TRUST STRIP ── */
.hero-trust{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-top:24px;
}
.ht-chip{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;letter-spacing:.5px;
  color:rgba(255,255,255,.7);
  background:rgba(42,125,225,.08);
  border:1px solid rgba(42,125,225,.2);
  padding:6px 12px;border-radius:20px;
  transition:background .25s,border-color .25s,color .25s;
}
.ht-chip:hover{
  background:rgba(42,125,225,.14);
  border-color:rgba(42,125,225,.35);
  color:#fff;
}
.ht-chip svg{color:var(--sky);flex-shrink:0;}

/* ── HERO CROSSHAIRS (blueprint corners) ── */
#hero::before, #hero::after{
  content:'';
  position:absolute;
  width:36px;height:36px;
  border:1px solid rgba(91,163,245,.25);
  pointer-events:none;
  z-index:1;
}
#hero::before{
  top:74px;left:36px;
  border-right:none;border-bottom:none;
}
#hero::after{
  bottom:28px;right:36px;
  border-left:none;border-top:none;
}

.section-light{ position:relative; }

/* ── DIFERENCIAIS SECTION ── */
.diferenciais-section{
  position:relative;
  overflow:hidden;
}
.diferenciais-section::after{
  content:'';
  position:absolute;inset:0;
  pointer-events:none;
  background-image:repeating-linear-gradient(30deg,
    transparent 0,transparent 80px,
    rgba(42,125,225,.04) 80px,rgba(42,125,225,.04) 81px);
  z-index:0;
}
.diferenciais-section > *{
  position:relative;
  z-index:1;
}
.diferenciais-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  max-width:900px;
  margin:0 auto;
}
.dif-card{
  background:#fff;
  border:1px solid var(--cloud);
  border-radius:10px;
  padding:28px 24px;
  text-align:center;
  transition:transform .3s,box-shadow .3s,border-color .3s;
  position:relative;
}
.dif-card:hover{
  transform:translateY(-4px);
  border-color:var(--blue-l);
  box-shadow:0 12px 32px rgba(42,125,225,.15);
}
.dif-ico{
  width:54px;height:54px;
  margin:0 auto 16px;
  border-radius:12px;
  background:rgba(42,125,225,.1);
  border:1px solid rgba(42,125,225,.2);
  display:flex;align-items:center;justify-content:center;
  color:var(--blue-l);
  transition:background .3s,border-color .3s;
}
.dif-card:hover .dif-ico{
  background:rgba(42,125,225,.18);
  border-color:rgba(42,125,225,.4);
}
.dif-title{
  font-family:'Poppins',sans-serif;
  font-size:18px;
  color:var(--navy);
  margin-bottom:8px;
  line-height:1.2;
}
.dif-desc{
  font-size:13px;
  color:var(--slate);
  line-height:1.6;
}
@media(max-width:900px){
  .diferenciais-grid{ grid-template-columns:1fr; }
}

/* ── SOBRE: MISSION / VISION / VALUES ── */
.sobre-mvv{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  max-width:900px;
  margin:32px auto 0;
  padding-top:28px;
  border-top:1px solid rgba(11,29,53,.08);
}
.mvv-card{
  padding:20px 18px;
  background:#fff;
  border:1px solid var(--cloud);
  border-left:3px solid var(--blue-l);
  border-radius:8px;
  transition:transform .25s,box-shadow .25s;
}
.mvv-card:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(42,125,225,.1);
}
.mvv-label{
  font-size:10px;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;
  color:var(--blue-l);
  margin-bottom:10px;
}
.mvv-card p{
  font-size:13px;
  color:#3a4a5e;
  line-height:1.6;
  margin:0;
}
@media(max-width:900px){
  .sobre-mvv{ grid-template-columns:1fr; }
}

/* ── DISPLAY WEIGHTS (compensate for swap from serif display to Poppins) ── */
h2, h3,
.logo, .footer-logo, .footer-col-title,
.proj-title, .pc-cat, .dif-title, .svc-card-name, .c-headline,
.mvv-label {
  font-weight: 700;
}
.hero-brand, .stat-n, .hpc-num, .sb-num {
  font-weight: 800;
}

@media(max-width:900px){
  nav{padding:12px 20px;justify-content:space-between;}nav.solid{padding:10px 20px;}
  .nav-logo img{height:40px;}
  nav.solid .nav-logo img{height:38px;}
  .nav-cv{display:none;}
  .nav-burger{display:flex;}
  .nav-menu{
    display:flex;
    position:fixed;
    top:0;right:-100%;
    width:280px;max-width:80vw;
    height:100vh;
    background:var(--navy);
    flex-direction:column;
    justify-content:center;
    align-items:flex-start;
    padding:80px 32px 32px;
    gap:0;
    margin:0;
    list-style:none;
    box-shadow:-8px 0 40px rgba(0,0,0,.4);
    transition:right .35s cubic-bezier(.4,0,.2,1);
    z-index:200;
  }
  .nav-menu.open{ right:0; }
  .nav-menu li{ width:100%; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.08); }
  .nav-menu li:last-child{ border-bottom:none; }
  .nav-menu a{
    font-size:15px !important;
    color:#fff !important;
    letter-spacing:1px;
    display:block;
    width:100%;
  }
  #hero{padding:104px 24px 56px;min-height:auto;}
  #hero::before{ top:88px;left:16px;width:36px;height:36px; }
  #hero::after{ bottom:20px;right:16px;width:36px;height:36px; }
  .hero-trust{ gap:6px;margin-top:18px; }
  .ht-chip{ font-size:10px;padding:5px 10px; }
  .hero-content{grid-template-columns:1fr;gap:36px;}
  .hero-left{ max-width:100%; }
  .hero-photo{ order:-1;justify-self:center; }
  .hero-photo::before{ top:-12px;left:-12px;width:44px;height:44px; }
  .hero-photo::after{ bottom:-12px;right:-12px;width:44px;height:44px; }
  .hero-photo-circle{width:190px;height:190px;}
  .hero-right{display:none;}
  .stats-bar{flex-wrap:wrap;padding:28px 20px;}
  .stat-div{display:none;}
  .section{padding:60px 20px;}
  .svc-grid{grid-template-columns:1fr;gap:32px;}
  .proj-grid{grid-template-columns:1fr;}
  .sobre-grid{grid-template-columns:1fr;gap:40px;}
  .sobre-badge{right:0;bottom:-12px;}
  .contact-grid{grid-template-columns:1fr;gap:40px;}
  footer{padding:22px 20px;flex-direction:column;text-align:center;}
  .footer-links{flex-wrap:wrap;justify-content:center;}
}

@media(max-width:540px){
  .hero-photo{ display:none; }
  .hero-content{ gap:0; }
}
