/* Montese Embalagens — style.css v2.1 */
@import url('fonts.css');

/* ============================================================
   VARIABLES
   ============================================================ */
:root {
  --green:       #006436;
  --green-dark:  #004A28;
  --green-mid:   #005A30;
  --green-light: #E8F2EC;
  --green-xlight:#F0F6F2;
  --off-white:   #F4F5F3;
  --text:        #161A18;
  --muted:       #536068;
  --border:      #D4DAD6;
  --gray-bar:    #7F7F7F;
  --wa:          #25D366;
  --container:   1240px;
  --pad-section: 96px;
  --font-body:    'Aileron', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --ease-out-quart: cubic-bezier(.25, 1, .5, 1);
  --ease-out-expo:  cubic-bezier(.16, 1, .3, 1);
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  color: var(--text);
  background: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, select, textarea { font-family: inherit; }

/* ============================================================
   LAYOUT
   ============================================================ */
.container { max-width: var(--container); margin: 0 auto; padding: 0 48px; }
section { padding: var(--pad-section) 0; }
section.alt { background: var(--off-white); }

/* ============================================================
   SECTION TYPOGRAPHY
   ============================================================ */
.section-label {
  display: inline-flex;
  align-items: center;
  font-weight: 900;
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--green);
  padding-left: 14px;
  border-left: 3px solid var(--green);
  margin-bottom: 22px;
  line-height: 1.2;
}
.section-title {
  font-weight: 900;
  font-size: clamp(28px, 4vw, 50px);
  color: var(--text);
  line-height: 1.08;
  letter-spacing: -.02em;
  margin-bottom: 18px;
  max-width: 740px;
}
.section-sub {
  font-size: 17px;
  color: var(--muted);
  line-height: 1.75;
  max-width: 580px;
  margin-bottom: 52px;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 900;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 14px 28px;
  background: var(--green);
  color: #fff;
  border-radius: 2px;
  border: none;
  cursor: pointer;
  transition: background .2s var(--ease-out-quart), transform .18s var(--ease-out-quart), box-shadow .2s var(--ease-out-quart);
}
.btn-primary:hover {
  background: var(--green-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(0, 100, 54, .22);
}
.btn-primary:active {
  transform: translateY(0);
  box-shadow: none;
}
.btn-primary.btn-full { width: 100%; }

.btn-white {
  display: inline-flex;
  align-items: center;
  font-weight: 900;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 14px 28px;
  background: #fff;
  color: var(--green);
  border-radius: 2px;
  transition: opacity .2s, transform .18s var(--ease-out-quart);
}
.btn-white:hover { opacity: .9; transform: translateY(-1px); }

.btn-outline-white {
  display: inline-flex;
  align-items: center;
  font-weight: 900;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 13px 28px;
  background: transparent;
  color: #fff;
  border-radius: 2px;
  border: 1px solid rgba(255,255,255,.45);
  transition: border-color .2s, background .2s;
}
.btn-outline-white:hover {
  border-color: rgba(255,255,255,.9);
  background: rgba(255,255,255,.08);
}

/* ============================================================
   LOGO
   ============================================================ */
.logo { display: flex; align-items: center; gap: 14px; }
.logo-bar { width: 16px; height: 48px; background: var(--gray-bar); flex-shrink: 0; }
.logo-word { font-weight: 900; font-size: 34px; color: var(--green); letter-spacing: -.01em; line-height: 1; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, box-shadow .3s;
}
.site-header.scrolled {
  border-bottom-color: var(--border);
  box-shadow: 0 1px 20px rgba(0,0,0,.07);
}
.header-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: 72px;
  gap: 0;
}
.nav-links {
  display: flex;
  gap: 56px;
  justify-content: center;
}
.nav-links a {
  font-weight: 900;
  font-size: 15px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text);
  transition: color .2s;
}
.nav-links a:hover { color: var(--green); }
.btn-cta {
  font-weight: 900;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 13px 28px;
  background: var(--green);
  color: #fff;
  border-radius: 2px;
  margin-left: auto;
  transition: background .2s;
  white-space: nowrap;
  justify-self: end;
}
.btn-cta:hover { background: var(--green-dark); }

/* Hamburger */
.hamburger { display: none; flex-direction: column; gap: 5px; padding: 6px 4px; margin-left: auto; }
.hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--text);
  border-radius: 1px;
  transition: transform .25s ease, opacity .25s ease;
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.mobile-menu {
  position: fixed;
  top: 72px; left: 0; right: 0;
  background: #fff;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 28px 48px;
  gap: 22px;
  z-index: 99;
  transform: translateY(-110%);
  opacity: 0;
  pointer-events: none;
  transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .3s;
}
.mobile-menu.open { transform: translateY(0); opacity: 1; pointer-events: auto; }
.mobile-menu a {
  font-weight: 900;
  font-size: 13px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text);
  transition: color .2s;
}
.mobile-menu a:hover { color: var(--green); }
.mobile-menu .btn-cta { align-self: flex-start; margin-left: 0; }

/* ============================================================
   HERO
   ============================================================ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(32px); }
  to   { opacity: 1; transform: translateY(0); }
}

.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  position: relative;
  background-image:
    linear-gradient(135deg,
      rgba(0,50,28,.94) 0%,
      rgba(0,68,40,.82) 50%,
      rgba(0,80,48,.52) 100%),
    url('../Montese-Fotos/Foto%20Capa.png');
  background-size: cover;
  background-position: center 35%;
  background-attachment: fixed;
  padding: 144px 0 88px;
}
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(
    90deg,
    rgba(255,255,255,.016) 0px,
    rgba(255,255,255,.016) 1px,
    transparent 1px,
    transparent 80px
  );
  pointer-events: none;
}
.hero-inner { position: relative; z-index: 1; max-width: 720px; }
.hero-label {
  color: rgba(255,255,255,.6);
  border-left-color: rgba(255,255,255,.35);
  animation: fadeUp .65s cubic-bezier(.4,0,.2,1) both;
  animation-delay: .1s;
}
.hero h1 {
  font-weight: 900;
  font-size: clamp(38px, 5.8vw, 72px);
  color: #fff;
  line-height: 1.05;
  letter-spacing: -.025em;
  margin-bottom: 28px;
  animation: fadeUp .7s cubic-bezier(.4,0,.2,1) both;
  animation-delay: .27s;
}
.hero-sub {
  font-size: clamp(16px, 1.8vw, 19px);
  color: rgba(255,255,255,.78);
  line-height: 1.72;
  max-width: 500px;
  margin-bottom: 44px;
  animation: fadeUp .65s cubic-bezier(.4,0,.2,1) both;
  animation-delay: .46s;
}
.hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  animation: fadeUp .6s cubic-bezier(.4,0,.2,1) both;
  animation-delay: .62s;
}

/* ============================================================
   SETORES
   ============================================================ */
.setores-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 6px;
  overflow: hidden;
}
.setor-card {
  position: relative;
  overflow: hidden;
  cursor: default;
  aspect-ratio: 16 / 10;
  background: #1a1a1a;
}
.setor-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .45s cubic-bezier(.4,0,.2,1), filter .35s;
  filter: brightness(.92);
}
.setor-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 40, 20, .82) 0%,
    rgba(0, 40, 20, .45) 40%,
    rgba(0, 40, 20, .12) 100%
  );
  transition: background .35s;
  z-index: 1;
}
.setor-card:hover .setor-img {
  transform: scale(1.07);
  filter: brightness(1);
}
.setor-card:hover .setor-overlay {
  background: linear-gradient(
    to top,
    rgba(0, 100, 54, .78) 0%,
    rgba(0, 100, 54, .3) 40%,
    rgba(0, 100, 54, .05) 100%
  );
}
.setor-name {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 20px 24px;
  font-weight: 900;
  font-size: 17px;
  color: #fff;
  z-index: 2;
  letter-spacing: -.01em;
  transition: transform .35s cubic-bezier(.4,0,.2,1);
}
.setor-card:hover .setor-name { transform: translateY(-4px); }

/* ============================================================
   PORTFÓLIO
   ============================================================ */
.setores-tabs {
  display: flex;
  gap: 0;
  flex-wrap: nowrap;
  margin-bottom: 28px;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  overflow: hidden;
  width: fit-content;
  background: #fff;
}
/* ── Group headers ── */
.emb-group { margin-bottom: 12px; }
.emb-group-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #fff;
}
.emb-group-header.ecma  { background: var(--green); }
.emb-group-header.fefco { background: var(--gray-bar); }
.emb-group-title { white-space: nowrap; }
.emb-group-norm  { font-weight: 400; opacity: .7; letter-spacing: .06em; text-transform: none; font-style: italic; white-space: nowrap; }
.emb-group-line  { flex: 1; height: 1px; background: rgba(255,255,255,.2); }
.emb-group-count { font-weight: 400; opacity: .6; white-space: nowrap; }
.tab-btn {
  font-weight: 900;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 9px 18px;
  border: none;
  border-right: 1.5px solid var(--border);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  font-family: inherit;
  transition: background .15s, color .15s;
}
.tab-btn:last-child { border-right: none; }
.tab-btn:hover:not(.active) { background: #f0f5f1; color: var(--green); }
.tab-btn.active { background: var(--green); color: #fff; }
.emb-section { display: none; }
.emb-section.active { display: block; }
/* ── Accordion container ── */
.emb-accordions { /* container border removed — groups handle their own */ }
.emb-group-rows { border: 1px solid var(--border); border-top: none; }
.serie-item { border-bottom: 1px solid var(--border); }
.serie-item:last-child { border-bottom: none; }
.serie-header {
  width: 100%; display: flex; align-items: center; gap: 10px;
  padding: 13px 20px; background: #fff; cursor: pointer; border: none;
  text-align: left; font-family: inherit;
  transition: background .15s;
  /* border-left intentionally removed — group headers provide visual distinction */
}
.serie-info { display: flex; align-items: baseline; gap: 10px; flex: 1; min-width: 0; }
.serie-title { font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--text); white-space: nowrap; }
.serie-norm  { display: none; }
.serie-count { margin-left: auto; font-size: 10px; font-weight: 700; letter-spacing: .06em; color: #C0C0C0; white-space: nowrap; }
/* ECMA group: light green on hover */
.emb-group[data-group="papel"] .serie-header:hover {
  background: var(--green-light);
}
/* ECMA group: light green when expanded */
.emb-group[data-group="papel"] .serie-item.expanded .serie-header {
  background: var(--green-light);
}
/* FEFCO group: light gray on hover */
.emb-group[data-group="micro"] .serie-header:hover {
  background: #EAEAEA;
}
/* FEFCO group: light gray when expanded */
.emb-group[data-group="micro"] .serie-item.expanded .serie-header {
  background: #EAEAEA;
}
/* Hover: keep text dark */
.emb-group[data-group="papel"] .serie-header:hover .serie-title,
.emb-group[data-group="papel"] .serie-header:hover .serie-count,
.emb-group[data-group="papel"] .serie-header:hover .serie-letter {
  color: var(--green);
}
.emb-group[data-group="papel"] .serie-header:hover .chevron { stroke: var(--green); }
.emb-group[data-group="micro"] .serie-header:hover .serie-title,
.emb-group[data-group="micro"] .serie-header:hover .serie-count,
.emb-group[data-group="micro"] .serie-header:hover .serie-letter {
  color: var(--text);
}
.emb-group[data-group="micro"] .serie-header:hover .chevron { stroke: var(--text); }
/* Expanded ECMA: green text */
.emb-group[data-group="papel"] .serie-item.expanded .serie-header .serie-title,
.emb-group[data-group="papel"] .serie-item.expanded .serie-header .serie-count,
.emb-group[data-group="papel"] .serie-item.expanded .serie-header .serie-letter {
  color: var(--green);
}
.emb-group[data-group="papel"] .serie-item.expanded .serie-header .chevron { stroke: var(--green); }
/* Expanded FEFCO: dark text */
.emb-group[data-group="micro"] .serie-item.expanded .serie-header .serie-title,
.emb-group[data-group="micro"] .serie-item.expanded .serie-header .serie-count,
.emb-group[data-group="micro"] .serie-item.expanded .serie-header .serie-letter {
  color: var(--text);
}
.emb-group[data-group="micro"] .serie-item.expanded .serie-header .chevron { stroke: var(--text); }
.serie-letter {
  font-size: 13px;
  font-weight: 900;
  color: #ddd;
  width: 28px;
  text-align: right;
  flex-shrink: 0;
  line-height: 1;
  transition: color .15s;
}
.chevron { width: 14px; height: 14px; flex-shrink: 0; stroke: var(--muted); fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; transition: transform .22s var(--ease-out-expo), stroke .15s; }
.serie-item.expanded .chevron { transform: rotate(180deg); }
.serie-body {
  display: grid;
  grid-template-rows: 0fr;
  border-top: 0px solid var(--border);
  transition: grid-template-rows .28s cubic-bezier(.16,1,.3,1),
              border-top-width .28s cubic-bezier(.16,1,.3,1);
}
.serie-item.expanded .serie-body {
  grid-template-rows: 1fr;
  border-top-width: 1px;
}
.serie-body-inner { overflow: hidden; }

/* ── Card grid — 3 fixed columns ── */
.emb-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
}
.emb-card {
  background: #fff;
  transition: background .18s ease, transform .18s cubic-bezier(.16,1,.3,1), box-shadow .18s cubic-bezier(.16,1,.3,1);
  cursor: pointer;
}
.emb-card:hover {
  background: #FAFBFA;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.emb-card.emb-extra { display: none; }
.emb-card.emb-extra.revealed { display: block; }
/* === .emb-img — área da imagem (mockup sem fundo + janela dieline) === */
.emb-img {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--green-light);
}
.emb-card.fefco-card .emb-img { background: #F0F0F0; }

/* --- Mockup principal --- */
.emb-img .mockup {
  width: 100%; height: 100%;
  object-fit: contain; object-position: center;
  display: block; pointer-events: none;
  transition: transform .22s ease;
}
.emb-card:hover .emb-img .mockup { transform: scale(1.03); }

/* --- Legado: SVG puro (cards sem arquivos) --- */
.emb-img--legacy { cursor: default; }
.emb-img > svg { width: 32px; height: 32px; stroke: var(--green); fill: none; stroke-width: 1; stroke-linecap: round; stroke-linejoin: round; }
.emb-card.fefco-card .emb-img > svg { stroke: var(--gray-bar); }

/* --- Janela do dieline — canto superior esquerdo --- */
.dieline-window {
  position: absolute; top: 8px; left: 8px;
  width: 28%;
  max-height: 42%;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 3px;
  box-shadow: 0 2px 7px rgba(0,0,0,.13);
  overflow: hidden;
  pointer-events: auto;
  cursor: zoom-in;
  transition: border-color .15s, box-shadow .15s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.emb-card:hover .dieline-window {
  border-color: var(--green);
  box-shadow: 0 2px 8px rgba(0,100,54,.20);
}
.dieline-window img {
  width: 100%; height: auto;
  max-height: 100%;
  object-fit: contain;
  display: block;
}

/* --- Ícone de lupa no hover --- */
.zoom-hint {
  position: absolute; bottom: 7px; right: 7px;
  width: 24px; height: 24px;
  background: rgba(255,255,255,.88);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none; opacity: 0;
  transition: opacity .18s;
}
.emb-card:hover .zoom-hint { opacity: 1; }
.zoom-hint svg { width: 13px; height: 13px; stroke: var(--green); fill: none; stroke-width: 1.8; stroke-linecap: round; }

/* === LIGHTBOX === */
.lb-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(10,20,15,.74);
  backdrop-filter: blur(4px);
  z-index: 1000;
  align-items: center; justify-content: center;
}
.lb-overlay.open { display: flex; }
.lb-box {
  position: relative; background: #fff;
  border-radius: 6px; overflow: hidden;
  box-shadow: 0 28px 80px rgba(0,0,0,.40);
  display: flex; align-items: stretch;
  max-width: min(880px, 94vw); max-height: 90vh;
}
.lb-mockup-wrap {
  position: relative; background: #EEEFED;
  display: flex; align-items: center; justify-content: center;
  width: 520px; flex-shrink: 0;
  aspect-ratio: 4 / 3; overflow: hidden;
}
.lb-mockup-wrap > img { width: 100%; height: 100%; object-fit: contain; display: block; }
.lb-dieline-win {
  position: absolute; top: 14px; right: 14px;
  width: 30%; background: #fff;
  border: 1px solid #D0D5D2; border-radius: 4px;
  box-shadow: 0 4px 14px rgba(0,0,0,.18);
  overflow: hidden;
}
.lb-dieline-win img { width: 100%; height: auto; display: block; }
.lb-dieline-win.hidden { display: none; }

/* --- Dieline-only popup --- */
.dl-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(10,20,15,.82);
  backdrop-filter: blur(6px);
  z-index: 1100;
  align-items: center; justify-content: center;
  cursor: zoom-out;
}
.dl-overlay.open { display: flex; }
.dl-popup {
  position: relative;
  background: #fff;
  border-radius: 6px;
  box-shadow: 0 28px 80px rgba(0,0,0,.45);
  padding: 24px;
  max-width: 90vw;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: default;
}
.dl-popup-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .06em;
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: 16px;
  text-align: center;
}
.dl-popup img {
  max-width: 100%;
  max-height: calc(88vh - 90px);
  object-fit: contain;
  display: block;
}
.dl-close {
  position: absolute; top: 10px; right: 14px;
  background: none; border: none;
  font-size: 28px; color: var(--muted);
  cursor: pointer; line-height: 1;
  transition: color .15s;
}
.dl-close:hover { color: var(--text); }
.lb-info {
  padding: 26px 24px 22px;
  display: flex; flex-direction: column; gap: 0;
  min-width: 200px; max-width: 240px;
  border-left: 1px solid #E8EDE9;
  overflow-y: auto;
}
.lb-code  { font-size: 9px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #B8B8B8; }
.lb-tag   { font-size: 9px; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; color: var(--green); margin-top: 3px; }
.lb-tag.gray { color: var(--gray-bar); }
.lb-title { font-size: 15px; font-weight: 700; color: var(--text); line-height: 1.2; margin-top: 8px; }
.lb-divider { border: none; border-top: 1px solid #EAEEED; margin: 14px 0; }
.lb-section-label { font-size: 8.5px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--green); margin-bottom: 6px; }
.lb-text { font-size: 11.5px; color: #3E4A42; line-height: 1.6; margin-bottom: 14px; }
.lb-usecases { list-style: none; display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 14px; }
.lb-usecases li { font-size: 10px; font-weight: 700; background: #EEF4F0; color: var(--green); border: 1px solid #C6DDD0; border-radius: 3px; padding: 3px 8px; }
.lb-features { list-style: none; display: flex; flex-direction: column; gap: 7px; margin-bottom: 14px; }
.lb-features li { font-size: 11px; color: #3E4A42; line-height: 1.45; padding-left: 14px; position: relative; }
.lb-features li::before { content: '\2713'; position: absolute; left: 0; color: var(--green); font-weight: 700; font-size: 10px; }
.lb-close {
  position: absolute; top: 10px; right: 10px;
  width: 28px; height: 28px;
  background: rgba(255,255,255,.9); border: none;
  border-radius: 50%; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; color: #536068; z-index: 10;
  transition: background .15s, color .15s; line-height: 1;
}
.lb-close:hover { background: #161A18; color: #fff; }
@media (max-width: 740px) {
  .lb-box { flex-direction: column; max-height: 94vh; }
  .lb-mockup-wrap { width: 100%; flex-shrink: 1; }
  .lb-info { max-width: 100%; min-width: 0; border-left: none; border-top: 1px solid #E8EDE9; }
}
.emb-body { padding: 12px 14px 14px; }
.emb-code  { font-size: 9px; font-weight: 700; letter-spacing: .10em; text-transform: uppercase; color: #C0C0C0; margin-bottom: 2px; }
.emb-tag   { font-size: 9px; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; color: var(--green); margin-bottom: 5px; }
.emb-tag.gray { color: var(--gray-bar); }
.emb-title { font-size: 12px; font-weight: 700; color: var(--text); margin-bottom: 5px; line-height: 1.25; }
.emb-desc  { font-size: 11px; color: var(--muted); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* ── Ver mais ── */
.ver-mais-row { padding: 10px 18px; background: #fff; border-top: 1px solid var(--border); }
.ver-mais-btn { font-size: 10px; font-weight: 700; letter-spacing: .10em; text-transform: uppercase; color: var(--green); cursor: pointer; border: none; background: none; font-family: inherit; padding: 0; display: flex; align-items: center; gap: 6px; }
.ver-mais-btn::before { content: '+'; font-size: 14px; font-weight: 900; line-height: 1; }
.ver-mais-btn:hover { text-decoration: underline; }
.portfolio-cta {
  margin-top: 1px;
  padding: 28px 32px;
  background: var(--green-light);
  border: 1px solid rgba(0,100,54,.12);
  border-top: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.portfolio-cta p { font-size: 14px; color: var(--muted); margin: 0; }

/* ============================================================
   NÚMEROS STRIP
   ============================================================ */
.nums-strip {
  background-image:
    linear-gradient(rgba(0,58,28,.78), rgba(0,58,28,.78)),
    url('../Montese-Fotos/Impress%C3%A3o%20-%20Foto%202.png');
  background-size: cover;
  background-position: center 45%;
  background-attachment: fixed;
  padding: 88px 0;
}
.nums-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 48px;
}
.num-item { text-align: center; padding: 0 48px; border-right: 1px solid rgba(255,255,255,.12); }
.num-item:last-child { border-right: none; }
.num-n { font-weight: 900; font-size: clamp(52px, 6.5vw, 84px); color: #fff; line-height: 1; display: block; letter-spacing: -.03em; }
.num-city { font-size: clamp(28px, 3.2vw, 44px); padding-top: 8px; letter-spacing: -.02em; }
.num-l { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.6); margin-top: 14px; }

/* ============================================================
   SOBRE
   ============================================================ */
.sobre-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
  margin-top: 48px;
  margin-bottom: 72px;
}
.sobre-body { font-size: 16px; color: var(--muted); line-height: 1.82; margin-bottom: 18px; }
.sobre-body:last-child { margin-bottom: 0; }
.sobre-img img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;

  border-radius: 2px;
  display: block;
  box-shadow: 0 8px 40px rgba(0,0,0,.12);
}
.valores-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--border);
  border-left: 1px solid var(--border);
}
.valor-item {
  padding: 32px 28px;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  border-top: 3px solid var(--green);
  background: #fff;
  transition: background .2s;
}
.valor-item:hover { background: var(--green-light); }
.valor-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 10px; letter-spacing: -.01em; }
.valor-body { font-size: 13px; color: var(--muted); line-height: 1.7; }

/* ============================================================
   LOCALIZAÇÃO
   ============================================================ */
.mapa-embed { border-radius: 2px; overflow: hidden; border: 1px solid var(--border); margin-bottom: 28px; }
.mapa-embed iframe { width: 100%; height: 380px; border: none; display: block; }
.localizacao-info { display: flex; gap: 60px; flex-wrap: wrap; }
.info-label { font-size: 11px; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; color: var(--green); margin-bottom: 8px; }
.info-text { font-size: 16px; color: var(--text); line-height: 1.65; }
.info-text a { color: var(--green); transition: opacity .2s; }
.info-text a:hover { opacity: .75; }

/* ============================================================
   CONTATO
   ============================================================ */
.contato-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 80px; align-items: start; }
.wa-cta {
  display: flex;
  align-items: center;
  gap: 20px;
  background: var(--green-light);
  border: 1px solid rgba(0,100,54,.18);
  border-radius: 2px;
  padding: 28px;
  margin-bottom: 40px;
  cursor: pointer;
  transition: background .2s;
  text-decoration: none;
}
.wa-cta:hover { background: #d5e9dc; }
.wa-icon {
  width: 52px;
  height: 52px;
  background: var(--wa);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(37,211,102,.28);
}
.wa-icon svg { width: 28px; height: 28px; fill: #fff; }
.wa-text-title { font-size: 16px; font-weight: 900; color: var(--text); letter-spacing: -.01em; }
.wa-text-sub { font-size: 13px; color: var(--muted); margin-top: 3px; }
.info-block { margin-bottom: 28px; }

.form-group { display: flex; flex-direction: column; gap: 7px; margin-bottom: 20px; }
.form-label { font-size: 11px; font-weight: 900; letter-spacing: .13em; text-transform: uppercase; color: var(--muted); }
.form-input, .form-select, .form-textarea {
  font-size: 15px;
  color: var(--text);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 12px 14px;
  width: 100%;
  transition: border-color .2s, box-shadow .2s;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(0,100,54,.09);
}
.form-textarea { resize: vertical; min-height: 110px; }
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-note { font-size: 12px; color: var(--muted); margin-top: 14px; text-align: center; line-height: 1.6; opacity: .8; }

/* ============================================================
   WHATSAPP FLOAT
   ============================================================ */
.wa-float {
  position: fixed;
  bottom: 28px; right: 28px;
  width: 56px; height: 56px;
  background: var(--wa);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
  box-shadow: 0 4px 20px rgba(37,211,102,.38), 0 1px 4px rgba(0,0,0,.12);
  transition: transform .2s cubic-bezier(.34,1.56,.64,1), box-shadow .2s;
}
.wa-float:hover { transform: scale(1.1); box-shadow: 0 6px 28px rgba(37,211,102,.5), 0 2px 8px rgba(0,0,0,.14); }
.wa-float svg { width: 28px; height: 28px; fill: #fff; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background: #0D0D0D; color: rgba(255,255,255,.5); padding: 72px 0 40px; }
.footer-grid {
  display: grid;
  grid-template-columns: 2.2fr 1fr 1fr;
  gap: 64px;
  padding-bottom: 52px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.footer-logo .logo-word { color: #fff; }
.footer-logo .logo-bar { background: rgba(255,255,255,.25); }
.footer-desc { font-size: 14px; line-height: 1.8; margin-top: 20px; color: rgba(255,255,255,.55); max-width: 260px; }
.footer-col-title { font-size: 11px; font-weight: 900; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 20px; }
.footer-links { display: flex; flex-direction: column; gap: 12px; }
.footer-links a { font-size: 14px; color: rgba(255,255,255,.72); transition: color .2s; }
.footer-links a:hover { color: #fff; }
.footer-links li { font-size: 14px; color: rgba(255,255,255,.3); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 32px; font-size: 12px; color: rgba(255,255,255,.18); flex-wrap: wrap; gap: 8px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  :root { --pad-section: 72px; }
  .container { padding: 0 32px; }
  .sobre-grid { gap: 48px; }
  .contato-grid { gap: 48px; }
  .valores-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid > div:first-child { grid-column: 1 / -1; }
}

@media (max-width: 900px) {
  .nav-links, .header-inner > .btn-cta { display: none; }
  .hamburger { display: flex; }
  .hero { background-attachment: scroll; }
  .nums-strip { background-attachment: scroll; }
  .setores-grid { grid-template-columns: repeat(2, 1fr); }
  .sobre-grid { grid-template-columns: 1fr; gap: 36px; }
  .contato-grid { grid-template-columns: 1fr; gap: 48px; }
  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .footer-grid > div:first-child { grid-column: unset; }
  .form-grid-2 { grid-template-columns: 1fr; }
  .nums-grid { grid-template-columns: 1fr; padding: 0 32px; }
  .num-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,.1); padding: 40px 0; }
  .num-item:last-child { border-bottom: none; }
  .portfolio-cta { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 600px) {
  :root { --pad-section: 56px; }
  .container { padding: 0 20px; }
  .mobile-menu { padding: 28px 20px; }
  .setores-grid { grid-template-columns: 1fr 1fr; }
  .setor-card { aspect-ratio: 4 / 3; }
  .setor-name { font-size: 15px; padding: 16px 18px; }
  .valores-grid { grid-template-columns: 1fr; }
  .nums-grid { padding: 0 20px; }
  .localizacao-info { flex-direction: column; gap: 28px; }
  .hero-actions { flex-direction: column; align-items: flex-start; }
  .emb-grid { grid-template-columns: 1fr; }
  .sobre-img img { aspect-ratio: 16/9; }
  .serie-letter { width: 20px; font-size: 11px; }
}

@media (max-width: 375px) {
  .setores-grid { grid-template-columns: 1fr; }
  .setor-card { aspect-ratio: 16 / 10; }
}

/* ============================================================
   v2.1 ENHANCEMENTS
   ============================================================ */

/* Scroll indicator */
.scroll-indicator {
  position: absolute;
  bottom: 44px;
  left: 50%;
  transform: translateX(-50%);
  width: 22px;
  height: 36px;
  border: 1.5px solid rgba(255,255,255,.28);
  border-radius: 11px;
  display: flex;
  justify-content: center;
  padding-top: 6px;
  transition: opacity .4s ease;
  cursor: pointer;
}
.scroll-indicator.hidden { opacity: 0; pointer-events: none; }
.scroll-indicator span {
  width: 2px;
  height: 7px;
  background: rgba(255,255,255,.5);
  border-radius: 2px;
  animation: scrollBob 2.2s var(--ease-out-expo) infinite;
}
@keyframes scrollBob {
  0%, 100% { transform: translateY(0); opacity: .7; }
  50% { transform: translateY(7px); opacity: .2; }
}

/* Setor card hover handled in main section above */

/* Valores: consistent with setor hover */
.valor-item {
  transition: background .22s ease, border-top-color .22s ease;
}

/* Portfolio tab content — smooth entrance */
.emb-section.active {
  animation: tabReveal .32s var(--ease-out-expo) both;
}
@keyframes tabReveal {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Numbers strip: refined num display */
.num-n {
  font-variant-numeric: tabular-nums;
  letter-spacing: -.035em;
}

/* CTA header button: lift on hover */
.btn-cta {
  transition: background .2s, transform .18s var(--ease-out-quart), box-shadow .2s;
}
.btn-cta:hover {
  background: var(--green-dark);
  transform: translateY(-1px);
  box-shadow: 0 3px 10px rgba(0,100,54,.2);
}

/* WhatsApp CTA block: subtle scale */
.wa-cta {
  transition: background .2s, transform .18s var(--ease-out-quart);
}
.wa-cta:hover {
  background: #d5e9dc;
  transform: translateY(-1px);
}

/* Form inputs: smoother focus ring */
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(0,100,54,.1);
  outline: none;
}

/* Sobre image: sharper hover */
.sobre-img img {
  transition: box-shadow .3s ease, transform .3s var(--ease-out-quart);
}
.sobre-img img:hover {
  box-shadow: 0 12px 48px rgba(0,0,0,.16);
  transform: translateY(-2px);
}

/* Footer link hover: consistent with green theme */
.footer-links a {
  transition: color .18s ease, padding-left .18s var(--ease-out-quart);
}
.footer-links a:hover {
  color: #fff;
  padding-left: 4px;
}

/* Process section */
.processo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-top: 52px;
}
.processo-item {
  background: #fff;
  padding: 40px 32px;
}
.processo-num {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  color: var(--green);
  margin-bottom: 20px;
}
.processo-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.01em;
  margin-bottom: 12px;
  line-height: 1.3;
}
.processo-body {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.75;
}
@media (max-width: 900px) {
  .processo-grid { grid-template-columns: 1fr; }
  .processo-item { padding: 32px 24px; border-bottom: 1px solid var(--border); }
  .processo-item:last-child { border-bottom: none; }
}

/* Nav links: underline slide effect */
.nav-links a {
  position: relative;
  padding-bottom: 3px;
}
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1.5px;
  background: var(--green);
  transition: width .22s var(--ease-out-quart);
}
.nav-links a:hover::after { width: 100%; }
.nav-links a:hover { color: var(--green); }

/* Header: slightly more refined scrolled state */
.site-header.scrolled {
  border-bottom-color: var(--border);
  box-shadow: 0 1px 24px rgba(0,0,0,.06);
}

/* Reduced-motion safety */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}
