/* === EPOXIRAL – BASE + HERO/COMPARADOR + PRODUTO === */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;700&display=swap');

:root{
  --black: #373435;
  --white: #fff;
  --orange: #0580a1;
  --header-h: 120px; /* atualizado via JS */
  --hero-mobile-h: 60svh; /* pode trocar via hero--h80/90/100 */
}

/* Reset / Base */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video{
  scroll-behavior: smooth;
  margin:0; padding:0; border:0;
  font-size:100%; font:inherit; vertical-align:baseline;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section{ display:block; }
html{ height:100vh; }
body{
  font-family:'Montserrat', sans-serif;
  font-size:62.5%;
  background-color:var(--white);
  color:var(--orange);
  line-height:1;
  height:100vh;
}
ol, ul{ list-style:none; }
table{ border-collapse:collapse; border-spacing:0; }
*{ padding:0; margin:0; vertical-align:baseline; list-style:none; border:0 }

/* Tipografia */
h1{font-size:2.6em}
h2{font-size:2.4em}
h3{font-size:2.2em}
b{font-weight:bold}
p{line-height:2; font-size:1.4em}
a{color:var(--black); text-decoration:none; font-size:1.4em}
a:hover{text-decoration:underline}
span{font-size:1.6em}
input,textarea{font-family:'Montserrat', sans-serif}
button{cursor:pointer}

/* Helpers */
.no-margin{margin:0!important}
.no-padding{padding:0!important}
.center{text-align:center!important; margin:0 auto!important}
.full-width{width:100%!important}
.bold{font-weight:bold!important}
.text-shadow{text-shadow:1px 1px 2px #000}
.shadow{ box-shadow:0 1px 10px 0 rgba(0,0,0,.75); }

/* ===== HERO + COMPARADOR ===== */
.hero--compare{
  position:relative;
  padding: calc(var(--header-h, 120px) + 10px) 0 40px;
  min-height:70vh;
  overflow:hidden;
}
@media (max-width:768px){
  .hero--compare{ padding: calc(var(--header-h, 100px) + 0px) 0 24px; min-height:var(--hero-mobile-h); }

}
.hero__bg{ position:absolute; inset:0; z-index:1; }

/* Scrim externo desligado (scrim é interno ao comparador) */
.hero__scrim{ display:none !important; }

/* Comparador com scrim interno */
.comparador-hero{
  position:absolute; inset:0;
  width:100%; height:100%;
  overflow:hidden;
  z-index:1;
  touch-action: pan-y;      /* rola vertical quando não arrastando */
  -webkit-user-select:none;
  user-select:none;
}
.comparador-hero img{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover; object-position:center;
  user-select:none; pointer-events:none; z-index:1;
}
.comparador-hero .depois{ clip-path: inset(0 50% 0 0); }
.comparador-hero::after{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:2;
  background: linear-gradient(90deg,
    rgba(0,89,100,0.85) 0%,
    rgba(0,89,100,0.55) 35%,
    rgba(0,89,100,0.00) 65%);
}
.comparador-hero .linha{
  position:absolute; top:0; bottom:0; left:50%; transform:translateX(-50%);
  width:2px; background:#fff; z-index:3; pointer-events:none;
}
.comparador-hero .controle{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:42px; height:42px; background:#fff; border-radius:50%;
  display:flex; align-items:center; justify-content:center; cursor:ew-resize;
  box-shadow:0 6px 14px rgba(0,0,0,.25); z-index:3;
  touch-action: none; /* knob captura o gesto */
}
.comparador-hero .controle svg{ width:20px; height:20px; stroke:#0b3040; }

/* Conteúdo do hero (não bloqueia o knob) */
.hero__container{
  position:relative; z-index:7;
  pointer-events:none;                /* libera clique para o knob por baixo */
}
.hero__container a,
.hero__container button,
.hero__container .btn-hero,
.hero__container .badge,
.hero__container .badge2{ pointer-events:auto; } /* reativa interação só nos elementos clicáveis */

.hero__title{ font-size:clamp(28px,3.2vw,44px); color:#fff; line-height:1.1; margin:0 0 10px; }
.hero__title span{ color:#9ef0ff; font-weight: bold; }
.hero__sub{ color:#e6f7fb; font-size:clamp(16px,1.6vw,19px); margin:0 0 16px; max-width:52ch; }
.hero__badges{ display:flex; flex-wrap:wrap; gap:8px 10px; margin:12px 0 18px; }
.badge{ background:rgba(255,255,255,.14); color:#fff; border:1px solid rgba(255,255,255,.25); padding:6px 10px; border-radius:999px; font-size:13px; font-weight:700; letter-spacing:.2px; }
.badge2{ background:#0580a1; color:#fff; border:1px solid rgba(255,255,255,.25); padding:6px 10px; border-radius:999px; font-size:13px; font-weight:700; letter-spacing:.2px; }
.hero__ctas{ display:flex; gap:10px; flex-wrap:wrap; }
.btn-hero{ display:inline-block; padding:12px 16px; border-radius:12px; text-decoration:none; font-weight:800; box-shadow:0 8px 20px rgba(0,0,0,.2); transition:transform .15s ease, background .2s; }
.btn-hero--primary{ background:#00a5d9; color:#0b3040; }
.btn-hero--primary:hover{ transform:translateY(-1px); }
.btn-hero--ghost{ background:transparent; color:#fff; border:2px solid rgba(255,255,255,.65); }
.btn-hero--ghost:hover{ background:rgba(255,255,255,.12); }

/* Botões de troca (logo abaixo do hero) */
.botoes-position{ margin: 12px 0 0; }
.botoes-position .shadow{ background:#0b3040; color:#fff; border:1px solid rgba(255,255,255,.25); padding:10px 12px; border-radius:10px; }

/* ===== KPIs (antigo) – fundo cinza escuro ===== */
.bg-blackgrey{ background:#242424; color:#fff; padding:10px 0 }
.bg-blackgrey h4{ font-size:45px; font-weight:bold; text-align:center; color:#0580a1 }
.bg-blackgrey p{ font-size:20px; text-align:center; color:#fff; font-weight:bold }

/* ===== Produtos / cards (SERVIÇOS) – NOVO HOVER ===== */
.produtos{ background:#0580a1; color:#fff; text-align:center; padding:10px 0; margin:15px 0 }
.produtos h2{ font-size:25px; font-weight:bold }
.produtos h3{ font-size:20px; font-weight:bold }
.produtos .card{ border:2px solid #0580a1; border-radius:20px }

/* Base visual do card mantendo a mesma altura (via padding original) */
.produtos .card-inside{
  position:relative;
  border:1px solid #fff;
  padding:8px 0;                 /* mantém a sua altura visual */
  border-radius:10px;
  box-shadow:4px 4px 8px rgba(0,0,0,.808);
  text-align:center;
  overflow:hidden;

  background-size:cover;         /* definido pelas classes dos serviços */
  background-position:center;
  transition:filter .25s ease, transform .25s ease;
}

/* Overlay escuro por padrão (imagem “escurecida”) */
.produtos .card-inside::before{
  content:"";
  position:absolute; inset:0;
  background:rgba(0,0,0,.38);
  transition:opacity .25s ease, background .25s ease;
  z-index:0;
}

/* Conteúdo acima do overlay */
.produtos .card-inside h3{
  position:relative; z-index:1;
  color:#fff; text-shadow:0 1px 2px rgba(0,0,0,.35);
}

/* Botão escondido inicialmente */
.produtos .card-inside .btn-saiba-mais{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  background:#0580a1; color:#fff; padding:8px 16px; border-radius:20px; font-weight:bold;
  text-decoration:none; opacity:0; z-index:1;
  transition: opacity .25s ease, transform .25s ease, background .2s ease;
}

/* Esconde o <img> antigo sem mexer no HTML */
.produtos .card-inside > img{ display:none !important; }

/* HOVER: clareia a imagem e revela o botão */
.produtos .card-inside:hover::before{ background:rgba(0,0,0,.15); }
.produtos .card-inside:hover .btn-saiba-mais{
  opacity:1; transform:translate(-50%,-50%) translateY(-2px);
}

/* Foco acessível */
.produtos .card-inside:focus-within{ outline:3px solid #00a5d9; outline-offset:2px; }

/* Classes por serviço — aplique no wrapper .card (ex.: .card card--aplicacao) */
.card--aplicacao   .card-inside{ background-image:url('../imagens/servicos/aplicacao.jpg'); }
.card--rodapes     .card-inside{ background-image:url('../imagens/servicos/rodapes.jpg'); }
.card--junta       .card-inside{ background-image:url('../imagens/servicos/junta.jpg'); }
.card--descontam   .card-inside{ background-image:url('../imagens/servicos/descontaminacao.jpg'); }
.card--preparacao  .card-inside{ background-image:url('../imagens/servicos/preparacao.jpg'); }
.card--ralos       .card-inside{ background-image:url('../imagens/servicos/ralos.jpg'); }

/* ==== Projetos (Splide thumbs) ==== */
.thumbnails{ display:flex; margin:1rem auto 0; padding:0; justify-content:center }
.thumbnail{
  width:70px; height:70px; overflow:hidden; list-style:none;
  margin:0 .2rem; cursor:pointer; border:5px solid #0580a1; border-radius:15px;
}
.thumbnail img{ width:100% }
#main-carousel img{ box-sizing:border-box; border:5px solid #0580a1; border-radius:30px; width:100%; }

/* ==== Form ==== */
.bg-form{ background:#242424; color:#fff; padding:50px 0 }
.bg-form h3{ font-size:40px; font-weight:bold; padding-bottom:15px; text-align:center }
.bg-form h5{ font-size:25px; font-weight:200; padding-bottom:5px; text-align:center }
.bg-form li{ font-size:20px; line-height:2em }
.bg-form span{ font-size:20px; color:#00a5d9; padding-right:8px }
.bg-form img{ border:3px solid #00a5d9; border-radius:5px }

form{ background:#1e1e1e; padding:25px 30px; border-radius:8px; max-width:100%; box-shadow:0 0 10px #0580a1aa; }
label{ display:block; margin-bottom:6px; font-weight:600; color:#ffffffcc; font-size:18px }
input[type="text"], input[type="email"], input[type="tel"], select, textarea{
  width:90%; padding:10px 12px; margin-bottom:18px; border:2px solid #0580a1;
  border-radius:5px; background:#121212; color:#fff; font-size:1rem; transition:border-color .3s ease;
}
input[type="text"]:focus, input[type="email"]:focus, input[type="tel"]:focus, select:focus, textarea:focus{ border-color:#00c1ff; outline:none; }
textarea{ width:95%; resize:vertical }
button{ background:#0580a1; color:#fff; border:none; padding:12px 25px; font-size:1.1rem; font-weight:700; border-radius:5px; cursor:pointer; width:100%; transition:background-color .3s ease; }
button:hover{ background:#00a5d9 }

/* ===== Navegação / header ===== */
.menu-fixo{ position:fixed; top:0; left:0; width:100%; z-index:9999 }
header{ background:#fff; padding:0; position:relative; z-index:1000 }
.logo img{ width:50% }
nav{ align-items:end; position:relative; }
nav ul{ display:flex; gap:20px; justify-content:end; }
nav ul li a{ text-decoration:none; color:#fff; font-weight:bold; transition:color .3s ease }
nav ul li a:hover{ color:#000 }

/* Hambúrguer */
.menu-toggle{
  display:none; align-items:center; justify-content:center;
  width:44px; height:44px; background:transparent; border:0; padding:0; cursor:pointer;
}

/* MOBILE */
@media (max-width:768px){
  button{ font-size: 1.2em; }
  nav{ position:relative; min-height:44px; }
  .menu-toggle{
    display:inline-flex;
    position:absolute; right:0; top:50%;
    transform:translateY(-50%); z-index:2100;
  }
  nav ul{
    position:fixed; top:70px; right:0; background:#0580a1;
    flex-direction:column; width:220px; padding:20px; gap:15px;
    border-left:1px solid #0580a1; box-shadow:-2px 0 8px rgba(0,0,0,0.1);
    transform:translateX(100%); opacity:0; pointer-events:none;
    transition:transform .35s ease, opacity .35s ease;
    display:flex; z-index:2000;
  }
  nav ul.show{ transform:translateX(0); opacity:1; pointer-events:auto; }
  nav ul li a{ color:#fff; }
  .logo img{ width:150%; }
}
@media (min-width:769px){ .menu-toggle{ display:none !important; } }

/* Top bar */
.contact-header{ background:#242424; color:#fff }
.contact-header li{ display:inline; font-size:15px; font-weight:bold }
.contact-header span{ font-size:14px; padding:2px }

/* IcoMoon */
@font-face{
  font-family: 'icomoon';
  src: url('../fonts/icomoon.eot');
  src: url('../fonts/icomoon.eot?#iefix') format('embedded-opentype'),
       url('../fonts/icomoon.woff2') format('woff2'),
       url('../fonts/icomoon.woff')  format('woff'),
       url('../fonts/icomoon.ttf')   format('truetype'),
       url('../fonts/icomoon.svg#icomoon') format('svg');
  font-weight: normal; font-style: normal; font-display: swap;
}
[class^="icon-"], [class*=" icon-"]{
  font-family:'icomoon' !important; speak:never; font-style:normal; font-weight:normal;
  font-variant:normal; text-transform:none; line-height:1; display:inline-block;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
.icon-home:before{content:"\e900"} .icon-phone:before{content:"\e942"} .icon-envelop:before{content:"\e945"}
.icon-location:before{content:"\e947"} .icon-history:before{content:"\e94d"} .icon-clock:before{content:"\e94e"}
.icon-mail4:before{content:"\ea86"} .icon-facebook2:before{content:"\ea91"} .icon-instagram:before{content:"\ea92"}
.icon-whatsapp:before{content:"\ea93"} .icon-linkedin:before{content:"\eac9"} .icon-menu:before{content:"\e9bd"} .icon-cross:before{content:"\ea0f"}
.contact-header [class^="icon-"], .contact-header [class*=" icon-"]{ color:#fff; font-size:16px; }
.bg-form [class^="icon-"], .bg-form [class*=" icon-"]{ color:#00a5d9; font-size:20px; }

/* Legenda do infográfico */
.legend-cores{ margin: 8px 0 0; padding: 0; }
.cut3d-title{ font-size: 32px; font-weight: bold; }
.legend-cores li{
  list-style:none; position:relative; padding-left:22px; margin:6px 0;
  font-size:2.2em; color:#066e86; font-weight:bold;
}
.legend-cores li::before{
  content:""; position:absolute; left:0; top:.55em; width:10px; height:10px; border-radius:50%;
  background:var(--dot,#a8b3bc);
  box-shadow:0 0 0 3px #e9eef2 inset, 0 0 10px color-mix(in srgb, var(--dot) 60%, transparent);
}
.legend-cores .nota{ margin-top:10px; font-size:1.05em; color:#7a8a95; }
.legend-cores .nota::before{ display:none; }

/* Fade-in */
.fade-in{ opacity:0; transform:translateX(-20px); transition:opacity .6s ease-out, transform .6s ease-out; will-change:opacity, transform }
.fade-in.visible{ opacity:1; transform:translateY(0) }

/* Sticky CTA */
.sticky-cta{
  position:fixed; left:50%; bottom:14px; transform:translateX(-50%);
  display:flex; gap:10px; align-items:center;
  background:#0b3040; color:#fff; padding:10px 14px; border-radius:999px;
  box-shadow:0 8px 24px rgba(0,0,0,.25); opacity:0; pointer-events:none; transition:.3s;
}
.sticky-cta .btn{background:#25D366;color:#0b3040;font-weight:700;padding:8px 12px;border-radius:999px;text-decoration:none}
.sticky-cta .btn-alt{background:#fff;color:#0b3040}
.sticky-cta.is-visible{opacity:1;pointer-events:auto}

/* Durante arraste */
body.is-dragging{ user-select:none; }

/* Ancoragem suave com header fixo */
section[id], .site-footer[id]{ scroll-margin-top: var(--header-h, 120px); }

/* Alturas pré-definidas no mobile */
@media (max-width:768px){
/*   .hero--compare .comparador-hero{ height: var(--hero-mobile-h); } */
  .sticky-cta{ width: 90%; }
}
.hero--h80  { --hero-mobile-h: 80svh; }
.hero--h90  { --hero-mobile-h: 90svh; }
.hero--h100 { --hero-mobile-h: 100svh; }

/* ===== Footer ===== */
.site-footer{
  background: linear-gradient(180deg, #0b3040 0%, #06212a 100%);
  color:#e6f7fb; padding:48px 0 24px;
}
.site-footer a{ color:#9ee6ff; text-decoration:none; }
.site-footer a:hover{ text-decoration:underline; }
.site-footer h4{ font-size:1.6em; margin:0 0 10px; color:#c7f2ff; font-weight:800; }
.footer-brand img{ max-width:180px; height:auto; display:block; margin-bottom:12px; }
.footer-brand p{ color:#c7d8df; line-height:1.7; font-size:1.3em; max-width:46ch; }
.footer-links ul li{ margin:6px 0; }
.footer-links a{ font-size:1.3em; }
.footer-contact ul li{ display:flex; gap:10px; align-items:flex-start; margin:8px 0; line-height:1.6; font-size:1.3em; color:#d2e6ee; }
.footer-contact ul li span[class^="icon-"]{ color:#00a5d9; font-size:1.2em; line-height:1.2em; margin-top:2px; }
.footer-social{ margin-top:12px; }
.footer-social a{ display:inline-flex; width:38px; height:38px; border-radius:999px; align-items:center; justify-content:center; background:rgba(255,255,255,.12); margin-right:8px; transition:transform .15s ease, background .2s; }
.footer-social a:hover{ background:rgba(255,255,255,.22); transform:translateY(-1px); }
.footer-social span[class^="icon-"]{ color:#e6f7fb; font-size:18px; }
.footer-divider{ height:1px; background:linear-gradient(90deg, transparent, rgba(255,255,255,.2), transparent); margin:22px 0; }
.footer-bottom{ color:#b6cad1; font-size:1.2em; }
.footer-bottom small{ color:#91a9b3; }
@media (max-width:768px){
  .footer-brand p{ font-size:1.25em; }
  .footer-bottom{ text-align:center; }
  .footer-bottom .a-right{ text-align:center !important; margin-top:8px; }
}

/* ===== Páginas de produto (hero / cards / faq) – já padronizado ===== */
.product-hero{
  position:relative;
  padding: calc(var(--header-h, 120px) + 24px) 0 32px;
  background:
    radial-gradient(1200px 380px at 0% 0%, rgba(0,165,217,.22) 0%, rgba(0,165,217,0) 60%),
    linear-gradient(180deg, #0b3040 0%, #0b3040 40%, #0e3f52 100%);
  color:#fff; overflow:hidden;
}
.product-hero__chip{ display:inline-block; font-weight:800; letter-spacing:.2px; padding:6px 12px; border-radius:999px; background:#0580a1; color:#fff; border:1px solid rgba(255,255,255,.25); }
.product-hero__title{ margin:12px 0 6px; font-weight:800; font-size:clamp(24px, 3.2vw, 38px); line-height:1.15; }
.product-hero__sub{ max-width:70ch; color:#d7f1fa; font-size:clamp(14px, 1.6vw, 18px); margin-bottom:14px; }
.product-hero__badges{ display:flex; flex-wrap:wrap; gap:8px 10px; margin:12px 0 18px; padding:0; }
.product-hero__badges li{ list-style:none; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.25); color:#fff; font-weight:700; letter-spacing:.2px; padding:6px 10px; border-radius:999px; font-size:13px; }
.product-hero__ctas{ display:flex; gap:10px; flex-wrap:wrap; }
.btnP{ display:inline-block; padding:12px 16px; border-radius:12px; text-decoration:none; font-weight:800; box-shadow:0 8px 20px rgba(0,0,0,.2); transition:transform .15s ease, background .2s, color .2s, border-color .2s; }
.btnP--primary{ background:#0580a1; color:#fff; }
.btnP--primary:hover{ transform:translateY(-1px); background:#00a5d9; }
.btnP--ghost{ background:transparent; color:#fff; border:2px solid rgba(255,255,255,.65); }
.btnP--ghost:hover{ background:rgba(255,255,255,.12); }
.product-benefits{ padding: clamp(24px, 5vw, 48px) 0; }
.product-benefits__title{ margin:0 0 6px; text-align:center; font-weight:800; font-size: clamp(22px, 3.2vw, 32px); color:#0b3040; }
.product-benefits__lead{ text-align:center; color:#5b6b73; margin:0 0 20px; font-size: clamp(14px, 1.6vw, 18px); }
.h-100{ height:100%; }
.product-card{ border-radius: 18px; padding: clamp(18px, 2.4vw, 26px); box-shadow: 0 20px 40px rgba(0,0,0,.08); position:relative; overflow:hidden; min-height:230px; color:#fff; height:100%; transition: transform .18s ease, box-shadow .18s ease; }
.product-card--brand{ background: linear-gradient(180deg, #0580a1 0%, #067392 100%); }
.product-card--dark{ background: linear-gradient(180deg, #0b3040 0%, #071d29 100%); }
.product-card:hover{ transform: translateY(-4px); box-shadow: 0 26px 54px rgba(0,0,0,.12); }
.product-card__icon{ width: 56px; height: 56px; border-radius: 14px; display:grid; place-items:center; background: rgba(255,255,255,.14); margin-bottom: 12px; color:#fff; }
.product-card h3{ margin:6px 0 8px; font-size: clamp(16px, 2vw, 20px); font-weight:800; letter-spacing:.2px; }
.product-card p{ margin:0; color: rgba(255,255,255,.94); font-size: clamp(13px, 1.6vw, 15px); }
.product-faq{ background:#f5fafc; padding: clamp(22px, 5vw, 44px) 0; }
.product-faq__title{ text-align:center; font-weight:800; color:#0b3040; margin:0 0 6px; font-size: clamp(22px, 3.2vw, 30px); }
.product-faq__lead{ text-align:center; color:#5b6b73; margin:0 0 18px; font-size: clamp(14px, 1.6vw, 18px); }
.product-accordion{ max-width: 920px; margin: 0 auto; }
.product-accordion details{ background:#fff; border:1px solid #e3eef3; border-radius:12px; padding:14px 16px; margin-bottom:10px; box-shadow:0 8px 24px rgba(3,56,77,.04); }
.product-accordion summary{ list-style:none; cursor:pointer; font-weight:800; color:#0b3040; display:flex; align-items:center; gap:10px; }
.product-accordion summary::-webkit-details-marker{ display:none; }
.product-accordion .chev svg{ width:18px; height:18px; color:#0580a1; transition: transform .2s ease; }
.product-accordion details[open] .chev svg{ transform: rotate(90deg); }
.product-accordion details p{ margin:10px 2px 2px; color:#4b5a62; line-height:1.7; }
.product-accordion summary:focus-visible, .btnP:focus-visible{ outline:3px solid #00a5d9; outline-offset:2px; border-radius:10px; }

/* Ajustes móveis (produto) */
@media (max-width:768px){
  .product-hero{ padding: calc(var(--header-h, 100px) + 10px) 0 24px; }
  .product-hero__sub{ max-width: 100%; }
}


/* ===== PROJETOS – visual aprimorado ===== */
.section-projects{
  padding: clamp(28px, 6vw, 72px) 0;
  background:
    radial-gradient(900px 300px at 100% 0%, rgba(0,165,217,.08), transparent 70%),
    radial-gradient(700px 260px at 0% 100%, rgba(11,48,64,.06), transparent 70%);
}

.projects-intro{
  background:#fff;
  border:1px solid #e3eef3;
  border-radius:18px;
  padding: clamp(16px, 2.8vw, 28px);
  box-shadow:0 18px 48px rgba(3,56,77,.08);
}

.chip{
  display:inline-block; font-weight:800; letter-spacing:.2px;
  padding:6px 12px; border-radius:999px; font-size:13px;
  border:1px solid rgba(0,0,0,.06);
}
.chip--brand{ background:#0580a1; color:#fff; border-color: rgba(255,255,255,.25); }

.projects-title{
  margin:12px 0 6px; font-weight:800;
  font-size: clamp(20px, 2.8vw, 28px); color:#0b3040; display:flex; align-items:center; gap:10px;
}
.projects-title .accent-bar{
  content:""; display:inline-block; width:36px; height:6px; border-radius:999px; background:#0580a1;
}

.projects-lead{
  color:#5b6b73; font-size: clamp(14px, 1.6vw, 16px);
  margin:8px 0 14px; line-height:1.7;
}

.projects-bullets{ margin:0 0 16px; padding:0; }
.projects-bullets li{
  position:relative; padding-left:18px; margin:6px 0; color:#3a4a53; font-size:1.35em;
}
.projects-bullets li::before{
  content:""; position:absolute; left:0; top:.7em; width:8px; height:8px; border-radius:50%;
  background:#0580a1;
  box-shadow:0 0 0 3px rgba(5,128,161,.15);
}

.projects-cta{ display:flex; gap:10px; flex-wrap:wrap; }
.btn-line{
  display:inline-flex; align-items:center; gap:8px; font-weight:800;
  padding:10px 14px; border-radius:12px; border:2px solid #0580a1; color:#0580a1; text-decoration:none;
  transition:.2s ease;
}
.btn-line:hover{ background:#0580a1; color:#fff; text-decoration:none; }
.btn-soft{
  display:inline-flex; align-items:center; padding:10px 14px; border-radius:12px;
  background:#e7f7fc; color:#0b3040; font-weight:800; text-decoration:none;
}
.btn-soft:hover{ filter:brightness(.97); text-decoration:none; }

/* Galeria – moldura, sombra e setas */
.splide--projects .splide__track{
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.18);
  border:none;
}
.splide--projects .splide__slide img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.splide--projects .splide__arrow{
  background:rgba(6,33,42,.9); width:42px; height:42px; border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.25);
}
.splide--projects .splide__arrow svg{ fill:#fff; }

/* Thumbs */
.thumbnails--projects{ display:flex; justify-content:flex-end; gap:12px; margin:12px 0 0; }
.thumbnails--projects .thumbnail{
  width:78px; height:78px; border-radius:16px; overflow:hidden;
  border:3px solid rgba(5,128,161,.35); cursor:pointer; transition:.2s ease;
}
.thumbnails--projects .thumbnail.is-active{
  border-color:#0580a1; box-shadow:0 10px 26px rgba(5,128,161,.35);
}
.thumbnails--projects .thumbnail img{
  width:100%; height:100%; object-fit:cover; transform:scale(1); transition: transform .25s, filter .25s;
  filter:saturate(.9);
}
.thumbnails--projects .thumbnail:hover img{ transform:scale(1.05); filter:saturate(1); }

/* Responsivo: colocar o slider primeiro no mobile e ajustar espaçamentos */
@media (max-width:768px){
  .section-projects{ padding: 22px 0; }
  .thumbnails--projects{ justify-content:center; }
  .projects-intro{ margin-top:14px; }
  .contact-header li{
    font-size: 12px;
  }
  .contact-header [class^="icon-"], .contact-header [class*=" icon-"]{
    font-size: 13px;
  }
    .legend-cores li{ font-size: 1.4em;}
  .hero__title{
    padding-top: 50px;
    font-size: 23px;
text-shadow: 7px 2px 4px rgba(0,0,0,0.36);  }

.hero__sub{
  text-shadow: 7px 2px 4px rgba(0, 0, 0, 0.596);
}
.badge2{
  display: none;
}
.badge{
    text-shadow: 7px 2px 4px rgba(0, 0, 0, 0.596);

}
  
}
/* =============================
   Breadcrumbs (Produtos)
   ============================= */
.breadcrumbs{
  display:flex; align-items:center; gap:8px;
  padding-top:6px; padding-bottom:8px;
  color:#bfefff;
  font-size: 1.3em;
}
.breadcrumbs a{
  color:#bfefff; text-decoration:none; font-weight:700;
  border-bottom:1px dashed rgba(255,255,255,.35);
}
.breadcrumbs a:hover{ border-bottom-color: transparent; }
.breadcrumbs .sep{ opacity:.6; }
.breadcrumbs .current{ color:#e8fbff; font-weight:800; }

/* Garante respiro com header fixo */
.product-list-hero[id]{ scroll-margin-top: var(--header-h, 120px); }

/* Ajuste sutil de sombra/hover dos tiles */
.prod-tile{
  position:relative;
  isolation:isolate;
}
.prod-tile::after{
  content:"";
  position:absolute; inset:0; z-index:-1;
  border-radius:18px;
  box-shadow:0 0 0 1px rgba(255,255,255,.10) inset;
}


/* =============================
   LISTA DE PRODUTOS (Grid)
   ============================= */
.product-list-hero{
  padding: calc(var(--header-h, 120px) + 16px) 0 10px;
  background:
    radial-gradient(900px 280px at 0% 0%, rgba(0,165,217,.20) 0%, rgba(0,165,217,0) 70%),
    linear-gradient(180deg, #0b3040 0%, #0e3f52 100%);
  color:#fff;
}
.product-list-hero__title{
  font-weight:800;
  font-size:clamp(24px, 3.2vw, 36px);
  margin:0 0 6px;
}
.product-list-hero__sub{
  color:#d7f1fa;
  font-size:clamp(14px, 1.6vw, 18px);
}

.product-grid{
  padding: clamp(18px, 4vw, 36px) 0 clamp(24px, 5vw, 48px);
  background:#f9fcfe;
}

/* tile base */
.prod-tile{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  text-align:center;
  width:100%;
  min-height:120px;
  border-radius:18px;
  text-decoration:none;
  background: linear-gradient(180deg, #0b3040 0%, #071d29 100%);
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 14px 36px rgba(0,0,0,.12);
  transition: transform .16s ease, box-shadow .16s ease, background .2s ease;
}
.prod-tile:hover{
  transform: translateY(-4px);
  box-shadow: 0 22px 50px rgba(0,0,0,.18);
}
.prod-tile--brand{
  background: linear-gradient(180deg, #0580a1 0%, #067392 100%);
}

/* textos */
.prod-tile__name{
  font-weight:800;
  font-size: clamp(14px, 1.8vw, 18px);
  letter-spacing:.2px;
}
.prod-tile__tag{
  display:inline-block;
  padding:4px 8px;
  line-height:1;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.12);
  color:#eaf8ff;
  font-size: 12px;
}

/* espaçamento com header fixo */
.product-list-hero[id], .product-grid[id] { scroll-margin-top: var(--header-h, 120px); }


/* =============================
   PRODUTOS — TILES COM IMAGEM
   ============================= */

/* Reforço da base dos tiles (caso ainda não tenha) */
.prod-tile{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:4px;
  border-radius:18px;
  padding:14px 14px;
  min-height:160px;
  position:relative;
  overflow:hidden;
  text-decoration:none;
  color:#0b3040; /* será sobrescrito nos com imagem */
  transition:transform .2s ease, box-shadow .2s ease;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
}
@media (min-width: 992px){
  .prod-tile{ min-height:200px; }
}
.prod-tile__name{
  font-weight:800;
  font-size: clamp(14px, 1.6vw, 18px);
}
.prod-tile__tag{
  display:inline-block;
  font-size:12px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.25);
  color:#fff;
  font-weight:700;
}

/* Versão com imagem */
.prod-tile--img{
  color:#fff;
  isolation:isolate;
  background:#0b3040; /* fallback */
}
.prod-tile--img::before{
  /* camada da foto */
  content:"";
  position:absolute; inset:0;
  z-index:-2;
  background-size:cover;
  background-position:center;
  transform: scale(1.05);
  transition: transform .35s ease, filter .25s ease;
}
.prod-tile--img::after{
  /* gradiente de leitura */
  content:"";
  position:absolute; inset:0;
  z-index:-1;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.00) 15%, rgba(0,0,0,.55) 88%);
}
.prod-tile--img:hover::before{ transform: scale(1.1); }
.prod-tile--img:hover{ transform: translateY(-3px); box-shadow:0 20px 44px rgba(0,0,0,.16); }

/* Acessibilidade no foco teclado */
.prod-tile:focus-visible{
  outline:3px solid #00a5d9;
  outline-offset:2px;
  border-radius:14px;
}

/* =============================
   UMA CLASSE POR PRODUTO
   (troque os caminhos das imagens)
   ============================= */
.tile-duraline.prod-tile--img::before{
  background-image:url('../imagens/produtos/duraline.jpg');
}

.tile-eposystem.prod-tile--img::before{
  background-image:url('../imagens/produtos/epoxystem.jpg');
}

.tile-pucim.prod-tile--img::before{
  background-image:url('../imagens/produtos/pu-cim.jpg');
}

.tile-microcim.prod-tile--img::before{
  background-image:url('../imagens/produtos/microcim.jpg');
}

.tile-flake.prod-tile--img::before{
  background-image:url('../imagens/produtos/flake.jpg');
}

.tile-stain.prod-tile--img::before{
  background-image:url('../imagens/produtos/stain.jpg');
}

/* =============================
   PRODUTOS – GRID DE TILES
   ============================= */
.product-grid{ padding: 12px 0 28px; }

/* aumenta o “gutter” só nesta seção sem quebrar o Reflex */
.product-grid .grid{
  margin-left: -18px;
  margin-right: -18px;
}
.product-grid [class*="col-"]{
  padding-left: 18px;
  padding-right: 18px;
}

/* desktop com mais respiro */
@media (min-width: 1200px){
  .product-grid .grid{
    margin-left: -24px;
    margin-right: -24px;
  }
  .product-grid [class*="col-"]{
    padding-left: 24px;
    padding-right: 24px;
  }
}

/* alturas mais equilibradas dos cards */
.prod-tile{ min-height: 150px; }
@media (min-width: 992px){
  .prod-tile{ min-height: 180px; }
}
@media (max-width: 575px){
  .prod-tile{ min-height: 140px; }
}


/* ===== Chips genéricos (reuso do visual do product-hero__chip) ===== */
.chip{
  display:inline-block; font-weight:800; letter-spacing:.2px;
  padding:6px 12px; border-radius:999px; border:1px solid rgba(255,255,255,.25);
  background:#0580a1; color:#fff; font-size:13px;
}
.chip--brand{ background:#0580a1; color:#fff; }

/* ===== Seção: Embaixador ===== */
.section-ambassador{
  background: linear-gradient(180deg, #0b3040 0%, #0e3f52 100%);
  color:#e6f7fb;
  padding: clamp(24px, 5vw, 56px) 0;
  position: relative;
  overflow: hidden;
}
.section-ambassador::before{
  content:""; position:absolute; inset:-20% -20% auto auto; height:240px; width:240px;
  background: radial-gradient(closest-side, rgba(0,165,217,.18), transparent 70%);
  transform: translate(10%, -10%);
  pointer-events:none;
}

.ambassador-title{
  color:#fff; font-weight:800;
  font-size: clamp(22px, 3vw, 32px);
  margin: 8px 0 8px;
}
.ambassador-lead{
  color:#c7d8df; font-size: clamp(14px, 1.5vw, 18px);
  margin-bottom: 10px;
}

.ambassador-photo{ position:relative; max-width:440px; margin:0; }
.ambassador-photo img{
  width:100%; height:auto; display:block;
  border-radius:18px; border:4px solid #0580a1;
  box-shadow:0 20px 48px rgba(0,0,0,.25);
  object-fit:cover;
}
.ambassador-badge{
  position:absolute; left:12px; bottom:12px;
  background:#0580a1; color:#fff; border:1px solid rgba(255,255,255,.25);
  padding:6px 10px; border-radius:999px; font-weight:800; font-size:13px;
}

.ambassador-highlights{ margin:12px 0 16px; padding:0; }
.ambassador-highlights li{
  display:flex; gap:8px; align-items:center; margin:6px 0; font-size:1.3em; color:#d9eef6;
}
.ambassador-highlights .icon-check{ color:#00c1ff; font-size:1.2em; }

.ambassador-cta{ display:flex; gap:10px; flex-wrap:wrap; }

/* versão compacta (para lateral do formulário, se quiser) */
.ambassador-card{
  background:#0b3040; border:1px solid #0f4f63; border-radius:14px;
  padding:14px; color:#d7f1fa; display:flex; gap:12px; align-items:center;
}
.ambassador-card img{
  width:64px; height:64px; object-fit:cover; border-radius:10px; border:2px solid #0580a1;
}
.ambassador-card h4{ margin:0 0 2px; color:#fff; font-weight:800; }
.ambassador-card small{ color:#9fdcf1; }

/* ===== Fix centralização & overflow dos tiles na página de produtos ===== */

/* neutraliza os hacks de inline-block do Reflex só dentro da grade de produtos */
.product-grid .grid{
  justify-content: center;          /* centraliza cada linha */
  letter-spacing: normal;
  word-spacing: normal;
}

/* faz cada coluna virar um “slot” flex para o tile preencher 100% */
.product-grid [class*="col-"]{
  display: flex;                     /* col vira flex container */
}

.product-grid .prod-tile{
  width: 100%;
  height: 100%;
  overflow: hidden;                  /* garante que nada “vaze” dos cantos arredondados */
  border-radius: 18px;
}

/* espaçamentos um pouquinho maiores no desktop para “respirar” */
@media (min-width: 992px){
  .product-grid .grid{ row-gap: 22px; }
}

/* reforço para mobile pequeno: garante que a imagem (pseudo ::before) não estoure */
@media (max-width: 575px){
  .prod-tile--img::before{
    background-size: cover;
    background-position: center;
    transform: scale(1.03);
  }
}


/* Espaçamento vertical entre os cards de produtos */
.product-grid .grid{
  row-gap: 18px;                  /* mobile */
}

@media (min-width: 768px){
  .product-grid .grid{ row-gap: 22px; }
}
@media (min-width: 992px){
  .product-grid .grid{ row-gap: 28px; }
}


/* ===== Serviços – altura consistente dos cards ===== */
.produtos .card{
  display: flex;               /* faz todas as colunas terem a mesma altura */
}

.produtos .card .card-inside{
  flex: 1;
  min-height: 200px;           /* base (mobile maiorzinho) */
  display: flex;
  flex-direction: column;
  justify-content: flex-end;   /* mantém o título na parte de baixo */
  padding: 16px 12px;          /* um pouco mais de respiro interno */
}

/* sobe a altura nos breakpoints */
@media (min-width: 768px){
  .produtos .card .card-inside{ min-height: 240px; }
}
@media (min-width: 992px){
  .produtos .card .card-inside{ min-height: 280px; }
}
@media (min-width: 1200px){
  .produtos .card .card-inside{ min-height: 250px; }
}
