/* ==========================================================================
   Mi Automação — Folha de estilos principal
   Identidade visual premium escuro/terracota
   ========================================================================== */


/* --------------------------------------------------------------------------
   1. VARIÁVEIS CSS
   -------------------------------------------------------------------------- */

:root {
  /* Cores principais */
  --cor-bg:            #0e0e0e;
  --cor-bg-suave:      #141414;
  --cor-bg-card:       #1a1a1a;

  /* Terracota — família de destaque */
  --cor-ouro:          #a96f56;
  --cor-ouro-claro:    #c48c72;
  --cor-ouro-escuro:   #8a5540;
  --cor-ouro-alpha:    rgba(169, 111, 86, 0.15);
  --cor-ouro-borda:    rgba(169, 111, 86, 0.25);

  /* Texto */
  --cor-texto:         #e2e2e2;
  --cor-texto-suave:   #9a9a9a;
  --cor-texto-inv:     #0e0e0e;

  /* Header / Nav */
  --cor-header-bg:     #111111;
  --cor-nav-link:      #d4d4d4;
  --cor-nav-link-hover:#a96f56;
  --cor-submenu-bg:    #1c1c1c;
  --cor-submenu-borda: rgba(169, 111, 86, 0.18);

  /* Footer */
  --cor-footer-bg:     #090909;
  --cor-footer-texto:  #8a8a8a;
  --cor-footer-titulo: #a96f56;
  --cor-footer-link:   #b0b0b0;
  --cor-footer-link-hover: #a96f56;
  --cor-footer-linha:  rgba(255, 255, 255, 0.07);

  /* WhatsApp */
  --cor-whatsapp:      #25d366;
  --cor-whatsapp-dark: #1da851;

  /* Bordas e divisores */
  --cor-borda:         rgba(255, 255, 255, 0.08);

  /* Tipografia */
  --fonte-corpo: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial,
                 sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
  --fonte-titulo: var(--fonte-corpo);
  --tamanho-base:  17px;
  --linha-base:    1.6;

  /* Layout */
  --largura-max:   1200px;
  --gutter:        40px;
  --gutter-mobile: 20px;

  /* Header */
  --altura-header: 72px;

  /* Transições */
  --trans-rapida:  0.15s ease;
  --trans-normal:  0.25s ease;

  /* Sombras */
  --sombra-card:   0 4px 24px rgba(0, 0, 0, 0.45);
  --sombra-submenu:0 8px 32px rgba(0, 0, 0, 0.6);
}


/* --------------------------------------------------------------------------
   2. RESET / BASE
   -------------------------------------------------------------------------- */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: var(--tamanho-base);
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

body {
  font-family: var(--fonte-corpo);
  font-weight: 400;
  line-height: var(--linha-base);
  color: var(--cor-texto);
  background-color: var(--cor-bg);
}

img, video, svg {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: var(--cor-ouro);
  text-decoration: none;
  transition: color var(--trans-rapida);
}

a:hover {
  color: var(--cor-ouro-claro);
}

ul, ol {
  list-style: none;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

address {
  font-style: normal;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--fonte-titulo);
  font-weight: 600;
  line-height: 1.25;
  color: var(--cor-texto);
}

h1 { font-size: clamp(2rem, 4vw, 2.75rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.25rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.6rem); }
h4 { font-size: 1.2rem; }

p { margin-bottom: 1.4em; }
p:last-child { margin-bottom: 0; }


/* --------------------------------------------------------------------------
   3. LAYOUT GLOBAL — CONTAINER
   -------------------------------------------------------------------------- */

.container {
  width: 100%;
  max-width: var(--largura-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

@media (max-width: 768px) {
  .container {
    padding-inline: var(--gutter-mobile);
  }
}


/* --------------------------------------------------------------------------
   4. LAYOUT GLOBAL V2 — HEADER
   -------------------------------------------------------------------------- */

.mi-site-header {
  position: fixed;
  top: 18px;
  left: 0;
  right: 0;
  z-index: 9990;
  pointer-events: none;
}

.mi-header-pill {
  width: min(1280px, calc(100% - 48px));
  min-height: 72px;
  margin: 0 auto;
  padding: 0 10px 0 24px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 28px;
  pointer-events: auto;
  border: 1px solid rgba(247, 242, 234, .12);
  border-radius: 999px;
  background: rgba(15, 15, 15, .78);
  box-shadow: 0 24px 70px rgba(0, 0, 0, .30), inset 0 1px 0 rgba(255, 255, 255, .04);
  backdrop-filter: blur(30px) saturate(1.12);
}

.mi-brand {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 0;
  color: #fff;
  text-decoration: none;
}

.mi-brand:hover {
  color: #fff;
}

.mi-brand-logo {
  width: 76px;
  max-height: 52px;
  object-fit: contain;
}

.mi-brand-divider {
  width: 1px;
  height: 36px;
  background: rgba(247, 242, 234, .15);
  flex-shrink: 0;
}

.mi-brand-caption {
  display: flex;
  flex-direction: column;
  gap: 3px;
  color: rgba(247, 242, 234, .56);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .18em;
  line-height: 1.2;
  text-transform: uppercase;
  white-space: nowrap;
}

.mi-global-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  min-width: 0;
}

.mi-nav-item {
  position: relative;
}

.mi-nav-item--dropdown::after {
  content: "";
  position: absolute;
  left: -12px;
  right: -12px;
  top: 100%;
  height: 16px;
}

.mi-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  color: rgba(247, 242, 234, .70);
  font-size: 13px;
  font-weight: 560;
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
  transition: background .16s ease, color .16s ease;
}

.mi-nav-trigger {
  appearance: none;
}

.mi-nav-link:hover,
.mi-nav-link:focus-visible,
.mi-nav-item:hover > .mi-nav-link,
.mi-nav-item.is-active > .mi-nav-link,
.mi-nav-link.is-active {
  background: rgba(247, 242, 234, .08);
  color: #fff;
  outline: none;
}

.mi-nav-caret {
  width: 6px;
  height: 6px;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  opacity: .72;
}

.mi-nav-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  z-index: 20;
  min-width: 238px;
  padding: 7px;
  display: none;
  border: 1px solid rgba(247, 242, 234, .12);
  border-radius: 18px;
  background: rgba(18, 18, 18, .97);
  box-shadow: 0 24px 70px rgba(0, 0, 0, .34);
  transform: translateX(-50%);
  backdrop-filter: blur(30px) saturate(1.1);
}

.mi-nav-item:hover .mi-nav-dropdown,
.mi-nav-item:focus-within .mi-nav-dropdown,
.mi-nav-item.is-open .mi-nav-dropdown {
  display: block;
}

.mi-nav-dropdown a {
  display: block;
  padding: 10px 13px;
  border-radius: 10px;
  color: rgba(247, 242, 234, .72);
  font-size: 13px;
  line-height: 1.25;
  text-decoration: none;
  white-space: nowrap;
  transition: background .13s ease, color .13s ease;
}

.mi-nav-dropdown a:hover,
.mi-nav-dropdown a:focus-visible {
  background: rgba(247, 242, 234, .08);
  color: #fff;
  outline: none;
}

.mi-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.pill-apple {
  display: flex;
  align-items: center;
  gap: 16px;
}

.pill-apple img {
  max-height: 52px;
  width: auto;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.pill-apple-caption {
  display: flex;
  flex-direction: column;
  gap: 3px;
  color: rgba(247, 242, 234, .56);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .18em;
  line-height: 1.2;
  text-transform: uppercase;
  white-space: nowrap;
}

.mi-header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border: 1px solid rgba(255, 255, 255, .10);
  border-radius: 999px;
  background: var(--cor-ouro);
  box-shadow: 0 10px 28px rgba(169, 111, 86, .28);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
  text-decoration: none;
  transition: background .16s ease, transform .16s ease;
}

.mi-header-cta:hover,
.mi-header-cta:focus-visible {
  background: var(--cor-ouro-escuro);
  color: #fff;
  transform: translateY(-1px);
  outline: none;
}

.mi-menu-toggle {
  display: none;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  border: 1px solid rgba(247, 242, 234, .14);
  border-radius: 999px;
  background: rgba(247, 242, 234, .05);
}

.mi-menu-toggle span {
  width: 18px;
  height: 2px;
  border-radius: 2px;
  background: rgba(247, 242, 234, .82);
}

.mi-global-eyebrow-wrap {
  position: relative;
  z-index: 2;
  padding-top: 118px;
  padding-bottom: 22px;
  background: var(--cor-bg);
}

.mi-global-eyebrow-wrap .mi-container {
  width: min(1180px, calc(100% - 48px));
}

.mi-global-eyebrow-wrap .mi-eyebrow {
  margin: 0 !important;
}

@media (max-width: 1180px) {
  .mi-header-pill {
    grid-template-columns: auto auto;
    justify-content: space-between;
  }

  .mi-global-nav {
    position: absolute;
    top: calc(100% + 10px);
    left: 24px;
    right: 24px;
    display: none;
    max-height: calc(100vh - 112px);
    overflow: auto;
    padding: 10px;
    flex-direction: column;
    align-items: stretch;
    border: 1px solid rgba(247, 242, 234, .12);
    border-radius: 24px;
    background: rgba(15, 15, 15, .97);
    box-shadow: 0 24px 70px rgba(0, 0, 0, .34);
    backdrop-filter: blur(30px) saturate(1.1);
  }

  .mi-site-header.is-menu-open .mi-global-nav {
    display: flex;
  }

  .mi-nav-link,
  .mi-nav-trigger {
    width: 100%;
    justify-content: space-between;
    min-height: 44px;
  }

  .mi-nav-item--dropdown::after {
    display: none;
  }

  .mi-nav-dropdown {
    position: static;
    min-width: 0;
    display: none;
    margin: 2px 0 8px;
    padding: 6px;
    border-radius: 14px;
    box-shadow: none;
    transform: none;
    background: rgba(255, 255, 255, .04);
  }

  .mi-nav-item.is-open .mi-nav-dropdown {
    display: block;
  }

  .mi-nav-item:hover .mi-nav-dropdown {
    display: none;
  }

  .mi-nav-item.is-open:hover .mi-nav-dropdown {
    display: block;
  }

  .mi-menu-toggle {
    display: inline-flex;
  }
}

@media (max-width: 760px) {
  .mi-site-header {
    top: 10px;
  }

  .mi-header-pill {
    width: calc(100% - 24px);
    min-height: 64px;
    padding: 0 8px 0 16px;
    gap: 14px;
  }

  .mi-brand-logo {
    width: 64px;
    max-height: 44px;
  }

  .mi-brand-divider,
  .mi-brand-caption,
  .mi-header-cta {
    display: none;
  }

  .mi-global-nav {
    left: 12px;
    right: 12px;
  }

  .mi-global-eyebrow-wrap {
    padding-top: 92px;
    padding-bottom: 18px;
  }

  .mi-global-eyebrow-wrap .mi-container {
    width: calc(100% - 40px);
  }

}
/* --------------------------------------------------------------------------
   5. LAYOUT GLOBAL V2 — FOOTER
   -------------------------------------------------------------------------- */

.mi-site-footer {
  background:
    linear-gradient(180deg, rgba(15, 15, 15, .98), #080808 48%),
    var(--cor-footer-bg);
  border-top: 1px solid rgba(247, 242, 234, .10);
  margin-top: auto;
  color: rgba(247, 242, 234, .70);
}

.mi-footer-shell {
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto;
  padding: 70px 0 48px;
  display: grid;
  grid-template-columns: minmax(260px, 1.05fr) minmax(0, 2fr);
  gap: 56px;
}

.mi-footer-brand {
  max-width: 360px;
}

.mi-footer-logo {
  display: inline-flex;
  margin-bottom: 22px;
}

.mi-footer-logo img {
  width: 190px;
  height: auto;
}

.mi-footer-description {
  color: rgba(247, 242, 234, .62);
  font-size: 14px;
  line-height: 1.75;
  margin-bottom: 24px;
}

.mi-footer-contact p {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(247, 242, 234, .62);
  font-size: 14px;
}

.mi-footer-contact svg {
  flex: 0 0 auto;
  color: var(--cor-ouro);
}

.mi-footer-contact a {
  color: rgba(247, 242, 234, .78);
}

.mi-footer-contact a:hover {
  color: #fff;
}

.mi-footer-nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 30px;
}

.mi-footer-title {
  margin: 0 0 18px;
  color: rgba(247, 242, 234, .48);
  font-size: 11px;
  font-weight: 760;
  letter-spacing: .16em;
  line-height: 1.2;
  text-transform: uppercase;
}

.mi-footer-col ul {
  display: grid;
  gap: 10px;
}

.mi-footer-col a {
  display: inline-flex;
  color: rgba(247, 242, 234, .70);
  font-size: 14px;
  line-height: 1.35;
  text-decoration: none;
  transition: color .16s ease, transform .16s ease;
}

.mi-footer-col a:hover,
.mi-footer-col a:focus-visible {
  color: #fff;
  transform: translateX(2px);
  outline: none;
}

.mi-footer-bottom {
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto;
  padding: 22px 0 28px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
}

.mi-footer-bottom p {
  color: rgba(247, 242, 234, .48);
  font-size: 13px;
  margin: 0;
}

@media (max-width: 980px) {
  .mi-footer-shell {
    grid-template-columns: 1fr;
  }

  .mi-footer-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .mi-footer-shell,
  .mi-footer-bottom {
    width: calc(100% - 40px);
  }

  .mi-footer-nav {
    grid-template-columns: 1fr;
  }

  .mi-footer-bottom {
    flex-direction: column;
  }
}


/* --------------------------------------------------------------------------
   6. BOTÃO FLUTUANTE WHATSAPP
   -------------------------------------------------------------------------- */

.whatsapp-float {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--cor-whatsapp);
  color: #fff;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
  text-decoration: none;
  transition: background-color var(--trans-rapida), transform var(--trans-normal),
              box-shadow var(--trans-normal);
  animation: whatsapp-pulse 3s ease-in-out infinite;
}

.whatsapp-float:hover {
  background-color: var(--cor-whatsapp-dark);
  color: #fff;
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 8px 28px rgba(37, 211, 102, 0.55);
  animation: none;
}

.whatsapp-float__icone {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.whatsapp-float__texto {
  max-width: 200px;
  overflow: hidden;
  transition: max-width var(--trans-normal), opacity var(--trans-normal);
}

@keyframes whatsapp-pulse {
  0%, 100% { box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4); }
  50%       { box-shadow: 0 4px 28px rgba(37, 211, 102, 0.7); }
}


/* --------------------------------------------------------------------------
   7. UTILITÁRIOS GLOBAIS
   -------------------------------------------------------------------------- */

/* --- Botões pill --- */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 20px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 650;
  letter-spacing: -.01em;
  border: 1px solid transparent;
  text-decoration: none;
  transition: transform .16s ease, background .16s ease, border-color .16s ease, color .16s ease;
  white-space: nowrap;
  cursor: pointer;
}

.btn:active { transform: translateY(1px) scale(.99); }

.btn-primary {
  color: #141414;
  background: #f6f3ed;
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 10px 26px rgba(0,0,0,.14);
}

.btn-primary:hover { background: #ffffff; color: #141414; }

.btn-outline {
  color: rgba(247,242,234,.78);
  background: rgba(247,242,234,.04);
  border-color: rgba(247,242,234,.16);
}

.btn-outline:hover {
  background: rgba(247,242,234,.09);
  border-color: rgba(247,242,234,.30);
  color: rgba(247,242,234,.78);
}

.btn-terra {
  color: #fff;
  background: var(--cor-ouro);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 10px 28px rgba(169,111,86,.28);
}

.btn-terra:hover { background: var(--cor-ouro-escuro); color: #fff; }

/* --- Kicker e cabeçalho de seção --- */

.secao-kicker {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cor-ouro);
  margin-bottom: 12px;
}

.secao-header {
  text-align: center;
  margin-bottom: 56px;
}

.secao-header h2 {
  font-size: clamp(1.6rem, 2.5vw, 2.1rem);
  margin-top: 8px;
}

.destaque-ouro {
  color: var(--cor-ouro);
}


/* --------------------------------------------------------------------------
   8. HERO
   -------------------------------------------------------------------------- */

.hero {
  background-color: var(--cor-bg-suave);
  border-bottom: 1px solid var(--cor-borda);
  padding: 80px 0 60px;
  overflow: hidden;
}

.hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 60px;
}

.hero__kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cor-ouro);
  margin-bottom: 16px;
}

.hero__titulo {
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 24px;
  color: #fff;
}

.hero__texto {
  font-size: 16px;
  color: var(--cor-texto-suave);
  line-height: 1.75;
  margin-bottom: 36px;
  max-width: 520px;
}

.hero__imagem {
  position: relative;
}

.hero__imagem img {
  width: 100%;
  height: auto;
  border-radius: 6px;
  box-shadow: var(--sombra-card);
  object-fit: cover;
}

.hero__imagem::before {
  content: '';
  position: absolute;
  inset: -12px -12px 12px 12px;
  border: 1px solid var(--cor-ouro-borda);
  border-radius: 6px;
  pointer-events: none;
  z-index: -1;
}


/* --------------------------------------------------------------------------
   9. SERVIÇOS — 3 CARDS
   -------------------------------------------------------------------------- */

.servicos {
  padding: 80px 0;
  background-color: var(--cor-bg);
}

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

.servico-card {
  background-color: var(--cor-bg-card);
  border: 1px solid var(--cor-borda);
  border-top: 3px solid transparent;
  border-radius: 6px;
  padding: 36px 28px 28px;
  transition: border-color var(--trans-normal), transform var(--trans-normal),
              box-shadow var(--trans-normal);
}

.servico-card:hover {
  border-top-color: var(--cor-ouro);
  transform: translateY(-4px);
  box-shadow: var(--sombra-card);
}

.servico-card--destaque {
  border-top-color: var(--cor-ouro);
  background-color: var(--cor-bg-suave);
}

/* Imagem no topo do card (substitui ícone SVG) */
.servico-card__foto {
  margin: -1px -1px 24px;
  overflow: hidden;
  height: 200px;
  border-radius: 5px 5px 0 0;
}

.servico-card__foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.servico-card:hover .servico-card__foto img {
  transform: scale(1.04);
}

.servico-card__body {
  padding: 0 4px;
}

.servico-card__titulo {
  font-size: 1.1rem;
  font-weight: 600;
  color: #fff;
  margin-bottom: 12px;
}

.servico-card__texto {
  font-size: 14px;
  color: var(--cor-texto-suave);
  line-height: 1.7;
  margin-bottom: 20px;
}

.servico-card__link {
  font-size: 13px;
  font-weight: 600;
  color: var(--cor-ouro);
  letter-spacing: 0.04em;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: gap var(--trans-rapida), color var(--trans-rapida);
}

.servico-card__link:hover {
  color: var(--cor-ouro-claro);
  gap: 10px;
}


/* --------------------------------------------------------------------------
   10. EFICIÊNCIA E CONFORTO
   -------------------------------------------------------------------------- */

.eficiencia {
  padding: 80px 0;
  background-color: var(--cor-bg-suave);
}

.eficiencia__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 72px;
}

.eficiencia__imagem img {
  width: 100%;
  border-radius: 6px;
  box-shadow: var(--sombra-card);
}

.eficiencia__titulo {
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  margin-bottom: 20px;
  color: #fff;
}

.eficiencia__texto {
  font-size: 15px;
  color: var(--cor-texto-suave);
  line-height: 1.8;
  margin-bottom: 32px;
}


/* --------------------------------------------------------------------------
   11. SUA CASA, SEU ESTILO
   -------------------------------------------------------------------------- */

.estilo {
  padding: 80px 0;
  background-color: var(--cor-bg);
}

.estilo__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 72px;
}

.estilo__titulo {
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  margin-bottom: 20px;
  color: #fff;
}

.estilo__texto {
  font-size: 15px;
  color: var(--cor-texto-suave);
  line-height: 1.8;
  margin-bottom: 32px;
}

.estilo__imagem img {
  width: 100%;
  border-radius: 6px;
  box-shadow: var(--sombra-card);
}


/* --------------------------------------------------------------------------
   12. DIFERENCIAIS — 4 ÍCONES
   -------------------------------------------------------------------------- */

.diferenciais {
  padding: 80px 0;
  background-color: var(--cor-bg-suave);
}

.diferenciais__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}

.diferencial {
  text-align: center;
  padding: 32px 20px;
  background-color: var(--cor-bg-card);
  border: 1px solid var(--cor-borda);
  border-radius: 6px;
  transition: border-color var(--trans-normal), transform var(--trans-normal);
}

.diferencial:hover {
  border-color: var(--cor-ouro-borda);
  transform: translateY(-4px);
}

.diferencial__icone {
  width: 48px;
  height: 48px;
  margin: 0 auto 20px;
  color: var(--cor-ouro);
}

.diferencial__icone svg {
  width: 100%;
  height: 100%;
}

.diferencial__titulo {
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  margin-bottom: 10px;
}

.diferencial__texto {
  font-size: 13px;
  color: var(--cor-texto-suave);
  line-height: 1.7;
  margin-bottom: 0;
}


/* --------------------------------------------------------------------------
   13. AUTOMAÇÃO SEM COMPLICAÇÃO
   -------------------------------------------------------------------------- */

.sem-complicacao {
  padding: 80px 0;
  background-color: var(--cor-bg);
}

.sem-complicacao__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 72px;
}

.sem-complicacao__titulo {
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  margin-bottom: 20px;
  color: #fff;
}

.sem-complicacao__texto {
  font-size: 15px;
  color: var(--cor-texto-suave);
  line-height: 1.8;
  margin-bottom: 20px;
}

.sem-complicacao__texto strong {
  color: var(--cor-ouro);
  font-weight: 600;
}

.sem-complicacao__texto:last-of-type {
  margin-bottom: 32px;
}

.sem-complicacao__imagem img {
  width: 100%;
  border-radius: 6px;
  box-shadow: var(--sombra-card);
}


/* --------------------------------------------------------------------------
   14. PORTFÓLIO
   -------------------------------------------------------------------------- */

.portfolio {
  padding: 80px 0;
  background-color: var(--cor-bg-suave);
}

.portfolio__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 240px;
  gap: 12px;
}

.portfolio__item {
  position: relative;
  overflow: hidden;
  border-radius: 4px;
  background-color: var(--cor-bg-card);
  margin: 0;
}

.portfolio__item--destaque {
  grid-column: span 2;
}

.portfolio__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease, filter 0.5s ease;
  filter: brightness(0.85);
}

.portfolio__item:hover img {
  transform: scale(1.04);
  filter: brightness(0.7);
}

.portfolio__item figcaption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 12px 16px;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 100%);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity var(--trans-normal), transform var(--trans-normal);
}

.portfolio__item:hover figcaption {
  opacity: 1;
  transform: translateY(0);
}


/* --------------------------------------------------------------------------
   15. O QUE PODEMOS OFERECER
   -------------------------------------------------------------------------- */

.oferta {
  padding: 80px 0 96px;
  background-color: var(--cor-bg);
}

.oferta__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.oferta-card {
  background-color: var(--cor-bg-card);
  border: 1px solid var(--cor-borda);
  border-radius: 6px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color var(--trans-normal), transform var(--trans-normal),
              box-shadow var(--trans-normal);
}

.oferta-card:hover {
  border-color: var(--cor-ouro-borda);
  transform: translateY(-4px);
  box-shadow: var(--sombra-card);
}

.oferta-card__foto {
  height: 200px;
  overflow: hidden;
  flex-shrink: 0;
}

.oferta-card__foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.oferta-card:hover .oferta-card__foto img {
  transform: scale(1.04);
}

.oferta-card__body {
  padding: 24px 24px 28px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.oferta-card__titulo {
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  margin-bottom: 12px;
}

.oferta-card__texto {
  font-size: 14px;
  color: var(--cor-texto-suave);
  line-height: 1.7;
  flex: 1;
  margin-bottom: 20px;
}

.oferta-card__link {
  font-size: 13px;
  font-weight: 600;
  color: var(--cor-ouro);
  letter-spacing: 0.03em;
  align-self: flex-start;
  transition: color var(--trans-rapida), letter-spacing var(--trans-rapida);
}

.oferta-card__link:hover {
  color: var(--cor-ouro-claro);
  letter-spacing: 0.06em;
}


/* --------------------------------------------------------------------------
   16. RESPONSIVIDADE
   -------------------------------------------------------------------------- */

/* --- Tablet: md ≤ 1024px --- */

@media (max-width: 1024px) {
  :root {
    --gutter: 28px;
  }

  /* Seções de conteúdo — tablet */
  .hero__inner,
  .eficiencia__inner,
  .estilo__inner,
  .sem-complicacao__inner {
    gap: 48px;
  }

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

  .diferenciais__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }

  .oferta__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }

  .portfolio__grid {
    grid-auto-rows: 200px;
  }
}

/* --- Mobile: ≤ 768px --- */

@media (max-width: 768px) {
  :root {
    --gutter: var(--gutter-mobile);
    --altura-header: 64px;
  }

  /* Seções de conteúdo — mobile */
  .hero {
    padding: 48px 0 40px;
  }

  .hero__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .hero__imagem::before {
    display: none;
  }

  .hero__texto {
    max-width: 100%;
    margin-bottom: 28px;
  }

  .servicos__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .eficiencia,
  .estilo,
  .sem-complicacao {
    padding: 56px 0;
  }

  .eficiencia__inner,
  .estilo__inner,
  .sem-complicacao__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  /* Inverte a ordem no estilo: imagem fica abaixo do texto no mobile */
  .estilo__imagem {
    order: 1;
  }

  .diferenciais {
    padding: 56px 0;
  }

  .diferenciais__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }

  .diferencial {
    padding: 24px 16px;
  }

  .portfolio {
    padding: 56px 0;
  }

  .portfolio__grid {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 160px;
  }

  .portfolio__item--destaque {
    grid-column: span 2;
  }

  .portfolio__item figcaption {
    opacity: 1;
    transform: translateY(0);
  }

  .oferta {
    padding: 56px 0 72px;
  }

  .oferta__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .secao-header {
    margin-bottom: 40px;
  }

  /* WhatsApp: somente ícone em mobile */
  .whatsapp-float {
    bottom: 20px;
    right: 20px;
    padding: 14px;
    border-radius: 50%;
  }

  .whatsapp-float__texto {
    display: none;
  }

  .whatsapp-float__icone {
    width: 26px;
    height: 26px;
  }
}

/* --- Mobile pequeno: ≤ 480px --- */

@media (max-width: 480px) {
  h1 { font-size: 1.75rem; }
  h2 { font-size: 1.4rem; }
  h3 { font-size: 1.2rem; }
}

/* ============================================================
   ESTADOS JS — animações
   ============================================================ */

/* Animação de entrada dos cards */
.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .5s ease, transform .5s ease;
}

.fade-in.visivel {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   PÁGINAS INTERNAS
   ============================================================ */

/* Breadcrumb */
.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  font-size: 13px;
  color: var(--cor-texto-muted);
}

.breadcrumb li + li::before {
  content: '/';
  margin-right: 6px;
  color: var(--cor-ouro);
  opacity: .6;
}

.breadcrumb a {
  color: var(--cor-texto-muted);
  text-decoration: none;
  transition: color var(--trans-rapida);
}

.breadcrumb a:hover { color: var(--cor-ouro); }

.breadcrumb li[aria-current="page"] { color: var(--cor-ouro); }

/* ---- Hero interno ---- */
.hero-interno {
  background: linear-gradient(135deg, #111 0%, #1a1a1a 100%);
  padding: 72px 0 64px;
  position: relative;
  overflow: hidden;
}

.hero-interno::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(201,169,110,.07) 0%, transparent 60%);
  pointer-events: none;
}

.hero-interno__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  max-width: var(--max-largura);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.hero-interno__conteudo {
  position: relative;
  z-index: 1;
}

.hero-interno__titulo {
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 20px;
}

.hero-interno__titulo em {
  font-style: normal;
  color: var(--cor-ouro);
}

.hero-interno__subtitulo {
  font-size: 1.05rem;
  color: rgba(255,255,255,.75);
  line-height: 1.7;
  margin-bottom: 36px;
  max-width: 520px;
}

.hero-interno__acoes {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.hero-interno__imagem {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}

.hero-interno__imagem::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(201,169,110,.15) 0%, transparent 60%);
  pointer-events: none;
}

.hero-interno__imagem img {
  width: 100%;
  height: 380px;
  object-fit: cover;
  display: block;
  transition: transform .6s ease;
}

.hero-interno__imagem:hover img { transform: scale(1.03); }

/* ---- Seção introdução / conteúdo principal ---- */
.secao-intro {
  padding: 80px 0;
  background: var(--cor-bg);
}

.intro-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 64px;
  align-items: start;
  max-width: var(--max-largura);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.intro-grid--full {
  grid-template-columns: 1fr;
  max-width: 800px;
}

.intro-texto h2 {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  color: var(--cor-ouro);
  margin-bottom: 20px;
  line-height: 1.3;
}

.intro-texto p {
  color: rgba(255,255,255,.8);
  line-height: 1.8;
  margin-bottom: 18px;
}

.intro-texto p:last-child { margin-bottom: 0; }

.intro-lista {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.intro-lista li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  color: rgba(255,255,255,.8);
  font-size: .97rem;
  line-height: 1.6;
}

.intro-lista li::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 18px;
  min-width: 18px;
  background: var(--cor-ouro);
  border-radius: 50%;
  position: relative;
  top: 2px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 11px;
  background-repeat: no-repeat;
  background-position: center;
}

/* ---- Seção features ---- */
.secao-features {
  padding: 80px 0;
  background: #141414;
}

.secao-features__inner {
  max-width: var(--max-largura);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.secao-features .secao-header {
  text-align: center;
  margin-bottom: 56px;
}

.secao-features .secao-titulo {
  font-size: clamp(1.5rem, 2.8vw, 2rem);
  color: #fff;
  margin-bottom: 12px;
}

.secao-features .secao-subtitulo {
  color: var(--cor-texto-muted);
  font-size: 1rem;
  max-width: 560px;
  margin: 0 auto;
}

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

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

.features-grid--2 {
  grid-template-columns: repeat(2, 1fr);
}

.feature-card {
  background: #1c1c1c;
  border: 1px solid rgba(201,169,110,.15);
  border-radius: 8px;
  padding: 32px 28px;
  transition: border-color var(--trans-suave), transform var(--trans-suave), box-shadow var(--trans-suave);
}

.feature-card:hover {
  border-color: rgba(201,169,110,.45);
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,.35);
}

.feature-card__icone {
  width: 48px;
  height: 48px;
  background: rgba(201,169,110,.12);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  color: var(--cor-ouro);
}

.feature-card__icone svg { width: 24px; height: 24px; }

.feature-card__titulo {
  font-size: 1.05rem;
  font-weight: 600;
  color: #fff;
  margin-bottom: 10px;
}

.feature-card__desc {
  font-size: .92rem;
  color: var(--cor-texto-muted);
  line-height: 1.65;
}

/* ---- CTA interno ---- */
.secao-cta-interno {
  padding: 80px 0;
  background: linear-gradient(135deg, #161412 0%, #1e1a14 100%);
  text-align: center;
  border-top: 1px solid rgba(201,169,110,.12);
}

.cta-interno__inner {
  max-width: 680px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.cta-interno__titulo {
  font-size: clamp(1.5rem, 2.8vw, 2rem);
  color: #fff;
  margin-bottom: 16px;
}

.cta-interno__titulo em {
  font-style: normal;
  color: var(--cor-ouro);
}

.cta-interno__desc {
  color: rgba(255,255,255,.72);
  font-size: 1.02rem;
  line-height: 1.7;
  margin-bottom: 36px;
}

.cta-interno__acoes {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ---- Página Keypads ---- */
.keypads-intro {
  padding: 80px 0;
  background: var(--cor-bg);
}

.keypads-intro__inner {
  max-width: var(--max-largura);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.keypads-intro p {
  color: rgba(255,255,255,.8);
  line-height: 1.8;
  margin-bottom: 18px;
  max-width: 760px;
}

.keypads-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  max-width: var(--max-largura);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.secao-keypads {
  padding: 80px 0;
  background: #141414;
}

.secao-keypads__inner {
  max-width: var(--max-largura);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.secao-keypads .secao-header {
  text-align: center;
  margin-bottom: 56px;
}

.keypad-card {
  background: #1c1c1c;
  border: 1px solid rgba(201,169,110,.15);
  border-radius: 10px;
  overflow: hidden;
  transition: border-color var(--trans-suave), transform var(--trans-suave), box-shadow var(--trans-suave);
  display: flex;
  flex-direction: column;
}

.keypad-card:hover {
  border-color: rgba(201,169,110,.45);
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,.4);
}

.keypad-card__imagem {
  height: 220px;
  overflow: hidden;
}

.keypad-card__imagem img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}

.keypad-card:hover .keypad-card__imagem img { transform: scale(1.06); }

.keypad-card__corpo {
  padding: 28px 24px 32px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.keypad-card__marca {
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--cor-ouro);
  margin-bottom: 8px;
}

.keypad-card__titulo {
  font-size: 1.2rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 12px;
  line-height: 1.3;
}

.keypad-card__desc {
  font-size: .92rem;
  color: var(--cor-texto-muted);
  line-height: 1.65;
  flex: 1;
  margin-bottom: 24px;
}

.keypad-card__link {
  align-self: flex-start;
  color: var(--cor-ouro);
  text-decoration: none;
  font-size: .9rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: gap var(--trans-rapida), color var(--trans-rapida);
}

.keypad-card__link:hover { gap: 10px; color: #e0c285; }

/* ---- Página Contato ---- */
.contato-hero {
  padding: 64px 0 56px;
  background: linear-gradient(135deg, #111 0%, #1a1a1a 100%);
  text-align: center;
}

.contato-hero__inner {
  max-width: 680px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.contato-hero__titulo {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  color: #fff;
  margin-bottom: 16px;
}

.contato-hero__titulo em {
  font-style: normal;
  color: var(--cor-ouro);
}

.contato-hero__subtitulo {
  color: rgba(255,255,255,.72);
  font-size: 1.05rem;
  line-height: 1.7;
}

.contato-principal {
  padding: 80px 0;
  background: var(--cor-bg);
}

.contato-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 60px;
  max-width: var(--max-largura);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.contato-info__titulo {
  font-size: 1.4rem;
  color: var(--cor-ouro);
  margin-bottom: 32px;
}

.contato-info__item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 28px;
  padding-bottom: 28px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.contato-info__item:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.contato-info__icone {
  width: 44px;
  height: 44px;
  min-width: 44px;
  background: rgba(201,169,110,.12);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cor-ouro);
}

.contato-info__icone svg { width: 20px; height: 20px; }

.contato-info__label {
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--cor-ouro);
  margin-bottom: 4px;
}

.contato-info__valor {
  color: rgba(255,255,255,.85);
  font-size: .97rem;
  line-height: 1.6;
}

.contato-info__valor a {
  color: rgba(255,255,255,.85);
  text-decoration: none;
  transition: color var(--trans-rapida);
}

.contato-info__valor a:hover { color: var(--cor-ouro); }

.contato-info__horario {
  margin-top: 32px;
  background: #141414;
  border: 1px solid rgba(201,169,110,.15);
  border-radius: 8px;
  padding: 24px;
}

.contato-info__horario h3 {
  font-size: 1rem;
  color: var(--cor-ouro);
  margin-bottom: 12px;
}

.contato-info__horario p {
  font-size: .9rem;
  color: var(--cor-texto-muted);
  line-height: 1.7;
  margin: 0;
}

/* Formulário de contato */
.contato-form__titulo {
  font-size: 1.4rem;
  color: var(--cor-ouro);
  margin-bottom: 32px;
}

.form-contato {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.form-grupo {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.form-grupo--2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.form-label {
  font-size: .85rem;
  font-weight: 500;
  color: rgba(255,255,255,.7);
  letter-spacing: .03em;
}

.form-input,
.form-select,
.form-textarea {
  background: #1c1c1c;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 6px;
  color: #fff;
  font-family: var(--fonte-corpo);
  font-size: .97rem;
  padding: 14px 16px;
  outline: none;
  transition: border-color var(--trans-rapida), box-shadow var(--trans-rapida);
  width: 100%;
  box-sizing: border-box;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--cor-ouro);
  box-shadow: 0 0 0 3px rgba(201,169,110,.15);
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: rgba(255,255,255,.56);
}

.form-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a96f56' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 18px;
  padding-right: 44px;
  cursor: pointer;
}

.form-select option { background: #1c1c1c; color: #fff; }

.form-textarea {
  resize: vertical;
  min-height: 140px;
}

.form-submit {
  align-self: flex-start;
}

/* ---- Mapa ---- */
.secao-mapa {
  padding: 0 0 80px;
  background: var(--cor-bg);
}

.mapa-wrapper {
  max-width: var(--max-largura);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.mapa-wrapper iframe {
  width: 100%;
  height: 380px;
  border: 0;
  border-radius: 10px;
  filter: grayscale(.8) contrast(1.1);
  display: block;
}

/* ============================================================
   RESPONSIVE — PÁGINAS INTERNAS
   ============================================================ */
@media (max-width: 900px) {
  .hero-interno__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .hero-interno__imagem img { height: 280px; }

  .intro-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .features-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .features-grid--4 {
    grid-template-columns: repeat(2, 1fr);
  }

  .keypads-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .contato-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
}

@media (max-width: 600px) {
  .hero-interno { padding: 48px 0 40px; }

  .features-grid,
  .features-grid--4,
  .features-grid--2 {
    grid-template-columns: 1fr;
  }

  .keypads-grid {
    grid-template-columns: 1fr;
  }

  .form-grupo--2col {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   CLIMAFLOW — componentes específicos
   ============================================================ */

/* Badge "Solução B2B" */
.climaflow-badge {
  display: inline-block;
  background: rgba(201,169,110,.18);
  border: 1px solid rgba(201,169,110,.4);
  color: var(--cor-ouro);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 20px;
}

/* Cards numerados (arquitetura 6 pilares) */
.feature-card--numerado {
  position: relative;
  padding-top: 44px;
}

.feature-card--numerado::before {
  content: attr(data-numero);
  position: absolute;
  top: 20px;
  right: 20px;
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .08em;
  color: rgba(201,169,110,.68);
}

/* Compatibilidade: marcas */
.secao-marcas {
  padding: 72px 0;
  background: #111;
  border-top: 1px solid rgba(201,169,110,.08);
  border-bottom: 1px solid rgba(201,169,110,.08);
}

.secao-marcas__inner { max-width: var(--max-largura); margin: 0 auto; padding: 0 var(--gutter); }

.marcas-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-bottom: 28px;
}

.marca-badge {
  background: #1c1c1c;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 12px 24px;
  font-size: .9rem;
  font-weight: 600;
  color: rgba(255,255,255,.75);
  letter-spacing: .04em;
  transition: border-color var(--trans-rapida), color var(--trans-rapida);
}

.marca-badge:hover {
  border-color: rgba(201,169,110,.4);
  color: var(--cor-ouro);
}

.marcas-obs {
  text-align: center;
  font-size: .85rem;
  color: var(--cor-texto-muted);
  max-width: 620px;
  margin: 0 auto;
}

/* Fluxo hotelaria 4 passos */
.secao-hotelaria {
  padding: 80px 0;
  background: var(--cor-bg);
}

.secao-hotelaria__inner { max-width: var(--max-largura); margin: 0 auto; padding: 0 var(--gutter); }

.hotel-fluxo {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  gap: 0;
  align-items: start;
}

.hotel-passo {
  background: #1c1c1c;
  border: 1px solid rgba(201,169,110,.15);
  border-radius: 10px;
  padding: 32px 24px;
  transition: border-color var(--trans-suave);
  position: relative;
}

.hotel-passo:hover { border-color: rgba(201,169,110,.4); }

.hotel-passo__numero {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .12em;
  color: var(--cor-ouro);
  margin-bottom: 16px;
}

.hotel-passo__icone {
  width: 44px;
  height: 44px;
  background: rgba(201,169,110,.1);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cor-ouro);
  margin-bottom: 16px;
}

.hotel-passo__icone svg { width: 22px; height: 22px; }

.hotel-passo__titulo {
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 10px;
}

.hotel-passo__desc {
  font-size: .88rem;
  color: var(--cor-texto-muted);
  line-height: 1.65;
}

.hotel-fluxo__seta {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  color: var(--cor-ouro);
  opacity: .5;
  margin-top: 60px;
}

.hotel-fluxo__seta svg { width: 24px; height: 24px; }

/* Segmentos */
.secao-segmentos {
  padding: 80px 0;
  background: #141414;
}

.secao-segmentos__inner { max-width: var(--max-largura); margin: 0 auto; padding: 0 var(--gutter); }

.segmentos-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.segmento-card {
  background: #1c1c1c;
  border: 1px solid rgba(201,169,110,.12);
  border-radius: 8px;
  padding: 28px 22px;
  transition: border-color var(--trans-suave), transform var(--trans-suave);
}

.segmento-card:hover {
  border-color: rgba(201,169,110,.4);
  transform: translateY(-4px);
}

.segmento-card__icone {
  width: 44px;
  height: 44px;
  background: rgba(201,169,110,.1);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cor-ouro);
  margin-bottom: 16px;
}

.segmento-card__icone svg { width: 22px; height: 22px; }

.segmento-card__titulo {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 10px;
}

.segmento-card__desc {
  font-size: .88rem;
  color: var(--cor-texto-muted);
  line-height: 1.65;
}

/* Dados gerenciais */
.secao-dados {
  padding: 80px 0;
  background: #111;
}

.secao-dados__inner { max-width: var(--max-largura); margin: 0 auto; padding: 0 var(--gutter); }

.dados-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-bottom: 64px;
}

.dado-card {
  background: linear-gradient(135deg, #1c1c1c 0%, #222 100%);
  border: 1px solid rgba(201,169,110,.2);
  border-radius: 10px;
  padding: 32px 24px;
  text-align: center;
}

.dado-card__valor {
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 800;
  color: var(--cor-ouro);
  line-height: 1;
  margin-bottom: 12px;
  font-family: var(--fonte-titulo);
}

.dado-card__label {
  font-size: .85rem;
  color: rgba(255,255,255,.65);
  line-height: 1.5;
}

.dados-detalhes {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.dado-detalhe {
  display: flex;
  gap: 24px;
  align-items: flex-start;
  padding: 28px;
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 8px;
}

.dado-detalhe__icone {
  width: 44px;
  height: 44px;
  min-width: 44px;
  background: rgba(201,169,110,.1);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cor-ouro);
}

.dado-detalhe__icone svg { width: 22px; height: 22px; }

.dado-detalhe__titulo {
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  margin-bottom: 8px;
}

.dado-detalhe__desc {
  font-size: .9rem;
  color: var(--cor-texto-muted);
  line-height: 1.65;
}

/* ---- ClimaFlow responsive ---- */
@media (max-width: 1024px) {
  .hotel-fluxo {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }

  .hotel-fluxo__seta {
    display: none;
  }

  .segmentos-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .dados-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .hotel-fluxo {
    grid-template-columns: 1fr;
  }

  .segmentos-grid {
    grid-template-columns: 1fr;
  }

  .dados-grid {
    grid-template-columns: 1fr 1fr;
  }

  .dado-detalhe {
    flex-direction: column;
    gap: 16px;
  }
}

/* ============================================================
   CLIMAFLOW — Hero e seções específicas da nova versão
   ============================================================ */

.cf-hero {
  background: #0e0e0e;
  padding: 80px 0 72px;
  border-bottom: 1px solid rgba(201,169,110,.12);
}

.cf-hero__inner {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.cf-hero__supertitulo {
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--cor-texto-muted);
  margin-bottom: 20px;
}

.cf-hero__label {
  display: inline-block;
  background: rgba(201,169,110,.18);
  border: 1px solid rgba(201,169,110,.4);
  color: var(--cor-ouro);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 24px;
}

.cf-hero__h1 {
  font-size: clamp(3.5rem, 9vw, 5.5rem);
  font-weight: 800;
  color: #fff;
  line-height: 1;
  margin-bottom: 24px;
  letter-spacing: -.02em;
}

.cf-hero__subtitulo {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  color: rgba(255,255,255,.75);
  line-height: 1.65;
  margin-bottom: 16px;
  max-width: 680px;
}

.cf-hero__desc {
  font-size: 1rem;
  color: var(--cor-texto-muted);
  line-height: 1.75;
  max-width: 680px;
  margin-bottom: 40px;
}

/* 4 cards intro */
.cf-intro-cards {
  padding: 72px 0;
  background: #111;
  border-bottom: 1px solid rgba(201,169,110,.08);
}

.cf-intro-cards__inner {
  max-width: var(--largura-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.cf-intro-cards__h2 {
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  font-weight: 600;
  color: rgba(255,255,255,.65);
  margin-bottom: 40px;
  max-width: 700px;
  line-height: 1.55;
}

.cf-intro-cards__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.cf-intro-card {
  background: #1a1a1a;
  border: 1px solid rgba(201,169,110,.12);
  border-top: 2px solid var(--cor-ouro);
  border-radius: 8px;
  padding: 28px 22px;
  transition: border-color var(--trans-suave);
}

.cf-intro-card:hover { border-color: rgba(201,169,110,.4); }

.cf-intro-card__titulo {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 10px;
}

.cf-intro-card__desc {
  font-size: .88rem;
  color: var(--cor-texto-muted);
  line-height: 1.65;
}

/* Dados gerenciais — lista */
.cf-dados {
  padding: 80px 0;
  background: #141414;
  border-top: 1px solid rgba(201,169,110,.08);
  border-bottom: 1px solid rgba(201,169,110,.08);
}

.cf-dados__inner {
  max-width: var(--largura-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.cf-dados__h3 {
  font-size: 1.15rem;
  font-weight: 700;
  color: #fff;
  margin: 40px 0 16px;
}

.cf-dados__desc {
  font-size: .95rem;
  color: var(--cor-texto-muted);
  line-height: 1.7;
  max-width: 700px;
  margin-bottom: 32px;
}

.cf-dados__lista {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.cf-dados__item {
  padding: 24px 28px;
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,.06);
  border-left: 3px solid var(--cor-ouro);
  border-radius: 6px;
}

.cf-dados__item-titulo {
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  margin-bottom: 6px;
}

.cf-dados__item-desc {
  font-size: .88rem;
  color: var(--cor-texto-muted);
  line-height: 1.6;
}

/* Premissas técnicas */
.cf-premissas {
  padding: 80px 0;
  background: #0e0e0e;
}

.cf-premissas__inner {
  max-width: var(--largura-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.cf-premissas__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}

.cf-premissa {
  background: #1c1c1c;
  border: 1px solid rgba(201,169,110,.12);
  border-radius: 8px;
  padding: 32px 24px;
  transition: border-color var(--trans-suave);
}

.cf-premissa:hover { border-color: rgba(201,169,110,.35); }

.cf-premissa__titulo {
  font-size: 1rem;
  font-weight: 700;
  color: var(--cor-ouro);
  margin-bottom: 12px;
}

.cf-premissa__desc {
  font-size: .9rem;
  color: var(--cor-texto-muted);
  line-height: 1.65;
}

/* ClimaFlow nova versão — responsive */
@media (max-width: 1024px) {
  .cf-intro-cards__grid { grid-template-columns: repeat(2, 1fr); }
  .cf-dados__lista       { grid-template-columns: 1fr; }
  .cf-premissas__grid    { grid-template-columns: 1fr; gap: 16px; }
}

@media (max-width: 600px) {
  .cf-intro-cards__grid { grid-template-columns: 1fr; }
  .cf-hero__h1          { font-size: 3rem; }
}

/* --------------------------------------------------------------------------
   mi-cf — Correções tipográficas para sans-serif
   Seletores de maior especificidade sobrepõem o inline CSS das páginas.
   -------------------------------------------------------------------------- */

:root {
  --mi-v2-black: #0f0f0f;
  --mi-v2-carbon: #151515;
  --mi-v2-carbon-2: #1d1d1f;
  --mi-v2-porcelain: #f6f3ed;
  --mi-v2-porcelain-2: #ebe5da;
  --mi-v2-stone: #d8cfc1;
  --mi-v2-ink: #191917;
  --mi-v2-muted: #5f5a53;
  --mi-v2-muted-strong: #46423d;
  --mi-v2-terra: #a96f56;
  --mi-v2-terra-dark: #8f5646;
  --mi-v2-champagne: #d9c6ad;
  --mi-v2-line-dark: rgba(25, 25, 23, .12);
  --mi-v2-line-light: rgba(247, 242, 234, .13);
  --mi-v2-radius-xl: 34px;
  --mi-v2-radius-lg: 26px;
  --mi-v2-radius-md: 18px;
  --mi-v2-shadow-deep: 0 34px 90px rgba(0, 0, 0, .38);
  --mi-v2-shadow-soft: 0 22px 60px rgba(0, 0, 0, .12);
  --mi-v2-header-offset: 124px;
}

.mi-container {
  width: min(1180px, calc(100% - 48px));
  margin-inline: auto;
}

.mi-section {
  padding: clamp(72px, 8vw, 120px) 0;
}

.mi-section-light {
  background: var(--mi-v2-porcelain);
  color: var(--mi-v2-ink);
}

.mi-section-dark {
  background: var(--mi-v2-black);
  color: var(--mi-v2-porcelain);
}

.mi-eyebrow,
.mi-cf .mi-cf-kicker,
.mi-cf .mi-cf-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 0 20px !important;
  color: rgba(247, 242, 234, .64) !important;
  font-size: 11px !important;
  font-weight: 760 !important;
  letter-spacing: .18em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

.mi-title-accent,
.mi-cf .mi-cf-hero h1 .mi-title-accent,
.mi-page-hero-title .mi-title-accent,
.hero-interno__titulo .mi-title-accent {
  color: var(--mi-v2-terra) !important;
}

.mi-eyebrow::before,
.mi-cf .mi-cf-kicker::before,
.mi-cf .mi-cf-eyebrow::before {
  content: "";
  width: 38px;
  height: 1px;
  background: var(--mi-v2-terra);
  flex: 0 0 auto;
}

.mi-page-hero,
.mi-cf .mi-cf-hero,
.hero-interno {
  padding-top: clamp(56px, 7vw, 92px) !important;
}

.mi-cf .mi-cf-hero {
  min-height: 780px !important;
}

.mi-cf .mi-cf-hero-inner {
  padding-top: 96px !important;
  padding-bottom: 96px !important;
}

.mi-cf .mi-cf-hero h1 {
  font-size: clamp(36px, 4.8vw, 64px) !important;
  line-height: 1.06 !important;
  font-weight: 700 !important;
  letter-spacing: -.03em !important;
  color: var(--mi-v2-porcelain) !important;
  text-wrap: balance;
}

.mi-cf .mi-cf-hero-card h2 {
  font-size: 24px !important;
  font-weight: 700 !important;
  line-height: 1.22 !important;
  letter-spacing: -.02em !important;
  color: var(--mi-v2-ink) !important;
}

.mi-cf .mi-cf-title {
  font-size: clamp(28px, 3.8vw, 52px) !important;
  line-height: 1.1 !important;
  font-weight: 700 !important;
  letter-spacing: -.025em !important;
  color: var(--mi-v2-ink) !important;
  text-wrap: balance;
}

.mi-cf .mi-cf-section-dark .mi-cf-title {
  color: var(--mi-v2-porcelain) !important;
}

.mi-cf .mi-cf-hero-sub,
.mi-cf .mi-cf-hero-text,
.mi-cf .mi-cf-section-dark .mi-cf-lead,
.mi-cf .mi-cf-section-dark .mi-cf-step p {
  color: rgba(247, 242, 234, .76) !important;
}

.mi-cf .mi-cf-lead,
.mi-cf .mi-cf-card p,
.mi-cf .mi-cf-market p,
.mi-cf .mi-cf-panel p,
.mi-cf .mi-cf-list span,
.mi-cf .mi-cf-mini span {
  color: var(--mi-v2-muted-strong) !important;
}

.mi-cf .mi-cf-card h3,
.mi-cf .mi-cf-market h3,
.mi-cf .mi-cf-panel h3,
.mi-cf .mi-cf-list strong {
  color: var(--mi-v2-ink) !important;
}

.mi-card,
.mi-cf .mi-cf-card,
.mi-cf .mi-cf-market,
.mi-cf .mi-cf-panel,
.mi-cf .mi-cf-list div {
  border-radius: var(--mi-v2-radius-lg) !important;
  border-color: var(--mi-v2-line-dark) !important;
  box-shadow: 0 14px 40px rgba(20, 20, 20, .07) !important;
}

.mi-btn,
.mi-cf .mi-cf-btn,
.mi-cf .mi-cf-cta-btn,
.mi-cf .mi-cf-btn-outline {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 44px !important;
  padding: 0 20px !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: -.01em !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  transition: transform .16s ease, background .16s ease, border-color .16s ease, color .16s ease !important;
}

.mi-btn:hover,
.mi-cf .mi-cf-btn:hover,
.mi-cf .mi-cf-cta-btn:hover,
.mi-cf .mi-cf-btn-outline:hover {
  transform: translateY(-1px);
}

.mi-btn-primary {
  background: var(--mi-v2-porcelain);
  color: #141414;
  border-color: rgba(255, 255, 255, .10);
  box-shadow: 0 10px 26px rgba(0, 0, 0, .14);
}

.mi-btn-outline,
.mi-cf .mi-cf-btn-outline {
  background: rgba(247, 242, 234, .04) !important;
  border-color: rgba(247, 242, 234, .18) !important;
  color: rgba(247, 242, 234, .82) !important;
}

.mi-btn-terra,
.mi-cf .mi-cf-btn,
.mi-cf .mi-cf-cta-btn {
  background: var(--mi-v2-terra) !important;
  color: #fff !important;
  border-color: rgba(255, 255, 255, .10) !important;
  box-shadow: 0 10px 28px rgba(169, 111, 86, .28) !important;
}

.mi-btn-terra:hover,
.mi-cf .mi-cf-btn:hover,
.mi-cf .mi-cf-cta-btn:hover {
  background: var(--mi-v2-terra-dark) !important;
  color: #fff !important;
}

.mi-cf .mi-cf-kicker,
.mi-cf .mi-cf-eyebrow {
  color: rgba(25, 25, 23, .64) !important;
}

.mi-cf .mi-cf-hero .mi-cf-kicker,
.mi-cf .mi-cf-section-dark .mi-cf-kicker,
.mi-cf .mi-cf-section-dark .mi-cf-eyebrow {
  color: rgba(247, 242, 234, .66) !important;
}

.mi-cf .mi-cf-hero .mi-cf-kicker {
  display: none !important;
}

.btn--ouro,
.btn--primario {
  border-radius: 999px !important;
  background: var(--mi-v2-terra) !important;
  color: #fff !important;
  border-color: rgba(255, 255, 255, .10) !important;
}

.btn--contorno,
.btn--secundario {
  border-radius: 999px !important;
  background: rgba(247, 242, 234, .04) !important;
  border: 1px solid rgba(247, 242, 234, .18) !important;
  color: rgba(247, 242, 234, .82) !important;
}

.mi-cf .mi-cf-card-num,
.mi-cf .mi-cf-step strong {
  background: rgba(169, 111, 86, .11) !important;
  color: var(--mi-v2-terra) !important;
  border-radius: 999px !important;
}

.mi-cf .mi-cf-cta h2 {
  font-size: clamp(28px, 3.8vw, 52px) !important;
  line-height: 1.08 !important;
  font-weight: 700 !important;
  letter-spacing: -.025em !important;
}

.mi-cf .mi-cf-step strong {
  font-size: 40px !important;
  font-weight: 700 !important;
  letter-spacing: -.02em !important;
}

@media (max-width: 980px) {
  :root {
    --mi-v2-header-offset: 96px;
  }

  .mi-cf .mi-cf-hero-inner {
    padding-top: 72px !important;
    padding-bottom: 72px !important;
  }
}

@media (max-width: 640px) {
  .mi-container {
    width: calc(100% - 40px);
  }

  .mi-cf .mi-cf-kicker,
  .mi-cf .mi-cf-eyebrow,
  .mi-eyebrow {
    letter-spacing: .12em !important;
  }

  .mi-cf .mi-cf-hero h1 {
    font-size: clamp(34px, 11vw, 48px);
  }
}
