
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  background:#050505;
  color:#fff;
  line-height:1.7;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(1180px,92%);margin:auto}

.header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(5,5,5,.86);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav{
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
}
.brand img{width:185px}
.nav-menu{display:flex;gap:30px}
.nav-menu a{
  font-size:12px;
  font-weight:800;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:#d9d9d9;
}
.social-icons{display:flex;gap:10px}
.social-icons a{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  transition:.28s ease;
}
.social-icons svg{
  width:18px;
  height:18px;
  fill:#fff;
}
.social-icons a:hover{
  background:#fff;
  transform:translateY(-3px);
}
.social-icons a:hover svg{fill:#000}
.menu-btn{display:none}

.full-banner{
  min-height:calc(100vh - 92px);
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(90deg,rgba(0,0,0,.82),rgba(0,0,0,.35)),
    url('assets/banner-industrial.svg') center/cover no-repeat;
}
.full-banner:after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:190px;
  background:linear-gradient(transparent,#050505);
  pointer-events:none;
}
.banner-orb{
  position:absolute;
  border-radius:50%;
  filter:blur(8px);
  opacity:.14;
  animation:floatOrb 8s ease-in-out infinite alternate;
}
.orb-one{
  width:360px;height:360px;
  right:8%;top:16%;
  border:1px solid #fff;
}
.orb-two{
  width:180px;height:180px;
  left:12%;bottom:13%;
  border:1px solid #fff;
  animation-delay:1.2s;
}
.hero-grid{
  min-height:calc(100vh - 92px);
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:72px;
  align-items:center;
  position:relative;
  z-index:2;
  padding:90px 0;
}
.tag,.section-tag{
  display:inline-flex;
  color:#d5d5d5;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:12px;
  font-weight:900;
  margin-bottom:20px;
}
.hero h1{
  font-size:clamp(46px,6.4vw,88px);
  line-height:.98;
  letter-spacing:-.065em;
  max-width:860px;
}
.hero p{
  color:#c2c2c2;
  font-size:20px;
  max-width:650px;
  margin-top:28px;
}
.buttons{display:flex;gap:16px;flex-wrap:wrap;margin-top:38px}
.btn{
  min-height:56px;
  padding:0 25px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  font-size:12px;
  letter-spacing:.12em;
  font-weight:900;
  text-transform:uppercase;
  transition:.25s ease;
}
.btn.light{background:#fff;color:#000}
.btn.outline{border:1px solid rgba(255,255,255,.18);color:#fff}
.btn:hover{transform:translateY(-3px)}
.premium-panel{
  padding:36px;
  border-radius:40px;
  background:linear-gradient(145deg,rgba(255,255,255,.105),rgba(255,255,255,.025));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 40px 110px rgba(0,0,0,.48);
  animation:panelFloat 5s ease-in-out infinite alternate;
}
.premium-panel img{
  width:min(440px,100%);
  margin:auto;
  border-radius:18px;
}
.panel-line{
  height:1px;
  background:rgba(255,255,255,.13);
  margin:30px 0;
}
.panel-items{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.panel-items span{
  padding:16px 12px;
  border-radius:18px;
  background:rgba(0,0,0,.35);
  color:#d7d7d7;
  font-size:12px;
  text-align:center;
}

.light-section{
  background:#f5f5f5;
  color:#111;
  padding:110px 0;
}
.dark-section{
  background:#050505;
  color:#fff;
  padding:110px 0;
}
.split{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:80px;
}
.about h2,.services h2,.clients h2,.contact h2{
  font-size:clamp(36px,4.5vw,58px);
  line-height:1.05;
  letter-spacing:-.045em;
}
.about p{
  color:#4a4a4a;
  font-size:18px;
  margin-bottom:22px;
}
.section-header{
  max-width:820px;
  margin-bottom:52px;
}
.section-header.center{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}
.dark-text{color:#777}
.dark-title{color:#111}
.client-intro{
  color:#555;
  max-width:720px;
  margin:22px auto 0;
}
.service-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.service-grid article{
  min-height:260px;
  padding:34px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.09);
  background:linear-gradient(145deg,rgba(255,255,255,.07),rgba(255,255,255,.025));
  transition:.28s ease;
}
.service-grid article:hover{
  transform:translateY(-8px);
  border-color:rgba(255,255,255,.22);
}
.service-grid span{
  color:#777;
  font-weight:900;
}
.service-grid h3{
  font-size:24px;
  line-height:1.16;
  margin:28px 0 14px;
}
.service-grid p{color:#aaa}

.clients{
  border-top:1px solid #e8e8e8;
  border-bottom:1px solid #e8e8e8;
}
.client-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.client-logo{
  height:150px;
  border-radius:28px;
  background:#fff;
  border:1px solid #e5e5e5;
  display:grid;
  place-items:center;
  padding:22px;
  box-shadow:0 12px 35px rgba(0,0,0,.055);
  filter:grayscale(1);
  transition:.28s ease;
}
.client-logo:hover{
  filter:grayscale(0);
  transform:translateY(-6px);
  box-shadow:0 20px 45px rgba(0,0,0,.10);
}
.client-logo img{
  max-height:96px;
  object-fit:contain;
}

.contact-box{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:70px;
  padding:64px;
  border-radius:42px;
  border:1px solid rgba(255,255,255,.1);
  background:radial-gradient(circle at top right,rgba(255,255,255,.11),transparent 34%),#101010;
}
.contact p{color:#aaa;margin-top:22px}
.form{display:grid;gap:14px}
.form input,.form textarea{
  width:100%;
  background:#050505;
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  padding:18px 20px;
  font-family:inherit;
}
.form textarea{min-height:145px;resize:vertical}
.form button{
  min-height:58px;
  border:0;
  border-radius:999px;
  background:#fff;
  color:#000;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
  transition:.25s ease;
}
.form button:hover{transform:translateY(-3px)}

.footer{
  padding:54px 0;
  background:#000;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer-grid{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:40px;
  flex-wrap:wrap;
}
.footer img{width:190px;margin-bottom:16px}
.footer p{color:#888}
.footer-social{display:flex;gap:18px;flex-wrap:wrap}
.footer-social a{color:#ddd;border-bottom:1px solid rgba(255,255,255,.16);padding-bottom:6px}

.reveal{
  opacity:0;
  transform:translateY(28px);
  animation:revealUp .9s ease forwards;
}
.delay-1{animation-delay:.16s}
.delay-2{animation-delay:.28s}
.delay-3{animation-delay:.40s}

@keyframes revealUp{
  to{opacity:1;transform:translateY(0)}
}
@keyframes floatOrb{
  to{transform:translateY(-26px) translateX(18px)}
}
@keyframes panelFloat{
  to{transform:translateY(-12px)}
}

@media(max-width:1060px){
  .hero-grid,.split,.contact-box{grid-template-columns:1fr}
  .service-grid,.client-grid{grid-template-columns:repeat(2,1fr)}
  .nav-menu,.social-icons{display:none}
  .menu-btn{
    display:block;
    margin-left:auto;
    background:transparent;
    color:#fff;
    border:1px solid rgba(255,255,255,.14);
    border-radius:999px;
    padding:10px 14px;
    font-size:20px;
  }
  .nav-menu.active{
    display:flex;
    position:absolute;
    top:92px;
    left:0;
    right:0;
    background:#050505;
    border-bottom:1px solid rgba(255,255,255,.08);
    flex-direction:column;
    padding:26px 4%;
  }
}
@media(max-width:680px){
  .brand img{width:150px}
  .nav{min-height:78px}
  .nav-menu.active{top:78px}
  .service-grid,.client-grid,.panel-items{grid-template-columns:1fr}
  .hero-grid{min-height:auto;padding:74px 0}
  .hero h1{font-size:42px}
  .light-section,.dark-section{padding:76px 0}
  .contact-box{padding:28px;border-radius:28px}
}


/* Ajuste dos novos logotipos */
.brand{
  background:#fff;
  border-radius:16px;
  padding:8px 14px;
  display:inline-flex;
  align-items:center;
  box-shadow:0 10px 32px rgba(0,0,0,.18);
}
.brand img{
  width:180px;
  height:auto;
  object-fit:contain;
}
.premium-panel img{
  background:#fff;
  padding:28px;
  border-radius:26px;
  max-height:260px;
  object-fit:contain;
}
.footer img{
  background:#fff;
  padding:12px 16px;
  border-radius:16px;
  width:210px;
  object-fit:contain;
}
@media(max-width:680px){
  .brand img{width:140px}
}


/* Refinamentos solicitados */
.brand{padding:6px 12px;border-radius:14px}
.brand img{width:142px !important}
.footer img{width:160px !important;padding:10px 14px}
.footer-icons .social-icons{display:flex}
.footer-icons .social-icons a{width:42px;height:42px}
.link-more{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-height:48px;
  padding:0 18px;
  border-radius:999px;
  margin-top:24px;
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  font-size:12px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  transition:.25s ease;
}
.link-more:after{content:"→";font-size:16px}
.link-more:hover{transform:translateY(-3px);background:#fff;color:#000}
.dark-link{border-color:#d0d0d0;color:#111}
.dark-link:hover{background:#111;color:#fff}
.section-action{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:34px;
}
.center-action{justify-content:center}
.page-hero{
  min-height:520px;
  display:flex;
  align-items:center;
  background:
    linear-gradient(90deg,rgba(0,0,0,.86),rgba(0,0,0,.46)),
    url('assets/banner-industrial.svg') center/cover no-repeat;
  padding:110px 0;
}
.page-hero h1{
  font-size:clamp(44px,6vw,82px);
  line-height:.98;
  letter-spacing:-.065em;
  max-width:900px;
}
.page-hero p{
  max-width:680px;
  color:#c2c2c2;
  font-size:20px;
  margin-top:24px;
}
.page-content{
  padding:100px 0;
  background:#f5f5f5;
  color:#111;
}
.page-content.dark{
  background:#050505;
  color:#fff;
}
.editorial-grid{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:76px;
  align-items:start;
}
.editorial-grid h2{
  font-size:clamp(34px,4.3vw,56px);
  line-height:1.05;
  letter-spacing:-.045em;
}
.editorial-text p{
  color:#4b4b4b;
  font-size:18px;
  margin-bottom:22px;
}
.page-content.dark .editorial-text p{color:#aaa}
.info-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:44px;
}
.info-card{
  border-radius:28px;
  padding:30px;
  background:#fff;
  border:1px solid #e5e5e5;
  box-shadow:0 14px 34px rgba(0,0,0,.055);
}
.page-content.dark .info-card{
  background:linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.025));
  border-color:rgba(255,255,255,.10);
}
.info-card h3{font-size:22px;margin-bottom:12px}
.info-card p,.info-card li{color:#666}
.page-content.dark .info-card p,.page-content.dark .info-card li{color:#aaa}
.info-card ul{padding-left:18px}
.product-layout{
  display:grid;
  gap:28px;
}
.product-row{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:48px;
  align-items:center;
  padding:40px;
  border-radius:36px;
  background:#fff;
  border:1px solid #e5e5e5;
  box-shadow:0 16px 42px rgba(0,0,0,.06);
}
.product-visual{
  min-height:300px;
  border-radius:28px;
  background:
    linear-gradient(135deg,#111,#2b2b2b);
  display:grid;
  place-items:center;
  color:#fff;
  font-size:38px;
  font-weight:900;
  letter-spacing:.12em;
}
.product-row h2{
  font-size:clamp(32px,4vw,52px);
  line-height:1.05;
  letter-spacing:-.045em;
}
.product-row p{color:#555;font-size:18px;margin:20px 0}
.product-row ul{padding-left:18px;color:#555}
.client-page-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:40px;
}
.contact-list{
  display:grid;
  gap:14px;
  margin-top:28px;
}
.contact-list a{
  color:inherit;
  border-bottom:1px solid rgba(0,0,0,.18);
  padding-bottom:8px;
}
@media(max-width:1060px){
  .brand img{width:128px !important}
  .editorial-grid,.product-row{grid-template-columns:1fr}
  .info-grid,.client-page-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .brand img{width:118px !important}
  .footer img{width:142px !important}
  .info-grid,.client-page-grid{grid-template-columns:1fr}
  .page-hero{min-height:auto;padding:82px 0}
  .product-row{padding:26px;border-radius:28px}
}


/* Refinamento final do logotipo */
.brand{
  background:#fff;
  padding:3px 8px;
  border-radius:10px;
}
.brand img{
  width:150px !important;
  object-fit:contain;
}

.footer img{
  width:175px !important;
  background:#fff;
  padding:4px 10px !important;
  border-radius:10px;
  object-fit:contain;
}

.premium-panel img{
  padding:18px !important;
  background:#fff;
  border-radius:18px;
}

@media(max-width:680px){
  .brand img{
    width:126px !important;
  }
  .footer img{
    width:150px !important;
  }
}


/* Formulário mais leve e premium */
.form{
  background:#ffffff;
  padding:28px;
  border-radius:28px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 18px 48px rgba(0,0,0,.12);
}

.contact .form{
  background:rgba(255,255,255,.96);
}

.form input,
.form textarea{
  background:#f7f7f7 !important;
  color:#111 !important;
  border:1px solid #dedede !important;
  box-shadow:none;
}

.form input::placeholder,
.form textarea::placeholder{
  color:#777;
}

.form input:focus,
.form textarea:focus{
  outline:none;
  border-color:#111 !important;
  background:#fff !important;
}

.form button{
  background:#111 !important;
  color:#fff !important;
}

.form button:hover{
  background:#000 !important;
}

/* Ajuste para formulário em páginas claras */
.page-content .form{
  box-shadow:0 16px 42px rgba(0,0,0,.08);
}

/* Contato final continua escuro, mas formulário ganha contraste limpo */
.contact-box{
  background:radial-gradient(circle at top right,rgba(255,255,255,.10),transparent 34%),#101010;
}


/* Páginas legais */
.legal-links{
  display:flex;
  justify-content:center;
  gap:22px;
  flex-wrap:wrap;
  padding:0 0 40px;
  background:#000;
}

.legal-links a{
  color:#9a9a9a;
  font-size:13px;
  border-bottom:1px solid rgba(255,255,255,.12);
  padding-bottom:6px;
  transition:.25s ease;
}

.legal-links a:hover{
  color:#fff;
}

.legal-page{
  background:#f5f5f5;
  color:#111;
  padding:90px 0;
}

.legal-box{
  background:#fff;
  border-radius:34px;
  padding:54px;
  border:1px solid #e4e4e4;
  box-shadow:0 18px 42px rgba(0,0,0,.06);
}

.legal-box h1{
  font-size:clamp(38px,5vw,64px);
  line-height:1.02;
  letter-spacing:-.05em;
  margin-bottom:18px;
}

.legal-box h2{
  font-size:28px;
  margin:42px 0 16px;
}

.legal-box p,
.legal-box li{
  color:#555;
  margin-bottom:16px;
}

.legal-box ul{
  padding-left:22px;
}

.legal-highlight{
  padding:20px 24px;
  border-radius:18px;
  background:#f7f7f7;
  border:1px solid #ececec;
  margin:26px 0;
}

@media(max-width:680px){
  .legal-box{
    padding:28px;
    border-radius:24px;
  }
}


/* =========================================================
   ALTERAÇÕES FINAIS CONFIRMADAS - TORFER
   ========================================================= */

.premium-highlight-strip{
  background:#0b0b0b;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.premium-highlight-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
}

.premium-highlight-grid div{
  padding:30px 24px;
  border-left:1px solid rgba(255,255,255,.06);
}

.premium-highlight-grid strong{
  display:block;
  font-size:38px;
  line-height:1;
  color:#ffffff;
  margin-bottom:12px;
}

.premium-highlight-grid span{
  color:#cfcfcf;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.15em;
  font-weight:900;
}

.cert-premium{
  background:#050505;
  color:#fff;
  padding:110px 0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.cert-premium .section-header{
  max-width:850px;
  margin-bottom:54px;
}

.cert-premium .section-header.center{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}

.cert-premium h2{
  font-size:clamp(36px,4.5vw,58px);
  line-height:1.05;
  letter-spacing:-.045em;
}

.cert-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.cert-grid article{
  border-radius:30px;
  padding:36px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  box-shadow:0 18px 44px rgba(0,0,0,.22);
}

.cert-grid article:hover{
  transform:translateY(-6px);
  border-color:rgba(255,255,255,.24);
  transition:.25s ease;
}

.cert-grid h3{
  font-size:28px;
  margin-bottom:14px;
}

.cert-grid p{
  color:#aaa;
}

.product-category-title{
  margin-bottom:46px;
  max-width:880px;
}

.product-category-title h2{
  font-size:clamp(36px,4.5vw,58px);
  line-height:1.05;
  letter-spacing:-.045em;
}

.product-category-title p{
  color:#555;
  font-size:18px;
  margin-top:18px;
}

.product-row{
  position:relative;
  overflow:hidden;
}

.product-row::before{
  content:"";
  position:absolute;
  right:-120px;
  top:-120px;
  width:250px;
  height:250px;
  border-radius:50%;
  border:1px solid rgba(0,0,0,.06);
  pointer-events:none;
}

.product-visual{
  letter-spacing:.08em;
  text-align:center;
}

.product-row .link-more{
  margin-top:26px;
}

.link-more.whatsapp-cta{
  background:#111;
  color:#fff;
  border-color:#111;
}

.link-more.whatsapp-cta:hover{
  background:#000;
  color:#fff;
}

@media(max-width:860px){
  .premium-highlight-grid,
  .cert-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media(max-width:560px){
  .premium-highlight-grid,
  .cert-grid{
    grid-template-columns:1fr;
  }
}


/* =========================================================
   DESTAQUE EXTRA - CERTIFICAÇÕES E CLIENTES
   ========================================================= */

.cert-premium{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 20% 10%, rgba(255,255,255,.16), transparent 28%),
    radial-gradient(circle at 90% 70%, rgba(255,255,255,.09), transparent 32%),
    linear-gradient(135deg,#020202,#111 55%,#050505) !important;
  padding:135px 0 !important;
}

.cert-premium::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg, transparent 0%, transparent 42%, rgba(255,255,255,.055) 43%, transparent 44%),
    linear-gradient(120deg, transparent 0%, transparent 54%, rgba(255,255,255,.035) 55%, transparent 56%);
  pointer-events:none;
}

.cert-premium .container{
  position:relative;
  z-index:2;
}

.cert-premium .section-tag{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  padding:10px 16px;
  margin-bottom:24px;
}

.cert-premium h2{
  max-width:920px;
  margin-left:auto;
  margin-right:auto;
  font-size:clamp(42px,5.8vw,76px) !important;
  line-height:.98 !important;
}

.cert-premium .client-intro{
  color:#c8c8c8 !important;
  font-size:19px;
  margin-top:24px;
}

.cert-grid{
  margin-top:60px;
}

.cert-grid article{
  min-height:285px;
  padding:44px 36px !important;
  border-radius:34px !important;
  background:
    linear-gradient(145deg,rgba(255,255,255,.13),rgba(255,255,255,.035)) !important;
  border:1px solid rgba(255,255,255,.18) !important;
  box-shadow:0 30px 90px rgba(0,0,0,.38) !important;
  position:relative;
  overflow:hidden;
}

.cert-grid article::before{
  content:"";
  position:absolute;
  top:28px;
  right:28px;
  width:68px;
  height:68px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
}

.cert-grid article::after{
  content:"✓";
  position:absolute;
  top:38px;
  right:49px;
  color:#fff;
  font-size:22px;
  font-weight:900;
}

.cert-grid h3{
  font-size:34px !important;
  line-height:1.08;
  margin-bottom:20px !important;
  max-width:240px;
}

.cert-grid p{
  font-size:16px;
  line-height:1.7;
  color:#c9c9c9 !important;
}

/* Clientes maiores, com menos margem aparente */
.client-grid,
.client-page-grid{
  gap:22px !important;
}

.client-logo{
  height:190px !important;
  padding:12px !important;
  border-radius:30px !important;
  background:#fff !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.client-logo img{
  width:100% !important;
  height:100% !important;
  max-height:160px !important;
  object-fit:contain !important;
  transform:scale(1.22);
}

.client-logo:hover img{
  transform:scale(1.30);
  transition:.25s ease;
}

/* Ajustes específicos para logos com muito respiro original */
.client-logo img[src*="newfortress"],
.client-logo img[src*="white-martins"],
.client-logo img[src*="clean"],
.client-logo img[src*="messer"]{
  max-width:96% !important;
}

@media(max-width:860px){
  .cert-premium{
    padding:95px 0 !important;
  }
  .cert-grid article{
    min-height:245px;
  }
  .client-logo{
    height:170px !important;
  }
}

@media(max-width:560px){
  .client-logo{
    height:155px !important;
  }
  .cert-premium h2{
    font-size:40px !important;
  }
}


/* =========================================================
   GALERIAS DE PRODUTOS REAIS
   ========================================================= */

.product-gallery-section{
  padding:100px 0;
  background:#f5f5f5;
  color:#111;
  border-top:1px solid #e8e8e8;
}

.gallery-header{
  margin-bottom:42px;
  max-width:820px;
}

.gallery-header h2{
  font-size:clamp(34px,4.5vw,56px);
  line-height:1.05;
  letter-spacing:-.045em;
}

.product-gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}

.gallery-card{
  background:#fff;
  border-radius:34px;
  overflow:hidden;
  border:1px solid #e6e6e6;
  box-shadow:0 20px 48px rgba(0,0,0,.08);
  transition:.28s ease;
  min-height:340px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}

.gallery-card:hover{
  transform:translateY(-8px);
  box-shadow:0 28px 60px rgba(0,0,0,.12);
}

.gallery-card img{
  width:100%;
  height:100%;
  max-height:300px;
  object-fit:contain;
}

@media(max-width:980px){
  .product-gallery-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media(max-width:640px){
  .product-gallery-grid{
    grid-template-columns:1fr;
  }
}


/* =========================================================
   GALERIAS INLINE + LIGHTBOX
   ========================================================= */

.product-gallery-section{
  display:none !important;
}

.inline-gallery{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:10px;
  margin:24px 0 4px;
}

.thumb{
  aspect-ratio:1/1;
  border:1px solid #e1e1e1;
  background:#fff;
  border-radius:14px;
  padding:6px;
  cursor:pointer;
  overflow:hidden;
  transition:.22s ease;
}

.thumb:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 24px rgba(0,0,0,.10);
  border-color:#111;
}

.thumb img{
  width:100%;
  height:100%;
  object-fit:contain;
}

.lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  background:rgba(0,0,0,.88);
  display:none;
  align-items:center;
  justify-content:center;
  padding:30px;
}

.lightbox.active{
  display:flex;
}

.lightbox-content{
  max-width:min(980px,86vw);
  max-height:86vh;
  display:grid;
  gap:14px;
  justify-items:center;
}

.lightbox-content img{
  max-width:100%;
  max-height:78vh;
  object-fit:contain;
  background:#fff;
  border-radius:18px;
  padding:16px;
  box-shadow:0 26px 80px rgba(0,0,0,.5);
}

.lightbox-caption{
  color:#fff;
  font-size:14px;
  text-align:center;
  opacity:.82;
}

.lightbox-close,
.lightbox-arrow{
  position:absolute;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:#fff;
  cursor:pointer;
  transition:.22s ease;
}

.lightbox-close{
  top:24px;
  right:24px;
  width:48px;
  height:48px;
  border-radius:50%;
  font-size:34px;
  line-height:1;
}

.lightbox-arrow{
  top:50%;
  transform:translateY(-50%);
  width:56px;
  height:72px;
  border-radius:18px;
  font-size:54px;
  line-height:1;
}

.lightbox-prev{
  left:26px;
}

.lightbox-next{
  right:26px;
}

.lightbox-close:hover,
.lightbox-arrow:hover{
  background:#fff;
  color:#000;
}

/* Certificações mais discretas */
.cert-premium{
  background:#0b0b0b !important;
  padding:82px 0 !important;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.cert-premium::before{
  display:none !important;
}

.cert-premium .section-tag{
  background:transparent !important;
  border:0 !important;
  padding:0 !important;
}

.cert-premium h2{
  font-size:clamp(32px,4vw,50px) !important;
  line-height:1.08 !important;
  max-width:780px;
}

.cert-premium .client-intro{
  font-size:16px !important;
  color:#aaa !important;
}

.cert-grid{
  margin-top:34px !important;
}

.cert-grid article{
  min-height:auto !important;
  padding:28px !important;
  border-radius:24px !important;
  background:rgba(255,255,255,.045) !important;
  border:1px solid rgba(255,255,255,.09) !important;
  box-shadow:none !important;
}

.cert-grid article::before,
.cert-grid article::after{
  display:none !important;
}

.cert-grid h3{
  font-size:22px !important;
  max-width:none !important;
  margin-bottom:10px !important;
}

.cert-grid p{
  font-size:15px !important;
  color:#a8a8a8 !important;
}

@media(max-width:980px){
  .inline-gallery{
    grid-template-columns:repeat(4,1fr);
  }
}

@media(max-width:680px){
  .inline-gallery{
    grid-template-columns:repeat(3,1fr);
  }

  .lightbox{
    padding:18px;
  }

  .lightbox-arrow{
    width:44px;
    height:58px;
    font-size:42px;
  }

  .lightbox-prev{
    left:10px;
  }

  .lightbox-next{
    right:10px;
  }

  .lightbox-close{
    top:12px;
    right:12px;
  }
}


/* =========================================================
   AJUSTES SOLICITADOS - LOGO, CLIENTES, TÍTULOS E LIGHTBOX
   ========================================================= */

/* Header/Footer com logo preto mais discreto */
.brand{
  background:#fff !important;
  padding:4px 8px !important;
  border-radius:10px !important;
}

.brand img{
  width:132px !important;
  height:auto !important;
  object-fit:contain !important;
}

.footer img{
  width:150px !important;
  background:#fff !important;
  padding:6px 9px !important;
  border-radius:10px !important;
  object-fit:contain !important;
}

/* Títulos levemente menores para melhorar equilíbrio visual */
.hero h1{
  font-size:clamp(40px,5.6vw,76px) !important;
  line-height:1.02 !important;
}

.page-hero h1{
  font-size:clamp(38px,5.2vw,68px) !important;
  line-height:1.03 !important;
}

.about h2,
.services h2,
.clients h2,
.contact h2,
.cert-premium h2,
.product-category-title h2,
.gallery-header h2{
  font-size:clamp(30px,3.8vw,48px) !important;
  line-height:1.08 !important;
}

.product-row h2{
  font-size:clamp(28px,3.3vw,42px) !important;
  line-height:1.1 !important;
}

/* Clientes: logos menores para não estourarem os cards */
.client-logo{
  overflow:hidden !important;
  height:165px !important;
  padding:20px !important;
  border-radius:26px !important;
}

.client-logo img{
  width:92% !important;
  height:92% !important;
  max-height:125px !important;
  object-fit:contain !important;
  transform:scale(1) !important;
}

.client-logo:hover img{
  transform:scale(1.06) !important;
}

/* Miniaturas como links, mantendo visual de botão */
.inline-gallery{
  display:grid !important;
  grid-template-columns:repeat(6,1fr);
  gap:10px;
  margin:24px 0 6px;
}

.inline-gallery .thumb{
  display:block;
  aspect-ratio:1/1;
  border:1px solid #ddd;
  background:#fff;
  border-radius:14px;
  padding:6px;
  overflow:hidden;
  cursor:pointer;
  transition:.22s ease;
}

.inline-gallery .thumb:hover{
  transform:translateY(-3px);
  border-color:#111;
  box-shadow:0 10px 24px rgba(0,0,0,.10);
}

.inline-gallery .thumb img{
  width:100%;
  height:100%;
  object-fit:contain;
}

/* Lightbox robusto */
.lightbox{
  position:fixed !important;
  inset:0 !important;
  z-index:99999 !important;
  background:rgba(0,0,0,.90) !important;
  display:none !important;
  align-items:center !important;
  justify-content:center !important;
  padding:28px !important;
}

.lightbox.active{
  display:flex !important;
}

.lightbox-content{
  max-width:min(980px,86vw) !important;
  max-height:86vh !important;
  margin:0 !important;
  display:grid !important;
  gap:12px !important;
  justify-items:center !important;
}

.lightbox-content img{
  max-width:100% !important;
  max-height:78vh !important;
  object-fit:contain !important;
  background:#fff !important;
  border-radius:18px !important;
  padding:16px !important;
  box-shadow:0 28px 80px rgba(0,0,0,.55) !important;
}

.lightbox-caption{
  color:#fff !important;
  font-size:14px !important;
  text-align:center !important;
  opacity:.84 !important;
}

.lightbox-close,
.lightbox-arrow{
  position:absolute !important;
  border:1px solid rgba(255,255,255,.20) !important;
  background:rgba(255,255,255,.12) !important;
  color:#fff !important;
  cursor:pointer !important;
  z-index:100000 !important;
  transition:.22s ease !important;
}

.lightbox-close{
  top:22px !important;
  right:22px !important;
  width:50px !important;
  height:50px !important;
  border-radius:50% !important;
  font-size:34px !important;
  line-height:1 !important;
}

.lightbox-arrow{
  top:50% !important;
  transform:translateY(-50%) !important;
  width:58px !important;
  height:74px !important;
  border-radius:18px !important;
  font-size:54px !important;
  line-height:1 !important;
}

.lightbox-prev{left:24px !important;}
.lightbox-next{right:24px !important;}

.lightbox-close:hover,
.lightbox-arrow:hover{
  background:#fff !important;
  color:#000 !important;
}

/* Certificações ainda mais discretas */
.cert-premium{
  padding:68px 0 !important;
}

.cert-grid article{
  padding:24px !important;
  border-radius:20px !important;
}

.cert-grid h3{
  font-size:20px !important;
}

@media(max-width:980px){
  .inline-gallery{
    grid-template-columns:repeat(4,1fr);
  }
}

@media(max-width:680px){
  .brand img{width:118px !important;}
  .footer img{width:136px !important;}

  .client-logo{
    height:145px !important;
    padding:18px !important;
  }

  .inline-gallery{
    grid-template-columns:repeat(3,1fr);
  }

  .lightbox{
    padding:16px !important;
  }

  .lightbox-arrow{
    width:44px !important;
    height:58px !important;
    font-size:42px !important;
  }

  .lightbox-prev{left:8px !important;}
  .lightbox-next{right:8px !important;}
  .lightbox-close{top:10px !important;right:10px !important;}
}


/* =========================================================
   FOTO EM DESTAQUE NOS PRODUTOS + REDES ATUALIZADAS
   ========================================================= */

.product-visual.product-photo{
  background:#fff !important;
  border:1px solid #e3e3e3;
  padding:26px;
  min-height:360px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.02);
}

.product-visual.product-photo::after{
  display:none !important;
}

.product-visual.product-photo img{
  width:100%;
  height:100%;
  max-height:330px;
  object-fit:contain;
  border-radius:18px;
  transition:.25s ease;
}

.product-visual.product-photo:hover img{
  transform:scale(1.04);
}

@media(max-width:680px){
  .product-visual.product-photo{
    min-height:260px;
    padding:18px;
  }

  .product-visual.product-photo img{
    max-height:240px;
  }
}

/* Logo branco e acrônimo TORFER */
.brand{background:transparent!important;padding:0!important;border-radius:0!important;box-shadow:none!important}
.brand img{width:150px!important;height:auto!important;object-fit:contain!important}
.footer img{width:170px!important;background:transparent!important;padding:0!important;border-radius:0!important;object-fit:contain!important}
.torfer-acronym{background:#080808!important;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.torfer-acronym-grid{display:grid!important;grid-template-columns:repeat(6,1fr)!important}
.torfer-acronym-grid div{min-height:112px;padding:24px 14px!important;border-left:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.torfer-acronym-grid strong{font-size:34px!important;line-height:1;color:#fff;margin-bottom:10px}
.torfer-acronym-grid span{color:#cfcfcf;font-size:11px!important;line-height:1.35;text-transform:uppercase;letter-spacing:.11em!important;font-weight:900}
@media(max-width:980px){.torfer-acronym-grid{grid-template-columns:repeat(3,1fr)!important}}
@media(max-width:620px){.brand img{width:128px!important}.footer img{width:145px!important}.torfer-acronym-grid{grid-template-columns:repeat(2,1fr)!important}.torfer-acronym-grid div{min-height:96px;padding:20px 10px!important}.torfer-acronym-grid strong{font-size:30px!important}.torfer-acronym-grid span{font-size:10px!important;letter-spacing:.08em!important}}


/* =========================================================
   AJUSTES EDITORIAIS: TÍTULOS, ALINHAMENTO E LEITURA
   ========================================================= */

.hero-copy,
.section-header,
.product-category-title,
.gallery-header,
.clients-head,
.sticky-title,
.content-panel,
.editorial-text,
.product-row > div,
.contact-box > div,
.legal-box{
  text-align:left;
}

.section-header.center,
.center,
.center-action{
  text-align:center;
}

p,
li{
  text-wrap:pretty;
}

.hero p,
.page-hero p,
.about p,
.editorial-text p,
.product-row p,
.contact p,
.legal-box p{
  max-width:680px;
}

h1,
h2,
h3{
  text-wrap:balance;
}

.product-row{
  align-items:center !important;
}

.product-row ul{
  margin-top:18px;
}

.inline-gallery{
  justify-content:start;
}

.torfer-acronym-grid div{
  text-align:center !important;
}

.clients .section-header,
.client-intro{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}

.service-grid article,.cert-grid article{text-align:center;}
.service-grid article span{display:block;margin-bottom:18px;}


/* ===== AJUSTE GLOBAL DE CENTRALIZAÇÃO TORFER ===== */

.section-title,
.section-subtitle,
.hero-content,
.hero-content p,
.hero-content h1,
.hero-content h2,
.hero-content h3,
.about-content,
.about-content p,
.about-content h2,
.about-content h3,
.products-intro,
.products-intro p,
.products-intro h2,
.contact-content,
.contact-content p,
.contact-content h2,
.cta-section,
.cta-section p,
.cta-section h2,
footer,
footer p,
footer h3,
.stats-grid,
.card-content,
.card-content p,
.card-content h3,
.content-center,
.text-block,
.text-block p,
.text-block h2,
.text-block h3 {
    text-align: center;
}

/* Centralização de botões e grids */
.hero-buttons,
.cta-buttons,
.social-links,
.stats-grid {
    justify-content: center;
}

/* Melhor equilíbrio visual */
.section-title {
    margin-left: auto;
    margin-right: auto;
}

.section-subtitle,
.text-block p,
.about-content p,
.products-intro p,
.contact-content p {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
}

/* Mobile refinado */
@media (max-width: 768px) {
    .hero-content,
    .about-content,
    .products-intro,
    .contact-content,
    .card-content {
        text-align: center;
    }
}


/* ===== AJUSTE PONTUAL: HERO CONTATO CENTRALIZADO ===== */
.contato-page .hero,
.contato-page .hero-content,
.contato-page .page-hero,
.contato-page .page-hero .container,
.contato-page .hero .container {
    text-align: center !important;
    align-items: center !important;
    justify-content: center !important;
}

.contato-page .hero span,
.contato-page .hero p,
.contato-page .hero h1,
.contato-page .hero h2,
.contato-page .page-hero span,
.contato-page .page-hero p,
.contato-page .page-hero h1,
.contato-page .page-hero h2,
.contato-page .hero-content span,
.contato-page .hero-content p,
.contato-page .hero-content h1,
.contato-page .hero-content h2 {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.contato-page .hero .btn-group,
.contato-page .hero-buttons,
.contato-page .page-hero .btn-group,
.contato-page .page-hero .hero-buttons {
    justify-content: center !important;
}


/* ===== AJUSTE PONTUAL: HEROS CENTRALIZADOS EMPRESA / SERVIÇOS / CONTATO ===== */

.empresa-page .hero,
.empresa-page .hero-content,
.empresa-page .page-hero,
.empresa-page .page-hero .container,
.empresa-page .hero .container,
.servicos-page .hero,
.servicos-page .hero-content,
.servicos-page .page-hero,
.servicos-page .page-hero .container,
.servicos-page .hero .container,
.contato-page .hero,
.contato-page .hero-content,
.contato-page .page-hero,
.contato-page .page-hero .container,
.contato-page .hero .container {
    text-align: center !important;
    align-items: center !important;
    justify-content: center !important;
}

.empresa-page .hero span,
.empresa-page .hero p,
.empresa-page .hero h1,
.empresa-page .hero h2,
.empresa-page .hero-content span,
.empresa-page .hero-content p,
.empresa-page .hero-content h1,
.empresa-page .hero-content h2,
.empresa-page .page-hero span,
.empresa-page .page-hero p,
.empresa-page .page-hero h1,
.empresa-page .page-hero h2,
.servicos-page .hero span,
.servicos-page .hero p,
.servicos-page .hero h1,
.servicos-page .hero h2,
.servicos-page .hero-content span,
.servicos-page .hero-content p,
.servicos-page .hero-content h1,
.servicos-page .hero-content h2,
.servicos-page .page-hero span,
.servicos-page .page-hero p,
.servicos-page .page-hero h1,
.servicos-page .page-hero h2,
.contato-page .hero span,
.contato-page .hero p,
.contato-page .hero h1,
.contato-page .hero h2,
.contato-page .hero-content span,
.contato-page .hero-content p,
.contato-page .hero-content h1,
.contato-page .hero-content h2,
.contato-page .page-hero span,
.contato-page .page-hero p,
.contato-page .page-hero h1,
.contato-page .page-hero h2 {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.empresa-page .hero .btn-group,
.empresa-page .hero-buttons,
.empresa-page .page-hero .btn-group,
.empresa-page .page-hero .hero-buttons,
.servicos-page .hero .btn-group,
.servicos-page .hero-buttons,
.servicos-page .page-hero .btn-group,
.servicos-page .page-hero .hero-buttons,
.contato-page .hero .btn-group,
.contato-page .hero-buttons,
.contato-page .page-hero .btn-group,
.contato-page .page-hero .hero-buttons {
    justify-content: center !important;
}


/* ===== AJUSTE PONTUAL: HEROS CENTRALIZADOS PRODUTOS / CLIENTES ===== */

.produtos-page .hero,
.produtos-page .hero-content,
.produtos-page .page-hero,
.produtos-page .page-hero .container,
.produtos-page .hero .container,
.clientes-page .hero,
.clientes-page .hero-content,
.clientes-page .page-hero,
.clientes-page .page-hero .container,
.clientes-page .hero .container {
    text-align: center !important;
    align-items: center !important;
    justify-content: center !important;
}

.produtos-page .hero span,
.produtos-page .hero p,
.produtos-page .hero h1,
.produtos-page .hero h2,
.produtos-page .hero-content span,
.produtos-page .hero-content p,
.produtos-page .hero-content h1,
.produtos-page .hero-content h2,
.produtos-page .page-hero span,
.produtos-page .page-hero p,
.produtos-page .page-hero h1,
.produtos-page .page-hero h2,
.clientes-page .hero span,
.clientes-page .hero p,
.clientes-page .hero h1,
.clientes-page .hero h2,
.clientes-page .hero-content span,
.clientes-page .hero-content p,
.clientes-page .hero-content h1,
.clientes-page .hero-content h2,
.clientes-page .page-hero span,
.clientes-page .page-hero p,
.clientes-page .page-hero h1,
.clientes-page .page-hero h2 {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.produtos-page .hero .btn-group,
.produtos-page .hero-buttons,
.produtos-page .page-hero .btn-group,
.produtos-page .page-hero .hero-buttons,
.clientes-page .hero .btn-group,
.clientes-page .hero-buttons,
.clientes-page .page-hero .btn-group,
.clientes-page .page-hero .hero-buttons {
    justify-content: center !important;
}


/* ===== EMPRESA: CENTRALIZAR APENAS CARDS MISSÃO / VISÃO / VALORES ===== */

.empresa-page .mission-card,
.empresa-page .vision-card,
.empresa-page .values-card,
.empresa-page .mission-card *,
.empresa-page .vision-card *,
.empresa-page .values-card * {
    text-align: center !important;
}

.empresa-page .mission-card p,
.empresa-page .vision-card p,
.empresa-page .values-card p {
    margin-left: auto !important;
    margin-right: auto !important;
}


/* CENTRALIZAÇÃO DOS CARDS DE SERVIÇOS */
.info-card{
    text-align:center;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
}

.info-card h3,
.info-card p{
    text-align:center;
}

.info-card p{
    max-width:320px;
    margin-left:auto;
    margin-right:auto;
}

