:root{
  --primary:#0F4C5C;
  --accent:#00B4D8;
  --support:#8ED1C6;
  --bg:#F7F9F8;
  --text:#2B2B2B;

  --card:#ffffff;
  --line:rgba(15,76,92,.14);
  --shadow:0 18px 45px rgba(0,0,0,.10);
  --shadow-soft:0 12px 30px rgba(0,0,0,.08);

  --radius-xl:26px;
  --radius-lg:22px;
  --radius-md:16px;

  --container:1120px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Open Sans', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit}

.container{
  width:min(var(--container), calc(100% - 40px));
  margin:0 auto;
}

.skip-link{
  position:absolute;left:-999px;top:10px;
  background:var(--primary);color:#fff;
  padding:10px 14px;border-radius:12px;z-index:9999
}
.skip-link:focus{left:10px}

/* TOPBAR */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(247,249,248,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;
  gap:14px;
  flex-wrap:nowrap;
}
/* BRAND */
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;min-width:0}
..brand-logo{
  width:80px;
  height:80px;
  min-width:48px;
  border-radius:14px;
  object-fit:contain;
  display:block;
  background:rgba(15,76,92,.06);
  border:1px solid rgba(15,76,92,.12);
  padding:0;              /* antes era 6px */
}
.brand-text{display:flex;flex-direction:column;line-height:1.1;min-width:0}
.brand-name{font-family:'Montserrat', sans-serif;font-weight:900;font-size:1rem;color:var(--primary);white-space:nowrap}
.brand-tagline{font-size:.86rem;color:rgba(43,43,43,.75);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:38vw}
.nav-desktop{display:flex;gap:18px;align-items:center}
.nav-desktop a{
  font-weight:700;
  font-size:.95rem;
  color:rgba(43,43,43,.86);
  position:relative;
}
.nav-desktop a::after{
  content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;
  background:var(--accent);
  transition:width .25s ease;
}
.nav-desktop a:hover::after{width:100%}

.topbar-cta{display:flex;align-items:center;gap:10px}

/* Mobile nav */
.nav-burger{
  display:none;
  width:38px;height:38px;
  border-radius:12px;
  border:1px solid rgba(15,76,92,.10);
  background:rgba(255,255,255,.35);
  box-shadow:none;
  cursor:pointer;
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
}
.nav-burger:hover{
  background:rgba(15,76,92,.04);
  border-color: rgba(15,76,92,.14);
}
.nav-burger:active{transform:scale(.98)}

.burger-lines{
  position:relative;
  display:block;
  width:18px;
  height:1.5px;
  margin:0 auto;
  background: rgba(15,76,92,.55);
  border-radius:999px;
}
.burger-lines::before,
.burger-lines::after{
  content:"";
  position:absolute;
  left:0;
  width:18px;
  height:1.5px;
  background: rgba(15,76,92,.55);
  border-radius:999px;
}
.burger-lines::before{top:-6px}
.burger-lines::after{top:6px}

.nav-mobile{
  display:none;
  border-top:1px solid var(--line);
  padding:12px 0 16px;
}

/* never show on desktop, even if JS toggles a class */
.nav-mobile.is-open{display:none}
.nav-mobile a{
  display:block;
  padding:12px 0;
  font-weight:800;
  color:rgba(15,76,92,.92);
}
.nav-mobile a:hover{color:var(--primary)}

/* BUTTONS */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 18px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:800;
  letter-spacing:.2px;
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease, color .22s ease;
  user-select:none;
  white-space:nowrap;
}

.btn:active{transform:translateY(1px)}
.btn-lg{padding:14px 22px}
.btn-block{width:100%}
.btn-primary{
  background:var(--primary);
  color:#fff;
  box-shadow:0 12px 26px rgba(15,76,92,.22);
}
.btn-primary:hover{transform:translateY(-2px)}
.btn-secondary{
  background:var(--accent);
  color:#fff;
  box-shadow:0 12px 26px rgba(0,180,216,.22);
}
.btn-secondary:hover{transform:translateY(-2px)}
.btn-ghost{
  background:transparent;
  border-color:rgba(15,76,92,.22);
  color:var(--primary);
}
.btn-ghost:hover{
  background:rgba(15,76,92,.06);
  transform:translateY(-2px);
}

/* HERO */
.hero{
  position:relative;
  padding:88px 0 64px;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:-120px -120px auto auto;
  width:540px;height:540px;border-radius:50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(0,180,216,.28), transparent 60%),
    radial-gradient(circle at 70% 60%, rgba(142,209,198,.36), transparent 62%);
  filter: blur(2px);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.25fr .95fr;
  gap:26px;
  align-items:start;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(15,76,92,.06);
  border:1px solid rgba(15,76,92,.14);
  font-weight:800;
  color:rgba(15,76,92,.85);
  margin-bottom:14px;
}
.pill .dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px rgba(0,180,216,.14);
}
.hero h1{
  font-family:'Montserrat', sans-serif;
  font-weight:900;
  color:var(--primary);
  font-size:clamp(2rem, 3.1vw, 3rem);
  line-height:1.08;
  margin-bottom:14px;
}
.highlight{color:var(--accent)}
.hero-sub{
  max-width:62ch;
  font-size:1.05rem;
  color:rgba(43,43,43,.86);
  margin-bottom:18px;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}

.hero-metrics{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
}
.metric{
  background:rgba(255,255,255,.78);
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px 14px;
  box-shadow:0 10px 24px rgba(0,0,0,.05);
}
.metric-title{
  display:block;
  font-weight:900;
  color:rgba(15,76,92,.92);
  font-family:'Montserrat', sans-serif;
}
.metric-desc{display:block;font-size:.92rem;color:rgba(43,43,43,.78);margin-top:4px}

.hero-card{
  background:rgba(255,255,255,.92);
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  padding:22px 22px;
  box-shadow:var(--shadow);
}
.hero-card h2{
  font-family:'Montserrat', sans-serif;
  color:var(--primary);
  font-weight:900;
  margin-bottom:8px;
}
.hero-card p{color:rgba(43,43,43,.84)}
.hero-card-note{
  margin-top:10px;
  font-size:.92rem;
  color:rgba(43,43,43,.72);
  text-align:center;
}
.checklist{
  margin:14px 0 16px;
  list-style:none;
  display:grid;
  gap:10px;
}
.checklist li{
  position:relative;
  padding-left:26px;
  color:rgba(43,43,43,.84);
}
.checklist li::before{
  content:"";
  position:absolute;left:0;top:8px;
  width:14px;height:14px;border-radius:6px;
  background:rgba(142,209,198,.55);
  border:1px solid rgba(15,76,92,.18);
}

/* SECTIONS */
.section{padding:74px 0}
.section-alt{background:rgba(15,76,92,.03)}
.section-head{text-align:center;max-width:860px;margin:0 auto 34px}
.section-head h2{
  font-family:'Montserrat', sans-serif;
  font-weight:900;
  color:var(--primary);
  font-size:clamp(1.65rem, 2.2vw, 2.25rem);
  margin-bottom:10px;
}
.section-head p{color:rgba(43,43,43,.78);font-size:1.02rem}

/* CARDS GRID */
.cards-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:18px;
}
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-soft);
  padding:22px 22px;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

/* SERVICE CARDS */
.services-grid .service-card{
  cursor:pointer;
  position:relative;
  padding-top:24px;
}
.services-grid .service-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 22px 55px rgba(0,0,0,.12);
  border-color: rgba(0,180,216,.30);
}
.services-grid .service-card:focus{
  outline:3px solid rgba(0,180,216,.25);
  outline-offset:3px;
}
.service-icon{
  width:56px;height:56px;
  border-radius:18px;
  background:linear-gradient(135deg, rgba(0,180,216,.18), rgba(142,209,198,.32));
  border:1px solid rgba(15,76,92,.14);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 12px;
}
.service-icon svg{
  width:26px;height:26px;
  fill:rgba(15,76,92,.92);
}
.service-card h3{
  text-align:center;
  font-family:'Montserrat', sans-serif;
  font-weight:900;
  color:var(--primary);
  margin-bottom:10px;
}
.service-card .muted{
  text-align:center;
  color:rgba(43,43,43,.76);
}
.card-cta-row{
  margin-top:16px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:10px;
}
.chip{
  font-weight:900;
  font-size:.9rem;
  color:rgba(15,76,92,.92);
  background:rgba(15,76,92,.06);
  border:1px solid rgba(15,76,92,.14);
  padding:8px 12px;
  border-radius:999px;
}
.arrow{
  width:10px;height:10px;
  border-right:2px solid rgba(15,76,92,.60);
  border-bottom:2px solid rgba(15,76,92,.60);
  transform: rotate(-45deg);
}

/* CTA BOX */
.section-cta{margin-top:26px}
.cta-box{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:18px 20px;
  border-radius:var(--radius-xl);
  background:linear-gradient(135deg, rgba(15,76,92,.10), rgba(0,180,216,.10));
  border:1px solid rgba(15,76,92,.16);
  box-shadow:var(--shadow-soft);
}
.cta-box h3{
  font-family:'Montserrat', sans-serif;
  font-weight:900;
  color:var(--primary);
  margin-bottom:4px;
}
.cta-box p{color:rgba(43,43,43,.76)}

/* PARTNERS */
.partners-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:18px;
}
.partner{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  padding:22px 22px;
  box-shadow:var(--shadow-soft);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.partner:hover{
  transform:translateY(-6px);
  box-shadow: 0 22px 55px rgba(0,0,0,.12);
  border-color: rgba(0,180,216,.30);
}
.partner-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.partner-badge{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,180,216,.12);
  border:1px solid rgba(0,180,216,.20);
  color:rgba(15,76,92,.92);
  font-weight:900;
  font-size:.82rem;
  white-space:nowrap;
}
.partner h3{
  font-family:'Montserrat', sans-serif;
  font-weight:900;
  color:var(--primary);
  margin:0;
}
.mini-list{margin:12px 0 0 18px;color:rgba(43,43,43,.78)}
.mini-list li{margin:6px 0}

/* MARQUEE (DEPOIMENTOS LOOP) */
.marquee{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius-xl);
  border:1px solid rgba(15,76,92,.14);
  background:rgba(255,255,255,.55);
  box-shadow:var(--shadow-soft);
  padding:18px 0;
}
.marquee-track{
  display:flex;
  gap:14px;
  width:max-content;
  animation: marquee 26s linear infinite;
  padding:0 14px;
}
.testimonial-card{
  background:var(--card);
  border:1px solid rgba(15,76,92,.12);
  border-radius:18px;
  padding:14px 16px;
  box-shadow:0 10px 24px rgba(0,0,0,.06);
  white-space:nowrap;
  font-weight:800;
  color:rgba(43,43,43,.82);
}
@keyframes marquee{
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* CONTACT */
.contact-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:18px;
}
.contact-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  padding:22px 22px;
  box-shadow:var(--shadow-soft);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}
.contact-card:hover{
  transform:translateY(-6px);
  box-shadow: 0 22px 55px rgba(0,0,0,.12);
  border-color: rgba(0,180,216,.30);
  background: linear-gradient(135deg, rgba(0,180,216,.06), rgba(142,209,198,.10));
}
.contact-head{
  display:flex;
  align-items:center;
  gap:12px;
  justify-content:center;
  margin-bottom:10px;
}
.contact-ico{
  width:44px;height:44px;border-radius:16px;
  background:rgba(0,180,216,.12);
  border:1px solid rgba(0,180,216,.20);
  display:flex;align-items:center;justify-content:center;
}
.contact-ico svg{width:22px;height:22px;fill:rgba(15,76,92,.92)}
.contact-card h3{
  font-family:'Montserrat', sans-serif;
  font-weight:900;
  color:var(--primary);
  margin:0;
  text-align:center;
}
.contact-value{
  text-align:center;
  font-weight:800;
  color:rgba(43,43,43,.82);
  margin:8px 0 14px;
}
.map-wrap{
  margin-top:20px;
  border-radius:var(--radius-xl);
  overflow:hidden;
  border:1px solid rgba(15,76,92,.14);
  box-shadow:var(--shadow-soft);
}
.map-wrap iframe{
  width:100%;
  height:280px;
  border:0;
  display:block;
}

/* FOOTER (FINAL, NA PÁGINA) */
.site-footer{
  border-top:1px solid rgba(15,76,92,.14);
  background:rgba(15,76,92,.02);
  padding:30px 0 18px;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap:18px;
  align-items:start;
}
.footer-brand{
  display:flex;gap:12px;align-items:flex-start;
}
.footer-logo{width:54px;height:54px;object-fit:contain}
.footer-title{
  font-family:'Montserrat', sans-serif;
  font-weight:900;
  color:var(--primary);
}
.footer-sub{color:rgba(43,43,43,.74);margin-top:4px}
.footer-col strong{
  display:block;
  font-family:'Montserrat', sans-serif;
  font-weight:900;
  color:var(--primary);
  margin-bottom:10px;
}
.footer-link{
  display:block;
  font-weight:800;
  color:rgba(43,43,43,.82);
  margin:8px 0;
}
.footer-link:hover{color:var(--primary)}
.footer-muted{color:rgba(43,43,43,.70);font-size:.95rem}

.footer-social{display:flex;gap:10px;margin-top:12px}
.social-btn{
  width:44px;height:44px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,180,216,.10);
  border:1px solid rgba(0,180,216,.22);
  transition:transform .22s ease, background .22s ease;
}
.social-btn:hover{transform:translateY(-2px);background:rgba(0,180,216,.16)}
.social-btn svg{width:22px;height:22px;fill:rgba(15,76,92,.92)}

.footer-bottom{
  margin-top:16px;
  padding-top:12px;
  border-top:1px solid rgba(15,76,92,.10);
  display:flex;
  justify-content:space-between;
  align-items:center;
}

/* MODAL */
.modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:999;
}
.modal.is-open{display:block}
.modal-backdrop{
  position:absolute;inset:0;
  background:rgba(15,76,92,.38);
  backdrop-filter: blur(4px);
}
.modal-panel{
  position:relative;
  width:min(720px, calc(100% - 28px));
  margin:70px auto;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(15,76,92,.16);
  border-radius:28px;
  box-shadow:0 30px 90px rgba(0,0,0,.25);
  padding:22px 22px 20px;
}
.modal-close{
  position:absolute;
  top:12px;right:12px;
  width:42px;height:42px;
  border-radius:16px;
  border:1px solid rgba(15,76,92,.14);
  background:rgba(15,76,92,.04);
  cursor:pointer;
}
.modal-close:hover{background:rgba(15,76,92,.07)}
.modal-close span{
  font-size:24px;
  line-height:1;
  color:rgba(15,76,92,.85);
}
.modal-badge{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(142,209,198,.22);
  border:1px solid rgba(15,76,92,.14);
  color:rgba(15,76,92,.92);
  font-weight:900;
  font-size:.82rem;
  margin-bottom:10px;
}
.modal-head h3{
  font-family:'Montserrat', sans-serif;
  font-weight:900;
  color:var(--primary);
  font-size:1.6rem;
  margin-bottom:6px;
}
.modal-body{
  margin-top:14px;
  border-top:1px dashed rgba(15,76,92,.18);
  padding-top:14px;
}
.modal-list{
  margin:12px 0 0 18px;
  color:rgba(43,43,43,.80);
}
.modal-list li{margin:6px 0}
.modal-actions{margin-top:16px}

/* RESPONSIVE */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:18px}
  .hero-metrics{grid-template-columns:1fr;gap:10px}
  .cards-grid{grid-template-columns:1fr;gap:14px}
  .partners-grid{grid-template-columns:1fr;gap:14px}
  .contact-grid{grid-template-columns:1fr;gap:14px}
  .footer-grid{grid-template-columns:1fr;gap:14px}

  .nav-desktop{display:none}
  .topbar-cta{display:none}
  .nav-burger{display:inline-flex;align-items:center;justify-content:center}

  /* Mobile drawer open state */
  .nav-mobile.is-open{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }
  .nav-mobile a{
    padding:12px 2px;
    text-align:left;
  }
  .modal-panel{margin:56px auto}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .marquee-track{animation:none}
  .card, .btn, .social-btn, .contact-card, .partner{transition:none}
}
