/* ==========================================================
   VERITAS WEB v2 — styles.css
   Paleta: #7f9473 sage | #d3c795 areia | #ffffff branco
           #1f1f1f carvão | #c02c20 vermelho
   Tipografia: Cormorant Garamond (display) + DM Sans (body)
   ========================================================== */

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

:root {
  /* Paleta principal */
  --sage:      #7f9473;
  --sage-dk:   #5e7055;
  --sage-lt:   #a3b598;
  --sand:      #d3c795;
  --sand-lt:   #d9d4a8;
  --sand-dk:   #b8a96e;
  --red:       #c02c20;
  --red-dk:    #a32419;
  --red-lt:    #d15c57;
  --charcoal:  #1f1f1f;
  --charcoal2: #2e2e2e;
  --white:     #ffffff;
  --cream:     #faf9f6;
  --mist:      #f3f2ee;
  --slate:     #4a5f67;
  --plum:      #5c374b;

  /* Tipografia */
  --display: 'Cormorant Garamond', Georgia, serif;
  --body:    'DM Sans', system-ui, sans-serif;

  /* Layout */
  --container: 1140px;
  --header-h:  68px;
  --radius:    10px;
  --radius-lg: 18px;

  /* Sombras */
  --shadow-sm: 0 2px 10px rgba(31,31,31,.07);
  --shadow-md: 0 8px 28px rgba(31,31,31,.12);
  --shadow-lg: 0 20px 52px rgba(31,31,31,.16);

  --t: .26s cubic-bezier(.4,0,.2,1);
}

html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--body);
  background: var(--cream);
  color: var(--charcoal);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* Scrollbar */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--mist); }
::-webkit-scrollbar-thumb { background: var(--sage); border-radius: 3px; }
::selection { background: var(--sand); color: var(--charcoal); }

/* ── CONTAINER ── */
.container { max-width: var(--container); margin: 0 auto; padding: 0 28px; }

/* ── TIPOGRAFIA GLOBAL ── */
.section-eyebrow {
  font-family: var(--body);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--sage-dk);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.section-eyebrow::before {
  content: '';
  display: block;
  width: 24px; height: 1.5px;
  background: var(--sage);
}

.section-title {
  font-family: var(--display);
  font-size: clamp(2.2rem, 4.5vw, 3.4rem);
  font-weight: 600;
  line-height: 1.1;
  color: var(--charcoal);
  letter-spacing: -.01em;
}
.section-title em {
  font-style: italic;
  font-weight: 300;
  color: var(--sage-dk);
}
.section-sub {
  font-size: .95rem;
  color: #666;
  margin-top: 14px;
}
.section-header {
  text-align: center;
  margin-bottom: 64px;
}
.section-header .section-eyebrow {
  justify-content: center;
}
.section-header .section-eyebrow::before { display: none; }
.section-header .section-eyebrow::after {
  content: '';
  display: block;
  width: 24px; height: 1.5px;
  background: var(--sage);
}

/* ── BUTTONS ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 26px;
  border-radius: var(--radius);
  font-family: var(--body);
  font-size: .88rem;
  font-weight: 600;
  letter-spacing: .02em;
  cursor: pointer;
  border: 1.5px solid transparent;
  text-decoration: none;
  transition: var(--t);
  white-space: nowrap;
}
.btn--primary {
  background: var(--sage-dk);
  color: var(--white);
  border-color: var(--sage-dk);
}
.btn--primary:hover {
  background: var(--charcoal2);
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(31,31,31,.22);
}
.btn--outline {
  background: transparent;
  color: var(--charcoal);
  border-color: rgba(31,31,31,.28);
}
.btn--outline:hover {
  border-color: var(--sage);
  color: var(--sage-dk);
  transform: translateY(-2px);
}
.btn--large { padding: 16px 32px; font-size: .95rem; }
.btn--full  { width: 100%; justify-content: center; }
.btn--wa {
  background: #25D366;
  color: var(--white);
  border-color: #25D366;
}
.btn--wa:hover {
  background: #1fb855;
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(37,211,102,.3);
}
.btn--red {
  background: var(--red);
  color: var(--white);
  border-color: var(--red);
}
.btn--red:hover {
  background: var(--red-dk);
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(192,44,32,.28);
}

/* ── REVEAL ── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s ease, transform .6s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal--delay-1 { transition-delay: .1s; }
.reveal--delay-2 { transition-delay: .2s; }
.reveal--delay-3 { transition-delay: .3s; }

/* ==========================================================
   HEADER
   ========================================================== */
.header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--header-h);
  transition: background var(--t), box-shadow var(--t), border-color var(--t);
  border-bottom: 1px solid transparent;
  /* Fundo transparente por padrão — fica sobre o hero escuro */
  background: transparent;
}
.header.scrolled {
  background: rgba(250,249,246,.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom-color: rgba(127,148,115,.18);
  box-shadow: 0 2px 20px rgba(31,31,31,.08);
}
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-h);
}

/* ── LOGO ── */
.nav__logo { display: flex; align-items: center; text-decoration: none; }
.logo-mark {
  height: 44px;
  width: auto;
  color: var(--white);
  transition: color var(--t);
}
.header.scrolled .logo-mark { color: var(--charcoal); }
.footer .logo-mark           { color: rgba(255,255,255,.7); }

/* ── NAV LINKS (desktop) ── */
.nav__menu {
  display: flex;
  align-items: center;
  gap: 4px;
  list-style: none;
}
.nav__link {
  font-size: .85rem;
  font-weight: 500;
  color: rgba(255,255,255,.82);
  text-decoration: none;
  padding: 8px 14px;
  border-radius: 8px;
  transition: var(--t);
}
.nav__link:hover                  { color: var(--white); }
.header.scrolled .nav__link       { color: var(--charcoal); }
.header.scrolled .nav__link:hover { color: var(--sage-dk); }

.nav__link--cta {
  background: var(--white);
  color: var(--charcoal) !important;
  font-weight: 600;
  border: 1.5px solid transparent;
  padding: 8px 18px;
}
.nav__link--cta:hover {
  background: transparent;
  border-color: rgba(255,255,255,.7);
  color: var(--white) !important;
}
.header.scrolled .nav__link--cta {
  background: var(--charcoal);
  color: var(--white) !important;
  border-color: var(--charcoal);
}
.header.scrolled .nav__link--cta:hover {
  background: var(--charcoal2);
  border-color: var(--charcoal2);
}

/* ── HAMBURGER ── */
.nav__hamburger {
  /* Oculto no desktop */
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--white);
  transition: color var(--t);
  flex-shrink: 0;
}
.header.scrolled .nav__hamburger { color: var(--charcoal); }

.ham-icon             { display: block; pointer-events: none; }
.ham-icon--close      { display: none; }
.nav__hamburger.open .ham-icon--open  { display: none; }
.nav__hamburger.open .ham-icon--close { display: block; }

/* ==========================================================
   HERO
   ========================================================== */
.hero {
  min-height: 100vh;
  background: var(--charcoal);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: calc(var(--header-h) + 60px) 0 80px;
}
.hero__texture {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.025'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero__accent-line {
  position: absolute;
  top: 0; bottom: 0; left: 50%;
  width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(127,148,115,.18), transparent);
  pointer-events: none;
}

.hero__inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}

.hero__eyebrow {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--sage-lt);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.hero__eyebrow::before {
  content: '';
  width: 24px; height: 1.5px;
  background: var(--sage);
  display: block;
}

.hero__title {
  font-family: var(--display);
  font-size: clamp(3.2rem, 7vw, 5.6rem);
  font-weight: 600;
  line-height: 1.0;
  color: var(--white);
  letter-spacing: -.02em;
  margin-bottom: 24px;
}
.hero__title em {
  font-style: italic;
  font-weight: 300;
  color: var(--sand);
}

.hero__sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,.58);
  max-width: 420px;
  line-height: 1.8;
  margin-bottom: 40px;
}

.hero__actions { display: flex; flex-wrap: wrap; gap: 12px; }

/* Hero visual — mockup browser */
.hero__visual { position: relative; }

.hero__frame {
  background: #2a2a2a;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 32px 80px rgba(0,0,0,.5);
}
.hero__frame-bar {
  background: #222;
  padding: 10px 16px;
  display: flex;
  gap: 6px;
  align-items: center;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.hero__frame-bar span {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
}
.hero__frame-bar span:first-child { background: var(--red-lt); opacity:.7; }
.hero__frame-bar span:nth-child(2) { background: var(--sand); opacity:.5; }
.hero__frame-bar span:nth-child(3) { background: var(--sage); opacity:.6; }

.hero__frame-body { padding: 20px; display: flex; flex-direction: column; gap: 14px; }
.hf-hero-block {
  height: 110px;
  background: linear-gradient(135deg, var(--sage-dk) 0%, var(--slate) 100%);
  border-radius: 8px;
  opacity: .85;
}
.hf-row { display: flex; gap: 10px; }
.hf-card {
  flex: 1; height: 60px;
  background: rgba(255,255,255,.06);
  border-radius: 7px;
  border: 1px solid rgba(255,255,255,.07);
}
.hf-text-block { display: flex; flex-direction: column; gap: 6px; padding: 4px 0; }
.hf-line { height: 8px; background: rgba(255,255,255,.1); border-radius: 4px; }
.hf-line--lg { width: 65%; background: rgba(255,255,255,.18); height: 10px; }
.hf-line--sm { width: 42%; }

.hero__badge-float {
  position: absolute;
  bottom: -14px; right: -14px;
  background: var(--sage);
  color: var(--white);
  font-size: .78rem;
  font-weight: 700;
  padding: 10px 16px;
  border-radius: 100px;
  display: flex;
  align-items: center;
  gap: 7px;
  box-shadow: 0 8px 24px rgba(127,148,115,.4);
  animation: floatUp 3s ease-in-out infinite alternate;
}
@keyframes floatUp {
  from { transform: translateY(0); }
  to   { transform: translateY(-6px); }
}

.hero__scroll {
  position: absolute;
  bottom: 32px; left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,.3);
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .15em;
  text-transform: uppercase;
}
.hero__scroll-line {
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, rgba(255,255,255,.3), transparent);
  /* BUG FIX #3: transform-origin deve estar no elemento, não dentro do @keyframes */
  transform-origin: top center;
  animation: scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine {
  0%   { transform: scaleY(0); opacity: 1; }
  50%  { transform: scaleY(1); opacity: 1; }
  100% { transform: scaleY(1); opacity: 0; }
}

/* ==========================================================
   SOBRE
   ========================================================== */
.sobre {
  padding: 120px 0;
  background: var(--cream);
}
.sobre__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.sobre__text {
  font-size: 1rem;
  color: #555;
  line-height: 1.85;
  margin-bottom: 18px;
}
.sobre__manifesto {
  background: var(--charcoal);
  color: var(--white);
  border-radius: var(--radius-lg);
  padding: 40px 36px;
  position: relative;
  margin-bottom: 28px;
  overflow: hidden;
}
.sobre__manifesto::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--sage);
}
.sobre__manifesto-mark {
  font-family: var(--display);
  font-size: 5rem;
  line-height: .6;
  color: rgba(211,199,149,.2);
  font-weight: 300;
  margin-bottom: 12px;
  display: block;
}
.sobre__manifesto blockquote {
  font-family: var(--display);
  font-size: 1.25rem;
  font-weight: 300;
  font-style: italic;
  line-height: 1.7;
  color: rgba(255,255,255,.88);
  border: none;
  padding: 0;
  margin: 0 0 16px;
}
.sobre__manifesto footer {
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--sage-lt);
}

/* Stats / Contadores */
.sobre__stats {
  display: flex;
  gap: 28px;
  margin: 24px 0 28px;
  flex-wrap: wrap;
}
.stat-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.stat-item__num {
  font-family: var(--display);
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--charcoal);
  line-height: 1;
  letter-spacing: -.02em;
}
.stat-item__suffix {
  font-family: var(--display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--sage-dk);
  line-height: 1;
}
.stat-item__label {
  font-size: .73rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #888;
}


.value-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 16px 20px;
  background: var(--mist);
  border-radius: var(--radius);
  border: 1px solid rgba(127,148,115,.15);
  transition: var(--t);
}
.value-item:hover {
  border-color: var(--sage);
  box-shadow: var(--shadow-sm);
}
.value-item__dot {
  width: 8px; height: 8px; flex-shrink: 0;
  border-radius: 50%;
  background: var(--sage);
  margin-top: 6px;
}
.value-item strong { display: block; font-size: .9rem; font-weight: 700; color: var(--charcoal); margin-bottom: 3px; }
.value-item span { font-size: .85rem; color: #666; }

/* ==========================================================
   SERVIÇOS
   ========================================================== */
.servicos {
  padding: 120px 0;
  background: var(--charcoal);
  position: relative;
  overflow: hidden;
}
.servicos::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M0 0h40v40H0V0zm1 1v38h38V1H1z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.servicos .section-eyebrow { color: var(--sage-lt); }
.servicos .section-eyebrow::before { background: var(--sage-lt); }
.servicos .section-title { color: var(--white); }
.servicos .section-title em { color: var(--sand); }

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

.servico {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-lg);
  padding: 40px 32px;
  position: relative;
  overflow: hidden;
  transition: var(--t);
}
.servico:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(127,148,115,.35);
  transform: translateY(-5px);
  box-shadow: 0 20px 48px rgba(0,0,0,.3);
}
.servico__num {
  position: absolute;
  top: 20px; right: 24px;
  font-family: var(--display);
  font-size: 4.5rem;
  font-weight: 600;
  color: rgba(127,148,115,.1);
  line-height: 1;
  pointer-events: none;
}
.servico__icon {
  width: 52px; height: 52px;
  border-radius: 12px;
  background: rgba(127,148,115,.12);
  border: 1px solid rgba(127,148,115,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--sage-lt);
  margin-bottom: 22px;
  transition: var(--t);
}
.servico:hover .servico__icon {
  background: var(--sage);
  color: var(--white);
  border-color: var(--sage);
}
.servico h3 {
  font-family: var(--display);
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--white);
  margin-bottom: 14px;
  letter-spacing: -.01em;
}
.servico p { font-size: .9rem; color: rgba(255,255,255,.55); line-height: 1.75; margin-bottom: 24px; }
.servico__link {
  font-size: .82rem;
  font-weight: 700;
  color: var(--sage-lt);
  text-decoration: none;
  letter-spacing: .04em;
  transition: var(--t);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.servico__link:hover { color: var(--sand); gap: 8px; }

/* ==========================================================
   PORTFÓLIO
   ========================================================== */
.portfolio {
  padding: 120px 0;
  background: var(--mist);
}

/* ── Filtros ── */
.portfolio__filters {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 44px;
}
.portfolio__filter-btn {
  font-family: var(--body);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 8px 20px;
  border-radius: 100px;
  border: 1.5px solid rgba(127,148,115,.3);
  background: transparent;
  color: #777;
  cursor: pointer;
  transition: var(--t);
}
.portfolio__filter-btn:hover,
.portfolio__filter-btn.active {
  background: var(--charcoal);
  border-color: var(--charcoal);
  color: var(--white);
}

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

.pitem {
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  position: relative;
  border: 1px solid rgba(127,148,115,.15);
  background: var(--white);
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.pitem:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
/* Cor dinâmica via CSS custom property injetada pelo JS */
.pitem::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--pitem-accent, transparent);
  opacity: 0;
  transition: opacity .4s ease;
  pointer-events: none;
  z-index: 0;
  border-radius: inherit;
}
.pitem:hover::before { opacity: .04; }

.pitem__visual {
  height: 185px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* Mockup dentro do portfólio */
.pitem__mockup {
  width: 78%;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 7px;
  overflow: hidden;
}
.pm-bar {
  background: rgba(0,0,0,.25);
  padding: 6px 10px;
  display: flex; gap: 5px; align-items: center;
}
.pm-bar span {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
}
.pm-body { padding: 12px; display: flex; flex-direction: column; gap: 8px; }
.pm-hero { height: 42px; background: rgba(255,255,255,.18); border-radius: 5px; }
.pm-lines { display: flex; flex-direction: column; gap: 5px; }
.pm-l { height: 6px; background: rgba(255,255,255,.2); border-radius: 3px; }
.pm-l--w70 { width: 70%; }
.pm-l--w50 { width: 50%; }

.pitem__info { padding: 18px 22px; }
.pitem__cat {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--sage-dk);
  display: block;
  margin-bottom: 5px;
}
.pitem__info h3 { font-family: var(--display); font-size: 1.3rem; font-weight: 600; color: var(--charcoal); }

.pitem__hover {
  position: absolute;
  inset: 0;
  background: rgba(31,31,31,.82);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  opacity: 0;
  transition: var(--t);
  font-size: .88rem;
  font-weight: 700;
  color: var(--sand-lt);
  letter-spacing: .04em;
  backdrop-filter: blur(4px);
}
.pitem:hover .pitem__hover { opacity: 1; }

/* ==========================================================
   DIFERENCIAIS
   ========================================================== */
.diferenciais {
  padding: 120px 0;
  background: var(--cream);
  position: relative;
}
.diferenciais::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(127,148,115,.3), transparent);
}

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

.dif {
  padding: 40px 32px;
  border-radius: var(--radius-lg);
  background: var(--white);
  border: 1px solid rgba(127,148,115,.15);
  transition: var(--t);
  position: relative;
  overflow: hidden;
}
.dif::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--sage), var(--sand));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t);
}
.dif:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.dif:hover::after { transform: scaleX(1); }

.dif__icon {
  width: 52px; height: 52px;
  border-radius: 12px;
  background: rgba(127,148,115,.1);
  border: 1px solid rgba(127,148,115,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--sage-dk);
  margin-bottom: 20px;
  transition: var(--t);
}
.dif:hover .dif__icon { background: var(--sage); color: var(--white); border-color: var(--sage); }
.dif h3 { font-family: var(--display); font-size: 1.4rem; font-weight: 600; color: var(--charcoal); margin-bottom: 10px; }
.dif p { font-size: .9rem; color: #666; line-height: 1.75; }

/* ==========================================================
   DEPOIMENTOS
   ========================================================== */
.depoimentos {
  padding: 120px 0;
  background: var(--charcoal);
}
.depoimentos .section-eyebrow { color: var(--sage-lt); }
.depoimentos .section-eyebrow::before { background: var(--sage-lt); }
.depoimentos .section-title { color: var(--white); }
.depoimentos .section-title em { color: var(--sand); }

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

.dep {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-lg);
  padding: 36px 30px;
  transition: var(--t);
  position: relative;
}
.dep:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(127,148,115,.3);
  transform: translateY(-4px);
}
.dep__stars {
  color: var(--sand);
  font-size: .95rem;
  letter-spacing: 2px;
  margin-bottom: 16px;
}
.dep blockquote {
  font-family: var(--display);
  font-size: 1.05rem;
  font-weight: 300;
  font-style: italic;
  line-height: 1.8;
  color: rgba(255,255,255,.78);
  border: none; padding: 0;
  margin: 0 0 24px;
}
.dep__author { display: flex; align-items: center; gap: 12px; }
.dep__av {
  width: 40px; height: 40px; flex-shrink: 0;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .8rem; color: var(--white);
}
.dep__author strong { display: block; font-size: .88rem; font-weight: 700; color: var(--white); }
.dep__author span { font-size: .78rem; color: rgba(255,255,255,.45); }

/* ==========================================================
   CTA BAND
   ========================================================== */
.cta-band {
  padding: 100px 0;
  background: var(--sage);
  position: relative;
  overflow: hidden;
}
.cta-band::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.cta-band__inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
}
.cta-band__text h2 {
  font-family: var(--display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 600;
  color: var(--white);
  line-height: 1.12;
  margin-bottom: 12px;
}
.cta-band__text h2 em {
  font-style: italic;
  font-weight: 300;
  color: var(--sand-lt);
}
.cta-band__text p { font-size: .95rem; color: rgba(255,255,255,.72); max-width: 420px; }
.cta-band__actions { display: flex; gap: 14px; flex-wrap: wrap; }
.cta-band .btn--primary {
  background: var(--white);
  color: var(--sage-dk);
  border-color: var(--white);
}
.cta-band .btn--primary:hover {
  background: var(--cream);
  border-color: var(--cream);
}

/* ==========================================================
   CONTATO
   ========================================================== */
.contato {
  padding: 120px 0;
  background: var(--cream);
}
.contato__inner {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 80px;
  align-items: start;
}
.contato__left p {
  font-size: .97rem;
  color: #666;
  line-height: 1.8;
  margin: 20px 0 32px;
}
.contato__info-items { display: flex; flex-direction: column; gap: 12px; }
.cinfo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .88rem;
  color: #555;
  font-weight: 500;
}
.cinfo svg { color: var(--sage-dk); flex-shrink: 0; }

/* FORM */
.contato__right {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 44px 40px;
  border: 1px solid rgba(127,148,115,.15);
  box-shadow: var(--shadow-sm);
}
.form { display: flex; flex-direction: column; gap: 20px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label { font-size: .78rem; font-weight: 700; color: var(--charcoal); letter-spacing: .03em; }
.form-group input,
.form-group textarea,
.form-group select {
  padding: 12px 15px;
  border: 1.5px solid #ddd;
  border-radius: var(--radius);
  font-family: var(--body);
  font-size: .9rem;
  color: var(--charcoal);
  background: var(--white);
  transition: var(--t);
  outline: none;
  width: 100%;
  appearance: none;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--sage);
  box-shadow: 0 0 0 3px rgba(127,148,115,.15);
}
.form-group input.error,
.form-group textarea.error { border-color: var(--red); }
.form-group textarea { resize: vertical; min-height: 110px; }
.form-err {
  font-size: .75rem;
  color: var(--red);
  font-weight: 600;
  display: none;
}
.form-err.visible { display: block; }
.form-ok {
  display: none;
  align-items: center;
  gap: 10px;
  background: rgba(127,148,115,.1);
  border: 1px solid rgba(127,148,115,.3);
  color: var(--sage-dk);
  padding: 14px 18px;
  border-radius: var(--radius);
  font-size: .88rem;
  font-weight: 600;
}
.form-ok.visible { display: flex; }

/* ==========================================================
   FOOTER
   ========================================================== */
.footer {
  background: #161616;
  padding: 44px 0;
}
.footer__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 24px;
}
.footer__links { display: flex; gap: 24px; flex-wrap: wrap; }
.footer__links a {
  font-size: .84rem;
  color: rgba(255,255,255,.4);
  text-decoration: none;
  transition: var(--t);
}
.footer__links a:hover { color: var(--sage-lt); }
.footer__copy { font-size: .78rem; color: rgba(255,255,255,.25); }

/* ==========================================================
   WHATSAPP FLOAT
   ========================================================== */
.wa-float {
  position: fixed;
  bottom: 28px; right: 28px;
  z-index: 900;
  width: 54px; height: 54px;
  border-radius: 50%;
  background: #25D366;
  display: flex; align-items: center; justify-content: center;
  color: var(--white);
  text-decoration: none;
  box-shadow: 0 4px 18px rgba(37,211,102,.38);
  transition: var(--t);
}
.wa-float:hover { transform: scale(1.1); box-shadow: 0 8px 26px rgba(37,211,102,.5); }
.wa-float__tip {
  position: absolute;
  right: calc(100% + 12px);
  background: var(--charcoal);
  color: var(--white);
  font-size: .75rem;
  font-weight: 600;
  padding: 7px 13px;
  border-radius: 8px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: var(--t);
}
.wa-float__tip::after {
  content: '';
  position: absolute;
  top: 50%; left: 100%;
  transform: translateY(-50%);
  border: 5px solid transparent;
  border-left-color: var(--charcoal);
}
.wa-float:hover .wa-float__tip { opacity: 1; }

/* INSTAGRAM LINK */
.btn--instagram {
  background: linear-gradient(135deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
  color: var(--white);
  border-color: transparent;
}
.btn--instagram:hover {
  opacity: .88;
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(220,39,67,.32);
}

/* CINFO links (telefone e e-mail clicáveis) */
.cinfo--link {
  text-decoration: none;
  color: inherit;
  transition: color var(--t);
}
.cinfo--link:hover { color: var(--sage-dk); }

/* ==========================================================
   MODAL
   ========================================================== */
.modal-overlay {
  position: fixed; inset: 0;
  z-index: 2000;
  background: rgba(22,22,22,.88);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; pointer-events: none;
  transition: opacity var(--t);
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal {
  background: var(--white);
  border-radius: var(--radius-lg);
  max-width: 700px; width: 100%;
  overflow: hidden;
  position: relative;
  transform: scale(.96) translateY(16px);
  transition: transform var(--t);
}
.modal-overlay.open .modal { transform: scale(1) translateY(0); }
.modal__close {
  position: absolute; top: 16px; right: 16px;
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--mist); border: 1px solid #ddd;
  color: var(--charcoal); display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: var(--t); z-index: 1;
}
.modal__close:hover { background: var(--charcoal); color: var(--white); }

/* Conteúdo gerado pelo JS */
.modal-body { padding: 32px 40px 28px; }
.modal-eyebrow {
  font-size: .7rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--sage-dk); margin-bottom: 6px;
}
.modal-title {
  font-family: var(--display); font-size: 1.75rem; font-weight: 600;
  color: var(--charcoal); margin-bottom: 16px; letter-spacing: -.01em;
}
.modal-preview {
  width: 100%; height: 220px; border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 24px; position: relative; overflow: hidden;
}
.modal-preview-inner {
  width: 76%; background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.15); border-radius: 8px; overflow: hidden;
}
.modal-desc { font-size: .9rem; color: #555; line-height: 1.72; margin-bottom: 16px; }
.modal-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 0; }
.modal-tag {
  font-size: .74rem; font-weight: 600; color: var(--charcoal);
  background: var(--mist); border: 1px solid #ddd;
  padding: 4px 12px; border-radius: 6px;
}
.modal-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.modal-footer-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 0;
}
.modal-cta-btn {
  font-size: .82rem !important;
  padding: 9px 18px !important;
  white-space: nowrap;
  flex-shrink: 0;
  background: var(--sage) !important;
  border-color: var(--sage) !important;
}
.modal-cta-btn:hover {
  background: var(--sage-dk) !important;
  border-color: var(--sage-dk) !important;
}
.modal-link {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: .84rem; font-weight: 700; color: var(--sage-dk);
  text-decoration: none; border: 1.5px solid rgba(127,148,115,.4);
  padding: 10px 18px; border-radius: var(--radius);
  transition: var(--t);
}
.modal-link:hover { background: var(--sage); color: var(--white); border-color: var(--sage); }
.modal-link--ext svg { flex-shrink: 0; }

/* Preview iframe dentro do modal */
.modal-iframe-wrap {
  width: 100%; height: 220px;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid #ddd;
  margin-bottom: 16px;
  position: relative;
  background: var(--mist);
}
.modal-iframe-wrap iframe {
  width: 300%; height: 300%;
  transform: scale(0.333);
  transform-origin: top left;
  border: none;
  pointer-events: none;
}
.modal-iframe-overlay {
  position: absolute; inset: 0;
  background: transparent;
  cursor: pointer;
  text-decoration: none;
  display: block;
}
.modal-iframe-overlay--clickable {
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  transition: background .2s ease;
}
.modal-iframe-overlay--clickable:hover {
  background: rgba(0,0,0,.18);
}
.modal-iframe-overlay__hint {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(0,0,0,.72);
  color: #fff;
  font-size: .8rem;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 20px;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .2s ease, transform .2s ease;
  pointer-events: none;
}
.modal-iframe-overlay--clickable:hover .modal-iframe-overlay__hint {
  opacity: 1;
  transform: translateY(0);
}

/* Card portfolio com iframe de preview */
.pitem__iframe {
  position: absolute;
  top: 0; left: 0;
  width: 300%; height: 300%;
  transform: scale(0.333);
  transform-origin: top left;
  border: none;
  pointer-events: none;
  display: block;
}
.pitem__iframe-overlay {
  position: absolute; inset: 0;
  background: transparent;
  z-index: 2;
}
.modal-loading {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: .82rem; color: #aaa; gap: 8px;
}

/* ==========================================================
   RESPONSIVE
   ========================================================== */

/* ── TABLET ≤ 1024px ── */
@media (max-width: 1024px) {
  .hero__inner         { grid-template-columns: 1fr; gap: 48px; }
  .hero__visual        { display: none; }
  .servicos__grid      { grid-template-columns: repeat(2, 1fr); }
  .difs__grid          { grid-template-columns: repeat(2, 1fr); }
  .deps__grid          { grid-template-columns: repeat(2, 1fr); }
  .portfolio__grid     { grid-template-columns: repeat(2, 1fr); }
  .sobre__inner,
  .contato__inner      { grid-template-columns: 1fr; gap: 48px; }
}

/* ── MOBILE ≤ 768px ── */
@media (max-width: 768px) {
  :root { --header-h: 64px; }

  /* ─ Header: fundo sólido desde o início no mobile ─
     No mobile não existe o efeito "hero transparente" pois
     a tela é pequena e o conteúdo começa logo abaixo.
     Isso evita a logo "sumida" e a barra preta fantasma.   */
  .header {
    background: var(--charcoal);
    border-bottom-color: rgba(255,255,255,.07);
  }
  /* Quando scrolled no mobile, fica um pouco mais claro */
  .header.scrolled {
    background: var(--charcoal);
    border-bottom-color: rgba(255,255,255,.1);
    box-shadow: 0 2px 16px rgba(0,0,0,.3);
  }
  /* Logo sempre branca no mobile (header sempre escuro) */
  .logo-mark                        { height: 38px; color: var(--white) !important; }
  .header.scrolled .logo-mark       { color: var(--white) !important; }

  /* ─ Hamburger: visível ─ */
  .nav__hamburger {
    display: flex;
    color: var(--white) !important;
  }
  .header.scrolled .nav__hamburger  { color: var(--white) !important; }

  /* ─ Menu mobile ─
     Usa opacity + visibility + translateY em vez de translateY(-110%)
     para não criar artefatos visuais acima do header.            */
  .nav__menu {
    /* Posição: logo abaixo do header */
    position: fixed;
    top: var(--header-h);
    left: 0;
    right: 0;
    z-index: 999;

    /* Visual */
    background: #161616;
    border-bottom: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 12px 32px rgba(0,0,0,.5);

    /* Layout */
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 8px 16px 24px;
    list-style: none;

    /* Animação: começa oculto (visibility+opacity, sem translateY que vaza) */
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity .25s ease, visibility .25s ease, transform .25s ease;
  }
  /* Estado aberto */
  .nav__menu.open {
    opacity: 1;
    visibility: visible;
    pointer-events: all;
    transform: translateY(0);
  }

  /* Links no menu mobile */
  .nav__menu li              { border-bottom: 1px solid rgba(255,255,255,.06); }
  .nav__menu li:last-child   { border-bottom: none; }
  .nav__link {
    display: block;
    padding: 15px 8px;
    font-size: .97rem;
    font-weight: 500;
    color: rgba(255,255,255,.78);
    border-radius: 0;
  }
  .nav__link:hover,
  .nav__link:focus            { color: var(--white); background: none; }
  .header.scrolled .nav__link { color: rgba(255,255,255,.78); }

  /* CTA no menu mobile */
  .nav__link--cta {
    display: block;
    margin-top: 12px;
    padding: 13px 16px !important;
    text-align: center;
    background: var(--sage) !important;
    color: var(--white) !important;
    border: none !important;
    border-radius: var(--radius) !important;
    font-weight: 600;
  }
  .nav__link--cta:hover { background: var(--sage-dk) !important; }
  .header.scrolled .nav__link--cta { background: var(--sage) !important; }

  /* ─ Hero ─ */
  .hero {
    padding: calc(var(--header-h) + 52px) 0 72px;
    min-height: calc(100svh - 0px);
  }
  .hero__title  { font-size: clamp(2.6rem, 10vw, 3.4rem); line-height: 1.06; }
  .hero__sub    { font-size: .96rem; max-width: 100%; }
  .hero__scroll { display: none; }

  /* ─ Seções ─ */
  .sobre, .servicos, .portfolio,
  .diferenciais, .depoimentos, .contato { padding: 80px 0; }
  .cta-band      { padding: 72px 0; }
  .section-header{ margin-bottom: 48px; }
  .section-title { font-size: clamp(1.95rem, 6.5vw, 2.6rem); }

  /* Sobre */
  .sobre__inner    { gap: 56px; }
  .sobre__left     { padding-bottom: 8px; border-bottom: 1px solid rgba(127,148,115,.15); }
  .sobre__manifesto { padding: 30px 26px; }
  .sobre__stats { gap: 20px; }
  .stat-item__num { font-size: 2rem; }

  /* Serviços */
  .servicos__grid { grid-template-columns: 1fr; gap: 14px; }
  .servico        { padding: 32px 26px; }

  /* Portfólio */
  .portfolio__grid { grid-template-columns: 1fr; gap: 14px; }
  .portfolio__filters { gap: 8px; }
  .portfolio__filter-btn { font-size: .72rem; padding: 7px 16px; }

  /* Diferenciais */
  .difs__grid { grid-template-columns: 1fr; gap: 14px; }
  .dif        { padding: 32px 26px; }

  /* Depoimentos */
  .deps__grid { grid-template-columns: 1fr; gap: 14px; }
  .dep        { padding: 28px 24px; }

  /* CTA band */
  .cta-band__inner   { flex-direction: column; text-align: center; gap: 32px; }
  .cta-band__text p  { margin: 0 auto; }
  .cta-band__actions { justify-content: center; flex-wrap: wrap; gap: 12px; }
  .cta-band__actions .btn { flex: 1 1 160px; justify-content: center; }

  /* Contato */
  .contato__inner { gap: 40px; }
  .contato__right { padding: 28px 22px; }
  .form-row       { grid-template-columns: 1fr; }

  /* Footer */
  .footer        { padding: 40px 0; }
  .footer__inner { flex-direction: column; align-items: center; text-align: center; gap: 22px; }
  .footer__links { justify-content: center; flex-wrap: wrap; gap: 20px; }

  /* Modal — bottom sheet */
  .modal-overlay { padding: 0; align-items: flex-end; }
  .modal {
    max-height: 92vh;
    overflow-y: auto;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    width: 100%;
    max-width: 100%;
  }
  .modal-body    { padding: 24px 18px 28px; }
  .modal-title   { font-size: 1.5rem; }
  .modal-footer-row { flex-direction: column; align-items: flex-start; gap: 12px; }
  .modal-cta-btn { width: 100%; justify-content: center; text-align: center; }

  /* Botões flutuantes */
  .wa-float       { bottom: 20px; right: 16px; width: 50px; height: 50px; }
  .wa-float__tip  { display: none; }
}

/* ── MOBILE PEQUENO ≤ 480px ── */
@media (max-width: 480px) {
  :root { --header-h: 58px; }

  .container    { padding: 0 18px; }
  .logo-mark    { height: 34px; }

  .hero {
    padding: calc(var(--header-h) + 44px) 0 64px;
    min-height: auto;
  }
  .hero__title   { font-size: clamp(2.1rem, 9vw, 2.8rem); }
  .hero__actions { flex-direction: column; gap: 10px; }
  .hero__actions .btn { width: 100%; justify-content: center; }

  .sobre, .servicos, .portfolio,
  .diferenciais, .depoimentos, .contato { padding: 64px 0; }
  .cta-band { padding: 60px 0; }

  .section-title { font-size: clamp(1.8rem, 7.5vw, 2.2rem); }

  .servico__num  { font-size: 3rem; top: 14px; right: 16px; }
  .pitem__visual { height: 160px; }

  .contato__right { padding: 22px 16px 28px; }
  .form-group input,
  .form-group textarea,
  .form-group select { font-size: .88rem; padding: 11px 12px; }

  .modal-body  { padding: 22px 16px 36px; }
  .modal-title { font-size: 1.4rem; }

  .footer__links { flex-direction: column; align-items: center; gap: 14px; }
}
