:root {
    --color-primary: #708440;
    --color-ink: #39414D;
    --color-bg: #ffffff;
  
    --container-max: 1200px;
    --container-pad: 16px;
  
    --radius: 10px;
    --shadow: 0 10px 30px rgba(0,0,0,.08);
  
    --font-sans: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  
    --nav-height: 76px;
    --z-header: 50;
  
    /* larguras fixas (mantêm alinhamento independente do texto) */
    --dd-width: 340px;
    --sd-width: 230px;
  }
  
  * { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  html, body {
  
}

  body {
    font-family: var(--font-sans);
    color: var(--color-ink);
    background: var(--color-bg);
  }
  
  .sr-only {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    
    white-space: nowrap; border: 0;
  }
  
  .container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-pad);
  }
  
  /* Header sticky */
  .site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: #ffffff;
  }
  
  
  .header-inner {
    min-height: var(--nav-height);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
  }
  
  /* Logo */
  .brand {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: var(--color-ink);
  }
  .brand__logo {
    height: 44px;      /* ajuste fino conforme a sua logo */
    width: auto;
    display: block;
  }
  
  /* Nav */
  .nav__list {
    list-style: none;
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 0;
    margin: 0;
  }
  
  .nav__item { position: relative; }
  
  .nav__link {
    text-decoration: none;
    color: var(--color-ink);
    font-weight: 500;
    padding: 10px 10px;
    border-radius: 8px;
  }
  
  .nav__link:hover,
  .nav__link:focus-visible {
    outline: none;
    background: rgba(112,132,64,.12);
  }
  
  /* CTA */
  .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-weight: 600;
    border-radius: 12px;
    padding: 10px 14px;
    border: 1px solid transparent;
    cursor: pointer;
  }
  .btn--primary {
    background: var(--color-primary);
    color: #fff;
  }
  .btn--primary:hover,
  .btn--primary:focus-visible {
    outline: none;
    filter: brightness(.95);
  }
  
  /* Mobile toggle */
  .nav-toggle {
    display: none;
    background: transparent;
    border: 1px solid rgba(57,65,77,.18);
    border-radius: 10px;
    padding: 10px;
  }
  .nav-toggle__bar {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--color-ink);
    margin: 4px 0;
  }
  
  /* Dropdown toggles (setinhas) */
  .dropdown-toggle,
  .subdropdown-toggle {
    display: none; /* só aparece no mobile */
    background: transparent;
    border: 0;
    color: var(--color-ink);
    font-size: 16px;
    padding: 8px 8px;
    border-radius: 8px;
  }
  .dropdown-toggle:focus-visible,
  .subdropdown-toggle:focus-visible {
    outline: 2px solid rgba(112,132,64,.45);
    outline-offset: 2px;
  }
  
  /* Dropdowns (desktop) */
  .has-dropdown,
  .has-subdropdown {
    position: relative;
  }
  
  .dropdown {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    display: none;
    background: #fff;
    border: 1px solid rgba(57,65,77,.12);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 10px;
    width: var(--dd-width); /* largura fixa */
  }
  
  .dropdown__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 6px;
  }
  
  .dropdown__item {
    position: relative;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  
  /* Link ocupa espaço previsível e alinhado */
  .dropdown__link {
    flex: 1;
    display: flex;
    align-items: center;
    text-decoration: none;
    color: var(--color-ink);
    padding: 10px 10px;
    border-radius: 8px;
    min-height: 40px;
  }
  
  .dropdown__link:hover,
  .dropdown__link:focus-visible {
    outline: none;
    background: rgba(57,65,77,.06);
  }
  
  .subdropdown {
    position: absolute;
    top: -10px;
    left: calc(100% + 10px);
    display: none;
    background: #fff;
    border: 1px solid rgba(57,65,77,.12);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 10px;
    width: var(--sd-width); /* largura fixa */
  }
  
  .subdropdown__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 6px;
  }
  
  .subdropdown__link {
    display: block;
    text-decoration: none;
    color: var(--color-ink);
    padding: 10px 10px;
    border-radius: 8px;
  }
  .subdropdown__link:hover,
  .subdropdown__link:focus-visible {
    outline: none;
    background: rgba(57,65,77,.06);
  }
  
  /* Hover no desktop */
  @media (min-width: 901px) {
    .has-dropdown:hover > .dropdown,
    .has-dropdown:focus-within > .dropdown {
      display: block;
    }
  
    .has-subdropdown:hover > .subdropdown,
    .has-subdropdown:focus-within > .subdropdown {
      display: block;
    }
  }
  
  /* Mobile */
  @media (max-width: 900px) {
    .nav-toggle { display: inline-flex; align-items: center; justify-content: center; }
  
    .nav {
      display: none;
      position: absolute;
      left: 0;
      right: 0;
      top: var(--nav-height);
      background: #fff;
      border-bottom: 1px solid rgba(57,65,77,.12);
    }
    .nav.is-open { display: block; }
  
    .nav__list {
      flex-direction: column;
      align-items: stretch;
      gap: 12px;
      padding: 10px var(--container-pad) 14px;
    }
  
    .nav__item--cta .btn { width: 100%; }
  
    /* Mostrar botões de toggle no mobile */
    .dropdown-toggle,
    .subdropdown-toggle { display: inline-flex; }
  
    /* Dropdowns em fluxo (sem flyout lateral) */
    .dropdown,
    .subdropdown {
      position: static;
      width: 100%;
      box-shadow: none;
      margin-top: 6px;
      display: none;
    }
  
    /* Quando a li está "aberta" via JS */
    .has-dropdown.is-open > .dropdown { display: block; }
    .has-subdropdown.is-open > .subdropdown { display: block; }
  }

  /* =========================
   HERO (Main)
========================= */
.hero {
  display: grid;
  grid-template-columns: 40% 60%;
  align-items: center;
  gap: 28px;
  padding: 34px 0 26px;
  margin-top: 80px;
}

.hero__content {
  max-width: 520px;
}

.hero__eyebrow {
  margin: 0 0 10px;
  font-weight: 400;          /* mais fina */
  color: rgba(57,65,77,.85);
  line-height: 1.3;
}

.hero__title {
  margin: 0 0 18px;
  font-weight: 550;          /* destaque */
  font-size: clamp(28px, 3.2vw, 44px);
  line-height: 1.1;
  letter-spacing: -0.4px;
}

.hero__actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

/* Link "Ver mais" */
.link {
  color: var(--color-ink);
  font-weight: 600;
  text-decoration: none;
  padding: 10px 6px;
  border-radius: 8px;
}

.link--more:hover,
.link--more:focus-visible {
  outline: none;
  background: rgba(57,65,77,.06);
}

/* Imagem */
.hero__media {
  width: 100%;
}

.hero__mediaLink {
  display: block;
  border-radius: 16px;
  
  text-decoration: none;
  border: 1px solid rgba(57,65,77,.12);
}

.hero__image {
  display: block;
  width: 100%;
  height: min(420px, 52vh);
  object-fit: cover;
}

/* =========================
   Responsivo
========================= */
@media (max-width: 900px) {
  .hero {
    grid-template-columns: 1fr;
    padding: 22px 0 18px;
  }

  .hero__content {
    max-width: 100%;
  }

  .hero__image {
    height: 320px;
  }
}/* =========================
   Hero Badge
========================= */

.hero__mediaLink {
  position: relative; /* necessário para posicionar o badge */
}

.hero__badge {
  position: absolute;
  top: 16px;
  left: 16px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #ffffff 0.1;
  padding: 8px 14px;
  border-radius: 999px;
  /*box-shadow: 0 6px 20px rgba(0,0,0,.12);*/
  z-index: 2;
}

.hero__badgeIcon {
  color: var(--color-primary);
  font-size: 32px;
  line-height: 1;
}

.hero__badgeText {
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.5px;
  color: var(--color-ink);
}

/* Fix: dropdown do menu acima do hero */
.site-header { 
  z-index: 999; 
}

.dropdown,
.subdropdown {
  position: absolute; /* garante que z-index funcione (desktop) */
  z-index: 1000;
}

/*Icones e vantagens Mazzu */

/* =========================
   Features (full width background)
========================= */
.features {
  width: 100%;
  background: var(--color-ink); /* #39414D */
  padding: 34px 0;
  margin-top: 24px; /* ajuste se quiser mais/menos distância do hero */
}

.features__inner {
  /* usa o .container (max-width 1200px) já existente */
}

.features__grid {
  list-style: none;
  padding: 0;
  margin: 0;

  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.features__item {
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 10px;

  padding: 14px 10px;
  border-radius: 14px;
}

.features__icon {
  width: 52px;
  height: 52px;
  border-radius: 999px;
  display: grid;
  place-items: center;

  background: rgba(255,255,255,.10);
  color: var(--color-primary); /* #708440 */
  font-size: 20px;
}

/* até 2 linhas abaixo do ícone */
.features__text {
  margin: 0;
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  line-height: 1.25;

  display: -webkit-box;
  -webkit-line-clamp: 2;        /* limita a 2 linhas */
  -webkit-box-orient: vertical;
  
}

@media (max-width: 900px) {
  .features {
    padding: 26px 0;
  }

  .features__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }

  .features__icon {
    width: 48px;
    height: 48px;
  }
}

@media (max-width: 520px) {
  .features__grid {
    grid-template-columns: 1fr;
  }
}

/* =========================
   Features (full width background)
========================= */
.features {
  width: 100%;
  background: var(--color-ink); /* #39414D */
  padding: 34px 0;
  margin-top: 100px; /* ajuste se quiser mais/menos distância do hero */
}

.features__inner {
  /* usa o .container (max-width 1200px) já existente */
}

.features__grid {
  list-style: none;
  padding: 0;
  margin: 0;

  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.features__item {
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 10px;

  padding: 14px 10px;
  border-radius: 14px;
}

.features__icon {
  width: 52px;
  height: 52px;
  object-fit: contain;
  display: block;
}


/* até 2 linhas abaixo do ícone */
.features__text {
  margin: 0;
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  line-height: 1.25;

  display: -webkit-box;
  -webkit-line-clamp: 2;        /* limita a 2 linhas */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (max-width: 900px) {
  .features {
    padding: 26px 0;
  }

  .features__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }

  .features__icon {
    width: 48px;
    height: 48px;
  }
}

@media (max-width: 520px) {
  .features__grid {
    grid-template-columns: 1fr;
  }
}

/* =========================
   Best Sellers (Carousel)
========================= */
.best-sellers {
  padding: 42px 0 24px;
}

.section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.section-title {
  margin: 0;
  font-size: 22px;
  font-weight: 700;
  color: var(--color-ink);
}

/* Carrossel leve: scroll horizontal + snap */
.carousel {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding: 8px 2px 14px;

  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

/* Barra de rolagem discreta (opcional) */
.carousel::-webkit-scrollbar { height: 8px; }
.carousel::-webkit-scrollbar-thumb { background: rgba(57,65,77,.18); border-radius: 999px; }
.carousel::-webkit-scrollbar-track { background: rgba(57,65,77,.06); border-radius: 999px; }

/* Card quadrado responsivo */
.card {
  position: relative;
  flex: 0 0 auto;
  width: clamp(140px, 18vw, 220px); /* responsivo */
  aspect-ratio: 1 / 1;             /* quadrado */
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(57,65,77,.12);
  text-decoration: none;

  scroll-snap-align: start;
}

.card__img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* Badge do 1º item */
.card__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #39414d;
  
  padding: 8px 12px;
  border-radius: 999px;
  box-shadow: 0 6px 20px rgba(0,0,0,.12);
  z-index: 2;
}

.card__badgeIcon {
  color: var(--color-primary);
  font-size: 24px;
  line-height: 1;
}

.card__badgeText {
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.4px;
  color: var(--color-bg);
}

/* Acessibilidade: foco visível */
.card:focus-visible {
  outline: 3px solid rgba(112,132,64,.45);
  outline-offset: 2px;
}
/* Setas do carrossel */
.carousel-wrap {
  position: relative;
}

.carousel-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;

  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(57,65,77,.18);
  background: #fff;
  color: var(--color-ink);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;

  display: grid;
  place-items: center;

  box-shadow: 0 8px 22px rgba(0,0,0,.10);
}

.carousel-btn--left { left: -6px; }
.carousel-btn--right { right: -6px; }

.carousel-btn:hover,
.carousel-btn:focus-visible {
  outline: none;
  border-color: rgba(112,132,64,.45);
}

/* dá “respiro” para não esconder o primeiro/último card atrás do botão */
.carousel {
  padding-left: 46px;
  padding-right: 46px;
}
@media (max-width: 900px) {
  .carousel-btn {
    display: none;
  }

  /* remove o “respiro” extra quando não há setas */
  .carousel {
    padding-left: 2px;
    padding-right: 2px;
  }
}

/* BOTÃO FLUTUANTE WHATSAPP */
/* =========================
   WhatsApp Floating Button
========================= */
.wa-float {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 2000;

  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 12px 14px;
  border-radius: 999px;

  background: var(--color-primary); /* #708440 */
  color: #fff;
  text-decoration: none;
  font-weight: 700;

  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 12px 30px rgba(0,0,0,.18);
}

.wa-float:hover,
.wa-float:focus-visible {
  outline: none;
  filter: brightness(.95);
}

.wa-float__icon {
  width: 34px;
  height: 34px;
  border-radius: 999px;

  display: grid;
  place-items: center;

  background: rgba(255,255,255,.16);
  line-height: 1;
}

.wa-float__text {
  font-size: 14px;
  letter-spacing: .2px;
}

/* Mobile: opcional deixar só o ícone para não ocupar espaço */
@media (max-width: 520px) {
  .wa-float__text { display: none; }
  .wa-float { padding: 12px; }
}
@keyframes waPulse {
  0% { box-shadow: 0 0 0 0 rgba(112,132,64,.6); }
  70% { box-shadow: 0 0 0 12px rgba(112,132,64,0); }
  100% { box-shadow: 0 0 0 0 rgba(112,132,64,0); }
}

.wa-float {
  animation: waPulse 2.5s infinite;
}

/* =========================
   Home PRODUTOS EM DESTAQUE (wireframe)
========================= */
.home-products {
  padding: 42px 0 28px;
}

.cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

/* Card */
.p-card {
  border: 1px solid rgba(57,65,77,.14);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  display: grid;
  grid-template-rows: auto 1fr;
}

/* Imagem em cima */
.p-card__media {
  display: block;
  text-decoration: none;
}

.p-card__img {
  width: 100%;
  aspect-ratio: 16 / 10;   /* ajuste aqui se quiser mais alto/baixo */
  object-fit: cover;
  display: block;
}

/* Conteúdo */
.p-card__body {
  padding: 14px 14px 16px;
  display: grid;
  gap: 10px;
}

.p-card__title {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-ink);
}

.p-card__desc {
  margin: 0;
  color: rgba(57,65,77,.82);
  line-height: 1.35;
  font-weight: 500;

  display: -webkit-box;
  -webkit-line-clamp: 3;   /* até 3 linhas como no wireframe */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.p-card__link {
  justify-self: start;
  text-decoration: underline;
  font-weight: 500;
  color: var(--color-primary);
  padding: 8px 6px;
  border-radius: 8px;
}

.p-card__link:hover,
.p-card__link:focus-visible {
  outline: none;
  background: rgba(112,132,64,.12);
}

/* Interação leve no card inteiro */
.p-card:hover {
  border-color: rgba(112,132,64,.35);
}

/* Responsivo */
@media (max-width: 900px) {
  .cards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 520px) {
  .cards-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================
   B2B CTA Section (wireframe)
========================= */
.b2b-cta {
  padding: 54px 0;
  background: rgba(57,65,77,.04);
  border-top: 1px solid rgba(57,65,77,.08);
  border-bottom: 1px solid rgba(57,65,77,.08);
}

.b2b-cta__inner {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 26px;
  align-items: center;
}

.b2b-cta__title {
  margin: 0 0 10px;
  font-size: clamp(22px, 2.2vw, 32px);
  line-height: 1.15;
  letter-spacing: -0.3px;
  color: var(--color-ink);
}

.b2b-cta__text {
  margin: 0 0 18px;
  color: rgba(57,65,77,.82);
  font-weight: 500;
  line-height: 1.45;
  max-width: 60ch;
}

.b2b-cta__actions {
  display: grid;
  gap: 10px;
  justify-items: start;
}

.b2b-cta__link {
  font-weight: 700;
  color: var(--color-ink);
  text-decoration: none;
  padding: 8px 6px;
  border-radius: 8px;
}

.b2b-cta__link:hover,
.b2b-cta__link:focus-visible {
  outline: none;
  background: rgba(112,132,64,.12);
}

.b2b-cta__media {
  display: grid;
  justify-items: end;
}

.b2b-cta__placeholder {
  width: min(420px, 100%);
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  background: rgba(57,65,77,.14);
  position: relative;
  overflow: hidden;
}

.b2b-cta__ph-item {
  position: absolute;
  border-radius: 16px;
  background: rgba(255,255,255,.12);
}

.b2b-cta__ph-item:nth-child(1) {
  width: 76%;
  height: 40%;
  left: 10%;
  top: 14%;
}

.b2b-cta__ph-item:nth-child(2) {
  width: 76%;
  height: 40%;
  left: 10%;
  top: 54%;
}

/* Responsive */
@media (max-width: 900px) {
  .b2b-cta__inner {
    grid-template-columns: 1fr;
  }
  .b2b-cta__media {
    justify-items: start;
  }
  .b2b-cta {
    padding: 40px 0;
  }
}



/* =========================
   Produtos (page only)
========================= */
.products-page{
  padding: 34px 0 60px;
}

.products-head{
  margin: 10px 0 18px;
}

.products-title{
  margin: 0 0 6px;
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 800;
  letter-spacing: -0.4px;
  color: var(--color-ink);
}

.products-subtitle{
  margin: 0;
  max-width: 70ch;
  color: rgba(57,65,77,.78);
  font-weight: 500;
  line-height: 1.45;
}

.products-controls{
  margin-top: 16px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(57,65,77,.10);
  background: rgba(57,65,77,.03);
}

.filters__row{
  display: grid;
  grid-template-columns: 1.2fr 0.9fr 0.8fr 0.8fr auto;
  gap: 12px;
  align-items: end;
}

.filters__actions{
  display: inline-flex;
  gap: 10px;
  align-items: center;
  white-space: nowrap;
}

.filters__meta{
  margin-top: 10px;
  color: rgba(57,65,77,.78);
  font-weight: 600;
  font-size: 13px;
}

.products-grid{
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

/* Card */
.p-card2{
  border: 1px solid rgba(57,65,77,.14);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  display: grid;
  grid-template-rows: auto 1fr;
}

.p-card2__media{
  display:block;
  text-decoration:none;
}

.p-card2__img{
  width:100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display:block;
}

.p-card2__body{
  padding: 14px 14px 16px;
  display:grid;
  gap:10px;
}

.p-card2__title{
  margin:0;
  font-size:18px;
  font-weight:800;
  color: var(--color-ink);
}

.p-card2__desc{
  margin:0;
  color: rgba(57,65,77,.82);
  font-weight:500;
  line-height:1.35;

  display:-webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow:hidden;
}

.p-card2__link{
  justify-self:start;
  text-decoration:none;
  font-weight:800;
  color: var(--color-ink);
  padding:8px 6px;
  border-radius:8px;
}

.p-card2__link:hover,
.p-card2__link:focus-visible{
  outline:none;
  background: rgba(112,132,64,.12);
}

.p-card2:hover{
  border-color: rgba(112,132,64,.35);
}

.products-empty{
  grid-column: 1 / -1;
  padding: 18px;
  border-radius: 16px;
  border: 1px dashed rgba(57,65,77,.22);
  background: rgba(57,65,77,.02);
  color: rgba(57,65,77,.85);
}

/*RESPONSIVO */

.products-grid{
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(4, 1fr); /* desktop */
  gap: 18px;
}

@media (max-width: 1000px){
  .products-grid{
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px){
  .products-grid{
    grid-template-columns: repeat(2, 1fr); /* mobile */
  }
}

[hidden] { display: none !important; visibility: hidden !important; }

/* =========================
   Footer (global)
========================= */
.site-footer{
  background: #39414D;
  color: rgba(255,255,255,.88);
  margin-top: 60px;
}

.footer__inner{
  padding: 44px 0 28px;
  display: grid;
  grid-template-columns: 1.35fr .85fr 1.1fr;
  gap: 26px;
}

.footer__title{
  color: #fff;
  font-weight: 800;
  margin: 0 0 10px;
  font-size: 15px;
  letter-spacing: .2px;
}

.footer__muted{
  color: rgba(255,255,255,.72);
  font-weight: 500;
  margin-bottom: 12px;
}

.footer__list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
  font-weight: 400;
  line-height: 1.35;
}

.footer__address{
  margin-top: 6px;
}

.footer__sep{
  margin: 0 8px;
  color: rgba(255,255,255,.45);
}

.footer__link{
  color: rgba(255,255,255,.90);
  text-decoration: none;
  font-weight: 200;
  font-family: montserrat;
}

.footer__link:hover,
.footer__link:focus-visible{
  outline: none;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.footer__list--links{
  gap: 10px;
}

.footer__mapbox{
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
}

.footer__mapbox iframe{
  width: 100%;
  height: 220px;
  border: 0;
  display: block;
}

.footer__map-placeholder{
  height: 220px;
  display: grid;
  place-items: center;
  color: rgba(255,255,255,.70);
  font-weight: 700;
  padding: 12px;
  text-align: center;
}

.footer__btn{
  display: inline-block;
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(112,132,64,.95);
  color: #fff;
  text-decoration: none;
  font-weight: 600;
}

.footer__btn:hover,
.footer__btn:focus-visible{
  outline: none;
  filter: brightness(1.05);
}

.footer__bottom{
  border-top: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.12);
}

.footer__bottom-inner{
  padding: 14px 0;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  align-items: center;
  color: rgba(255,255,255,.72);
  font-weight: 600;
  font-size: 13px;
}

/* Responsivo */
@media (max-width: 1000px){
  .footer__inner{
    grid-template-columns: 1fr 1fr;
  }
  .footer__map{
    grid-column: 1 / -1;
  }
}

@media (max-width: 620px){
  .footer__inner{
    grid-template-columns: 1fr;
  }
  .footer__bottom-inner{
    flex-direction: column;
    align-items: flex-start;
  }
}



/* =========================
   Produto (page)
========================= */
.product-page{
  padding: 22px 0 60px;
}

.product-crumb{
  display:flex;
  gap:10px;
  align-items:center;
  font-weight:700;
  color: rgba(57,65,77,.76);
  margin: 10px 0 16px;
}

.product-crumb__link{
  color: rgba(57,65,77,.86);
  text-decoration:none;
}

.product-crumb__link:hover,
.product-crumb__link:focus-visible{
  outline:none;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.product-top{
  display:grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 26px;
  align-items:start;
}

.product-gallery__main{
  border-radius: 18px;
  border: 1px solid rgba(57,65,77,.14);
  background: rgba(57,65,77,.03);
  overflow:hidden;
}

.product-gallery__img{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  padding: 10px;
}

.product-gallery__thumbs{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
}

.thumb{
  border: 1px solid rgba(57,65,77,.16);
  border-radius: 14px;
  background: #fff;
  padding: 6px;
  cursor:pointer;
}

.thumb__img{
  width:100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display:block;
  border-radius: 10px;
}

.thumb.is-active{
  border-color: rgba(112,132,64,.55);
  box-shadow: 0 0 0 3px rgba(112,132,64,.14);
}

.product-title{
  margin: 0 0 10px;
  font-size: clamp(24px, 2.6vw, 40px);
  font-weight: 800;
  letter-spacing: -0.4px;
  color: var(--color-ink);
}

.product-desc p{
  margin: 0 0 10px;
  color: rgba(57,65,77,.84);
  font-weight: 500;
  line-height: 1.55;
}

.product-block{
  margin-top: 16px;
}

.product-block__label{
  font-weight: 800;
  color: rgba(57,65,77,.92);
  margin-bottom: 8px;
}

.product-pills{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.pill{
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(57,65,77,.18);
  background: rgba(57,65,77,.03);
  font-weight: 900;
  cursor: pointer;
  min-width: 48px;
}

.pill.is-active{
  border-color: rgba(112,132,64,.55);
  background: rgba(112,132,64,.12);
}

.product-swatches{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items:center;
}

.swatch{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(57,65,77,.20);
  background: #fff;
  display:grid;
  place-items:center;
  cursor:pointer;
}

.swatch__dot{
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
}

.swatch.is-active{
  border-color: rgba(112,132,64,.60);
  box-shadow: 0 0 0 3px rgba(112,132,64,.16);
}

.product-colorname{
  margin-top: 8px;
  font-weight: 800;
  color: rgba(57,65,77,.86);
}

.product-cta{
  margin-top: 18px;
  display:flex;
  gap: 14px;
  align-items:center;
  flex-wrap: wrap;
}

.product-cta__btn{
  padding: 12px 16px;
  border-radius: 14px;
}

.product-cta__link{
  color: rgba(57,65,77,.92);
  font-weight: 600;
  text-decoration: underline;
  padding: 10px 8px;
  border-radius: 10px;
}

.product-cta__link:hover,
.product-cta__link:focus-visible{
  outline:none;
  background: rgba(112,132,64,.12);
}

/* Accordions */
.product-sections{
  margin-top: 22px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.accordion{
  border: 1px solid rgba(57,65,77,.14);
  border-radius: 16px;
  background: #fff;
  overflow: hidden;
}

.accordion__summary{
  list-style:none;
  cursor:pointer;
  padding: 14px 14px;
  font-weight: 900;
  color: rgba(57,65,77,.92);
  background: rgba(57,65,77,.03);
}

.accordion__summary::-webkit-details-marker{ display:none; }

.accordion__content{
  padding: 14px 14px 16px;
  color: rgba(57,65,77,.84);
  font-weight: 500;
  line-height: 1.55;
}

/* Conteúdos simples */
.p-list{ margin:0; padding-left: 18px; }
.p-list li{ margin: 6px 0; }
.p-kv{ display:grid; gap: 8px; margin-bottom: 10px; }
.p-note{ margin: 10px 0 0; color: rgba(57,65,77,.72); font-weight: 600; }

/* Responsivo */
@media (max-width: 980px){
  .product-top{
    grid-template-columns: 1fr;
  }
  .product-gallery__thumbs{
    grid-template-columns: repeat(5, 1fr);
  }
  .product-sections{
    grid-template-columns: 1fr;
  }
}

/* =========================
   B2B CTA Section (wireframe)
========================= */
.b2b-cta {
  padding: 54px 0;
  background: rgba(57,65,77,.04);
  border-top: 1px solid rgba(57,65,77,.08);
  border-bottom: 1px solid rgba(57,65,77,.08);
}

.b2b-cta__inner {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 26px;
  align-items: center;
}

.b2b-cta__title {
  margin: 0 0 10px;
  font-size: clamp(22px, 2.2vw, 32px);
  line-height: 1.15;
  letter-spacing: -0.3px;
  color: var(--color-ink);
}

.b2b-cta__text {
  margin: 0 0 18px;
  color: rgba(57,65,77,.82);
  font-weight: 500;
  line-height: 1.45;
  max-width: 60ch;
}

.b2b-cta__actions {
  display: grid;
  gap: 10px;
  justify-items: start;
}

.b2b-cta__link {
  font-weight: 700;
  color: var(--color-ink);
  text-decoration: none;
  padding: 8px 6px;
  border-radius: 8px;
}

.b2b-cta__link:hover,
.b2b-cta__link:focus-visible {
  outline: none;
  background: rgba(112,132,64,.12);
}

.b2b-cta__media {
  display: grid;
  justify-items: end;
}

.b2b-cta__placeholder {
  width: min(420px, 100%);
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  background: rgba(57,65,77,.14);
  position: relative;
  overflow: hidden;
}

.b2b-cta__ph-item {
  position: absolute;
  border-radius: 16px;
  background: rgba(255,255,255,.12);
}

.b2b-cta__ph-item:nth-child(1) {
  width: 76%;
  height: 40%;
  left: 10%;
  top: 14%;
}

.b2b-cta__ph-item:nth-child(2) {
  width: 76%;
  height: 40%;
  left: 10%;
  top: 54%;
}

/* Responsive */
@media (max-width: 900px) {
  .b2b-cta__inner {
    grid-template-columns: 1fr;
  }
  .b2b-cta__media {
    justify-items: start;
  }
  .b2b-cta {
    padding: 40px 0;
  }
}

/* =========================
   Modal
========================= */
.modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 3000;
}

.modal.is-open { display: block; }

.modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.45);
}

.modal__panel {
  position: relative;
  width: min(920px, calc(100% - 24px));
  max-height: calc(100vh - 40px); /* limita altura */
  margin: 20px auto;

  background: #fff;
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.22);

  display: flex;
  flex-direction: column;

  overflow: hidden;
}

/* Faz o formulário rolar internamente */
.form {
  overflow-y: auto;
  padding: 16px 18px 18px;
}
.modal__head {
  padding: 18px 18px 12px;
  border-bottom: 1px solid rgba(57,65,77,.10);
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.form::-webkit-scrollbar {
  width: 8px;
}

.form::-webkit-scrollbar-thumb {
  background: rgba(57,65,77,.25);
  border-radius: 999px;
}

.form::-webkit-scrollbar-track {
  background: transparent;
}

.modal__title {
  margin: 0;
  font-weight: 800;
  color: var(--color-ink);
  font-size: 18px;
}

.modal__subtitle {
  margin: 4px 0 0;
  color: rgba(57,65,77,.75);
  font-weight: 500;
  font-size: 13px;
}

.modal__close {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid rgba(57,65,77,.14);
  background: #fff;
  color: var(--color-ink);
  font-size: 22px;
  cursor: pointer;
}

.modal__close:hover,
.modal__close:focus-visible {
  outline: none;
  border-color: rgba(112,132,64,.45);
}

/* Form */
.form {
  padding: 16px 18px 18px;
}

.form__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.field--full { grid-column: 1 / -1; }

.field__label {
  display: block;
  font-weight: 700;
  font-size: 13px;
  margin: 0 0 6px;
  color: var(--color-ink);
}

.field__input {
  width: 100%;
  padding: 11px 12px;
  border-radius: 12px;
  border: 1px solid rgba(57,65,77,.16);
  background: #fff;
  font: inherit;
  color: var(--color-ink);
}

.field__input:focus {
  outline: none;
  border-color: rgba(112,132,64,.55);
  box-shadow: 0 0 0 4px rgba(112,132,64,.14);
}

.field__hint {
  display: block;
  min-height: 16px;
  margin-top: 6px;
  font-size: 12px;
  color: rgba(180, 33, 33, .95);
}

.field__radios {
  display: flex;
  gap: 14px;
  padding: 10px 0 2px;
}

.radio {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: rgba(57,65,77,.90);
}

.form__alert {
  margin-top: 10px;
  padding: 12px 12px;
  border-radius: 12px;
  background: rgba(180, 33, 33, .08);
  border: 1px solid rgba(180, 33, 33, .22);
  color: rgba(140, 20, 20, .95);
  font-weight: 700;
}

.form__foot {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(57,65,77,.10);
}

.btn--ghost {
  background: transparent;
  border: 1px solid rgba(57,65,77,.18);
  color: var(--color-ink);
}

.btn--ghost:hover,
.btn--ghost:focus-visible {
  outline: none;
  background: rgba(57,65,77,.06);
}

.form__fineprint {
  grid-column: 1 / -1;
  margin: 0;
  font-size: 12px;
  color: rgba(57,65,77,.70);
}

/* Modal scroll on small screens */
@media (max-width: 900px) {
  .modal__panel {
    margin: 12px auto;
  }
  .form__grid {
    grid-template-columns: 1fr;
  }
}

/* Honeypot hidden */
.hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* =========================
   Revendas (page)
========================= */
.dealers-page{
  padding: 34px 0 60px;
}

.dealers-head{
  margin: 10px 0 18px;
}

.dealers-title{
  margin: 0 0 6px;
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 300;
  letter-spacing: -0.4px;
  color: var(--color-ink);
}

.dealers-subtitle{
  margin: 0;
  max-width: 70ch;
  color: rgba(57,65,77,.78);
  font-weight: 300;
  line-height: 1.45;
}

.dealers-search{
  
  margin-top: 16px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(57,65,77,.10);
  background: rgba(57,65,77,.03);
  align-items: center;
  max-width: fit-content;
}

.dealers-search__form{
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: ;
  
}

.dealers-search__meta{
  margin-top: 10px;
  color: rgba(57,65,77,.78);
  font-weight: 600;
  font-size: 13px;
}

.dealers-grid{
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.dealer-card{
  border: 1px solid rgba(57,65,77,.14);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  display: grid;
  grid-template-columns: 1fr;
}

.dealer-card__media{
  position: relative;
}

.dealer-card__img{
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: ;
  display: block;
  background: rgba(57,65,77,.06);
}

.dealer-card__map{
  position: absolute;
  left: 12px;
  bottom: 12px;
  right: 12px;
  display: grid;
  gap: 10px;
}

.dealer-card__mapbtn{
  justify-self: start;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.42);
  color: #fff;
  font-weight: 800;
  cursor: pointer;
}

.dealer-card__mapbtn:hover,
.dealer-card__mapbtn:focus-visible{
  outline: none;
  filter: brightness(1.05);
}

.dealer-card__mapbox{
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.30);
}

.dealer-card__mapbox iframe{
  width: 100%;
  height: 240px;
  border: 0;
  display: block;
}

.dealer-card__mapplaceholder{
  height: 240px;
  display: grid;
  place-items: center;
  padding: 14px;
  color: rgba(255,255,255,.85);
  font-weight: 300;
  text-align: center;
}

.dealer-card__body{
  padding: 14px 14px 16px;
  display: grid;
  gap: 10px;
}

.dealer-card__title{
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-ink);
}

.dealer-card__sub{
  margin: 0;
  color: rgba(57,65,77,.78);
  font-weight: 400;
}

.dealer-card__contacts{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.dealer-chip{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 12px;
  border-radius: 999px;
  border: 1px solid rgba(57,65,77,.16);
  background: rgba(57,65,77,.03);
  color: var(--color-ink);
  text-decoration: none;
  font-weight: 600;
}

.dealer-chip:hover,
.dealer-chip:focus-visible{
  outline: none;
  background: rgba(112,132,64,.12);
  border-color: rgba(112,132,64,.35);
}

.dealer-card__addr{
  margin: 0;
  color: rgba(57,65,77,.82);
  font-weight: 500;
  line-height: 1.35;
}

.dealer-card__route{
  justify-self: start;
  text-decoration: none;
  font-weight: 800;
  color: var(--color-ink);
  padding: 8px 6px;
  border-radius: 8px;
}

.dealer-card__route:hover,
.dealer-card__route:focus-visible{
  outline: none;
  background: rgba(112,132,64,.12);
}

.dealers-empty{
  grid-column: 1 / -1;
  padding: 18px;
  border-radius: 16px;
  border: 1px dashed rgba(57,65,77,.22);
  background: rgba(57,65,77,.02);
  color: rgba(57,65,77,.85);
}

@media (max-width: 900px){
  .dealers-grid{
    grid-template-columns: 1fr;
  }
}