/* =====================================================
   NEXA LOTUS — CSS Premium v2
   Refinamento Avançado · Outfit + Lora
   ===================================================== */

:root {
  --bg:            #F7F5F2;
  --bg-alt:        #EFECE7;
  --bg-dark:       #181614;
  --bg-dark-alt:   #1F1C1A;
  --bg-dark-2:     #242220;
  --text:          #1C1917;
  --text-muted:    #6B6560;
  --text-light:    #A09990;
  --accent:        #5C7A4E;
  --accent-light:  #7A9D6A;
  --accent-glow:   rgba(92,122,78,0.25);
  --accent-warm:   #C4A882;
  --accent-gold:   #B89A6A;
  --border:        rgba(28,25,23,0.07);
  --border-strong: rgba(28,25,23,0.13);
  --border-dark:   rgba(255,255,255,0.08);
  --radius-sm:     8px;
  --radius-md:     14px;
  --radius-lg:     24px;
  --radius-xl:     32px;
  --shadow-sm:     0 2px 12px rgba(0,0,0,0.05);
  --shadow-md:     0 8px 32px rgba(0,0,0,0.08);
  --shadow-lg:     0 20px 60px rgba(0,0,0,0.11);
  --shadow-xl:     0 32px 80px rgba(0,0,0,0.14);
  --shadow-glow:   0 0 40px rgba(92,122,78,0.15);
  --transition:    0.35s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-fast: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --font-body:     'Outfit', sans-serif;
  --font-serif:    'Lora', serif;
  --max-w:         1200px;
  --header-h:      72px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; height: auto; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { font-family: var(--font-body); cursor: pointer; border: none; background: none; }

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 3px; }

.container { max-width: var(--max-w); margin: 0 auto; padding: 0 5%; }

/* ——— TYPOGRAPHY ——— */
.section-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.section-label::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 1.5px;
  background: var(--accent);
  flex-shrink: 0;
}
.section-label.light { color: var(--accent-light); }
.section-label.light::before { background: var(--accent-light); }

.section-title {
  font-size: clamp(1.9rem, 3.5vw, 2.8rem);
  font-weight: 700;
  line-height: 1.15;
  color: var(--text);
  letter-spacing: -0.02em;
}
.section-title em {
  font-style: italic;
  font-family: var(--font-serif);
  color: var(--accent);
}

.section-real-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border-radius:24px;
}

.section-header.centered { text-align: center; margin-bottom: 4rem; }
.section-header.centered .section-label { justify-content: center; }
.section-header.centered .section-label::before { display: none; }

/* ——— BUTTONS ——— */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--text);
  color: var(--bg);
  padding: 0.875rem 1.75rem;
  border-radius: 50px;
  font-size: 0.925rem;
  font-weight: 600;
  transition: var(--transition);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
}
.btn-primary::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--accent);
  opacity: 0;
  transition: var(--transition);
  border-radius: 50px;
}
.btn-primary:hover::after { opacity: 1; }
.btn-primary:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn-primary > * { position: relative; z-index: 1; }

.btn-primary.btn-glow:hover { box-shadow: 0 8px 30px rgba(92,122,78,0.35); }

.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--text-muted);
  padding: 0.875rem 1.5rem;
  border-radius: 50px;
  font-size: 0.925rem;
  font-weight: 500;
  border: 1.5px solid var(--border-strong);
  transition: var(--transition);
}
.btn-ghost:hover { color: var(--text); border-color: var(--text); background: rgba(28,25,23,0.03); }

.btn-outline-dark {
  display: inline-flex;
  align-items: center;
  color: var(--text);
  font-weight: 600;
  font-size: 0.95rem;
  padding-bottom: 3px;
  border-bottom: 2px solid var(--accent);
  transition: var(--transition);
  gap: 0.4rem;
}
.btn-outline-dark:hover { color: var(--accent); gap: 0.7rem; }

.btn-primary-sm {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: var(--text);
  color: var(--bg);
  padding: 0.7rem 1.4rem;
  border-radius: 50px;
  font-size: 0.875rem;
  font-weight: 600;
  transition: var(--transition);
  margin-top: 1.75rem;
  position: relative;
  overflow: hidden;
}
.btn-primary-sm::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--accent);
  opacity: 0;
  transition: var(--transition);
  border-radius: 50px;
}
.btn-primary-sm:hover::after { opacity: 1; }
.btn-primary-sm:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(92,122,78,0.25); }
.btn-primary-sm > * { position: relative; z-index: 1; }

/* ——————————————————
   HEADER
—————————————————— */
#header {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--header-h);
  z-index: 1000;
  background: rgba(247,245,242,0.85);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid var(--border);
  transition: var(--transition);
}
#header.scrolled { box-shadow: 0 1px 0 var(--border), 0 4px 20px rgba(0,0,0,0.06); }

.header-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 5%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.logo-link { display: flex; align-items: center; }
.logo-img { height: 46px; width: auto; }

.main-nav { display: flex; align-items: center; gap: 0.15rem; }
.main-nav a {
  font-size: 0.86rem;
  font-weight: 500;
  color: var(--text-muted);
  padding: 0.5rem 0.875rem;
  border-radius: 50px;
  transition: var(--transition-fast);
  position: relative;
}
.main-nav a::after {
  content: '';
  position: absolute;
  bottom: 6px; left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 16px; height: 2px;
  background: var(--accent);
  border-radius: 1px;
  transition: var(--transition-fast);
}
.main-nav a:hover { color: var(--text); }
.main-nav a:hover::after, .main-nav a.active::after { transform: translateX(-50%) scaleX(1); }
.main-nav a.active { color: var(--text); }
.main-nav a.nav-cta {
  background: var(--text);
  color: var(--bg);
  margin-left: 0.5rem;
}
.main-nav a.nav-cta::after { display: none; }
.main-nav a.nav-cta:hover { background: var(--accent); color: #fff; }

.menu-toggle { display: none; flex-direction: column; gap: 5px; padding: 8px; }
.menu-toggle span { display: block; width: 22px; height: 2px; background: var(--text); border-radius: 2px; transition: var(--transition); }

/* ——————————————————
   HERO
—————————————————— */
.hero {
  min-height: 100vh;
  padding-top: var(--header-h);
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--bg);
}

.hero-bg { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }

.hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
}
.hero-orb-1 {
  width: 600px; height: 600px;
  background: radial-gradient(circle, var(--accent) 0%, transparent 70%);
  opacity: 0.14;
  top: -150px; right: -50px;
  animation: orbFloat 12s ease-in-out infinite;
}
.hero-orb-2 {
  width: 450px; height: 450px;
  background: radial-gradient(circle, var(--accent-warm) 0%, transparent 70%);
  opacity: 0.12;
  bottom: -80px; left: -80px;
  animation: orbFloat 15s ease-in-out infinite reverse;
}
.hero-orb-3 {
  width: 300px; height: 300px;
  background: radial-gradient(circle, var(--accent) 0%, transparent 70%);
  opacity: 0.07;
  top: 50%; left: 40%;
  animation: orbFloat 18s ease-in-out infinite 3s;
}
@keyframes orbFloat {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(20px, -25px) scale(1.03); }
  66% { transform: translate(-15px, 15px) scale(0.97); }
}

.hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 100%);
}

.hero-noise {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  opacity: 0.4;
  pointer-events: none;
}

.hero-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 4rem 5% 5rem;
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: 4rem;
  align-items: center;
  position: relative;
  z-index: 1;
  width: 100%;
}

/* Reveal animations */
[data-reveal] { animation: revealLeft 0.9s cubic-bezier(0.16,1,0.3,1) both; }
[data-reveal-delay] { animation: revealRight 0.9s cubic-bezier(0.16,1,0.3,1) 0.2s both; }
@keyframes revealLeft {
  from { opacity: 0; transform: translateX(-30px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes revealRight {
  from { opacity: 0; transform: translateX(30px); }
  to   { opacity: 1; transform: translateX(0); }
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(92,122,78,0.09);
  color: var(--accent);
  padding: 0.4rem 1rem 0.4rem 0.6rem;
  border-radius: 50px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-bottom: 1.5rem;
  border: 1px solid rgba(92,122,78,0.18);
  width: fit-content;
}
.badge-dot {
  width: 7px; height: 7px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(92,122,78,0.2);
  animation: pulseDot 2.5s ease-in-out infinite;
}
@keyframes pulseDot {
  0%, 100% { box-shadow: 0 0 0 3px rgba(92,122,78,0.2); }
  50% { box-shadow: 0 0 0 6px rgba(92,122,78,0.08); }
}

.hero-headline {
  font-size: clamp(2.5rem, 4.5vw, 3.9rem);
  font-weight: 800;
  line-height: 1.08;
  color: var(--text);
  letter-spacing: -0.03em;
  margin-bottom: 1.25rem;
}
.hero-headline em {
  font-style: italic;
  font-family: var(--font-serif);
  color: var(--accent);
  font-weight: 600;
}

.hero-sub {
  font-size: 1.05rem;
  color: var(--text-muted);
  line-height: 1.72;
  margin-bottom: 1.5rem;
  max-width: 480px;
}

.hero-benefits {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.5rem;
  margin-bottom: 2rem;
}
.hero-benefits span {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-muted);
}
.hero-benefits span svg { color: var(--accent); flex-shrink: 0; }

.hero-ctas { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-bottom: 2.5rem; }

/* ——— Hero Mockup ——— */
.hero-mockup-wrap {
  position: relative;
  padding: 1rem 0.5rem 2.5rem;
}

.hero-browser {
  background: #fff;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl), 0 0 0 1px var(--border);
  overflow: hidden;
  position: relative;
  transform-origin: center top;
  animation: browserFloat 7s ease-in-out infinite;
  transition: box-shadow var(--transition);
}
.hero-browser:hover { box-shadow: var(--shadow-xl), var(--shadow-glow), 0 0 0 1px rgba(92,122,78,0.2); }
@keyframes browserFloat {
  0%, 100% { transform: translateY(0) rotate(-0.2deg); }
  50% { transform: translateY(-10px) rotate(0.2deg); }
}

.hb-top {
  background: #F0EDEA;
  padding: 0.7rem 0.875rem;
  display: flex;
  align-items: center;
  gap: 0.625rem;
  border-bottom: 1px solid var(--border);
}
.hb-dots { display: flex; gap: 5px; }
.hb-dots span { width: 10px; height: 10px; border-radius: 50%; }
.hb-dots span:nth-child(1) { background: #ff5f57; }
.hb-dots span:nth-child(2) { background: #febc2e; }
.hb-dots span:nth-child(3) { background: #28c840; }
.hb-bar {
  flex: 1;
  background: #fff;
  border-radius: 50px;
  padding: 0.22rem 0.75rem;
  font-size: 0.7rem;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 0.4rem;
  max-width: 220px;
}
.hb-bar svg { color: var(--accent); flex-shrink: 0; }
.hb-actions { margin-left: auto; color: var(--text-light); }

.hb-screen { background: var(--bg); overflow: hidden; }

.hero-real-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border-radius:0 0 18px 18px;
}

/* Scroll hint */
.hero-scroll-hint {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
.scroll-line {
  width: 1px; height: 48px;
  background: linear-gradient(to bottom, transparent, var(--accent), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%, 100% { opacity: 0.3; transform: scaleY(0.8); }
  50% { opacity: 1; transform: scaleY(1); }
}

/* ——————————————————
   PROOF STRIP
—————————————————— */
.proof-strip {
  background: var(--text);
  padding: 0.875rem 0;
  overflow: hidden;
}
.proof-inner {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
}
.proof-label {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(247,245,242,0.4);
  white-space: nowrap;
  flex-shrink: 0;
}
.proof-items {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.proof-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  font-weight: 500;
  color: rgba(247,245,242,0.75);
}
.proof-item svg { color: var(--accent-light); opacity: 0.6; }
.proof-sep { color: var(--accent); font-size: 0.6rem; opacity: 0.5; }

/* ——————————————————
   PRESENÇA DIGITAL
—————————————————— */
.section-presenca { padding: 6rem 0; background: var(--bg-alt); }
.presenca-header { margin-bottom: 3.5rem; }

.presenca-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 4rem;
  align-items: start;
  margin-bottom: 4rem;
}

.presenca-lead {
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.65;
  color: var(--text);
  margin-bottom: 1.25rem;
}
.presenca-lead strong { color: var(--accent); }
.presenca-body { font-size: 0.975rem; color: var(--text-muted); line-height: 1.78; margin-bottom: 1rem; }
.presenca-body:last-of-type { margin-bottom: 2rem; }

.presenca-stats { display: flex; flex-direction: column; gap: 1.25rem; }
.stat-block {
  padding: 1.25rem 1.5rem;
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  transition: var(--transition);
  overflow: hidden;
}
.stat-block:hover { transform: translateX(4px); border-color: var(--accent); box-shadow: var(--shadow-sm); }
.stat-inner { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 0.75rem; }
.stat-number {
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
  letter-spacing: -0.03em;
}
.stat-desc { font-size: 0.82rem; color: var(--text-muted); max-width: 180px; text-align: right; line-height: 1.5; }
.stat-bar { height: 3px; background: var(--border); border-radius: 2px; overflow: hidden; }
.stat-bar-fill { height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-light)); border-radius: 2px; transition: width 1s ease 0.3s; }

/* ——— editorial visual below ——— */
.presenca-visual { position: relative; }

/* pev-caption is defined above in editorial visual */

/* Presença editorial visual */
.presenca-editorial-visual {
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: var(--transition);
}
.presenca-editorial-visual:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.pev-svg { display: block; width: 100%; }
.pev-caption {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 1.25rem;
  border-top: 1px solid var(--border);
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--text-muted);
}
.pev-caption svg { color: var(--accent); flex-shrink: 0; }

/* Servico conceito */
.servico-conceito {
  margin-top: 1.5rem;
  padding: 0.875rem 1.125rem;
  background: rgba(92,122,78,0.07);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--accent);
  font-style: italic;
}

/* SEO editorial */
.seo-editorial {
  background: var(--bg-alt);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  padding: 2.5rem;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  transition: var(--transition);
}
.seo-editorial:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }

.seo-ed-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.seo-ed-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.625rem;
  padding: 1.25rem;
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  transition: var(--transition);
}
.seo-ed-item:hover { border-color: rgba(92,122,78,0.2); box-shadow: var(--shadow-sm); }
.seo-ed-item.seo-ed-accent {
  background: var(--accent);
  border-color: var(--accent);
}
.seo-ed-item.seo-ed-accent .seo-ed-icon { color: rgba(255,255,255,0.9); }
.seo-ed-item.seo-ed-accent span { color: rgba(255,255,255,0.9); }

.seo-ed-icon { color: var(--accent); }
.seo-ed-item span { font-size: 0.82rem; font-weight: 600; color: var(--text); }

.seo-ed-statement {
  padding: 1.5rem;
  background: var(--text);
  border-radius: var(--radius-md);
}
.seo-ed-statement p {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1rem;
  color: rgba(247,245,242,0.85);
  line-height: 1.6;
}
.seo-ed-statement p em {
  color: var(--accent-light);
  font-style: italic;
}

/* ——————————————————
   SERVIÇOS
—————————————————— */
.section-servicos { padding: 6rem 0; background: var(--bg); }

.servico-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  margin-bottom: 5rem;
  padding-bottom: 5rem;
  border-bottom: 1px solid var(--border);
}
.servico-row:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.servico-row.reverse { direction: rtl; }
.servico-row.reverse > * { direction: ltr; }

.servico-tag { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-bottom: 0.875rem; }
.servico-title {
  font-size: clamp(1.7rem, 2.8vw, 2.3rem);
  font-weight: 700;
  line-height: 1.15;
  color: var(--text);
  margin-bottom: 1.25rem;
  letter-spacing: -0.025em;
}
.servico-desc { font-size: 1rem; color: var(--text-muted); line-height: 1.75; margin-bottom: 1.5rem; }
.servico-list { display: flex; flex-direction: column; gap: 0.6rem; }
.servico-list li {
  font-size: 0.875rem;
  color: var(--text-muted);
  padding-left: 1.25rem;
  position: relative;
  line-height: 1.5;
}
.servico-list li::before { content: '✦'; position: absolute; left: 0; color: var(--accent); font-size: 0.6rem; top: 0.22em; }

.servico-preco { margin-top: 1.5rem; font-size: 0.875rem; color: var(--text-muted); }
.servico-preco strong { font-size: 1.6rem; font-weight: 800; color: var(--text); }
.servico-preco span { font-size: 0.78rem; }

/* Laptop SVG premium */
.servico-device-wrap{ position:relative; padding:0.5rem; max-width:560px; margin:0 auto; }

.real-device-image-wrap{
  position:relative;
  width:100%;
  border-radius:28px;
  overflow:hidden;
  background:#111;
  box-shadow:
    0 30px 70px rgba(0,0,0,.18),
    0 10px 25px rgba(0,0,0,.08);
}

.real-device-image{
  width:100%;
  display:block;
  aspect-ratio:16/10;
  object-fit:cover;
}

.laptop-premium { max-width: 500px; margin: 0 auto; transition: var(--transition); }
.laptop-premium:hover { transform: translateY(-6px) rotate(0.3deg); }
.lp-screen {
  background: #1C1917;
  border-radius: 10px 10px 0 0;
  padding: 3px;
  border: 2.5px solid #2A2723;
  border-bottom: none;
  overflow: hidden;
}
.lp-svg { display: block; width: 100%; border-radius: 6px; }
.lp-chin {
  height: 14px;
  background: linear-gradient(180deg, #2A2723, #1C1917);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2.5px solid #2A2723;
  border-top: none;
}
.lp-chin-notch {
  width: 50px; height: 4px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
}
.lp-base {
  height: 10px;
  background: #181614;
  border-radius: 0 0 8px 8px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.3);
  position: relative;
}
.lp-base::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 50%;
  transform: translateX(-50%);
  width: 55%; height: 4px;
  background: rgba(0,0,0,0.3);
  border-radius: 0 0 8px 8px;
  filter: blur(4px);
}

.servico-badge {
  position: absolute;
  top: 1rem; right: -0.5rem;
  background: var(--accent);
  color: #fff;
  padding: 0.45rem 0.875rem;
  border-radius: 50px;
  font-size: 0.75rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  box-shadow: 0 4px 14px rgba(92,122,78,0.35);
  animation: servicoBadgeFloat 4s ease-in-out infinite;
}
@keyframes servicoBadgeFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(6px); }
}

/* Infrastructure SVG */
.infra-mockup { position: relative; max-width: 480px; margin: 0 auto; transition: var(--transition); }
.infra-mockup:hover { transform: translateY(-6px); }
.infra-svg { width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-xl); }
.infra-status {
  position: absolute;
  bottom: 1rem; left: 50%; transform: translateX(-50%);
  background: rgba(24,22,20,0.9);
  backdrop-filter: blur(8px);
  color: rgba(247,245,242,0.8);
  padding: 0.45rem 0.875rem;
  border-radius: 50px;
  font-size: 0.72rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  white-space: nowrap;
}
.infra-dot {
  width: 7px; height: 7px;
  background: #22c55e;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 6px #22c55e;
  animation: pulseDot 2s ease-in-out infinite;
}

/* SEO mockup */
.seo-mockup { position: relative; max-width: 480px; margin: 0 auto; transition: var(--transition); }
.seo-mockup:hover { transform: translateY(-6px); }
.seo-svg { width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.seo-badge {
  position: absolute;
  top: 1rem; right: 1rem;
  background: #fff;
  color: var(--accent);
  border: 1px solid rgba(92,122,78,0.2);
  padding: 0.45rem 0.875rem;
  border-radius: 50px;
  font-size: 0.72rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  box-shadow: var(--shadow-sm);
}

/* ——————————————————
   COMO AJUDAMOS
—————————————————— */
.section-como { padding: 6rem 0; background: var(--bg-alt); }
.como-header { margin-bottom: 3.5rem; }

.como-steps {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 4rem;
  flex-wrap: wrap;
}
.como-step {
  flex: 1;
  min-width: 190px;
  padding: 1.75rem;
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}
.como-step::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent);
  opacity: 0;
  transition: var(--transition);
}
.como-step:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.como-step:hover::before { opacity: 1; }

.step-number {
  font-size: 0.68rem;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.step-number::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.como-step h4 { font-size: 1rem; font-weight: 700; margin-bottom: 0.5rem; color: var(--text); }
.como-step p { font-size: 0.85rem; color: var(--text-muted); line-height: 1.65; }

.como-connector {
  color: var(--text-light);
  padding-top: 2.2rem;
  flex-shrink: 0;
}

.como-visual { position: relative; border-radius: var(--radius-xl); overflow: hidden; }
.como-img-wrap { position: relative; }
.como-img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: brightness(0.9) saturate(0.85);
  transition: var(--transition);
}
.como-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(24,22,20,0.75) 30%, rgba(24,22,20,0.1) 70%);
}
.como-overlay-card {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 2rem 2.5rem;
}
.coc-accent {
  width: 32px; height: 2px;
  background: var(--accent);
  margin-bottom: 1rem;
  border-radius: 1px;
}
.como-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.05rem;
  color: rgba(247,245,242,0.9);
  line-height: 1.65;
  margin-bottom: 0.875rem;
}
.como-author { display: flex; align-items: center; gap: 0.75rem; }
.como-author-avatar {
  width: 28px; height: 28px;
  background: linear-gradient(135deg, var(--accent), var(--accent-light));
  border-radius: 50%;
  flex-shrink: 0;
}
.como-quote-author { font-size: 0.78rem; color: var(--accent-light); font-weight: 500; }

/* ——————————————————
   DIAGNÓSTICO
—————————————————— */
.section-diagnostico { padding: 6rem 0; background: var(--bg-dark); }

.diagnostico-inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 4rem;
  align-items: center;
}

.diag-title {
  font-size: clamp(1.9rem, 3.2vw, 2.6rem);
  font-weight: 700;
  color: #F7F5F2;
  line-height: 1.15;
  margin-bottom: 1rem;
  letter-spacing: -0.02em;
}
.diag-sub { font-size: 1rem; color: rgba(247,245,242,0.55); line-height: 1.7; margin-bottom: 1.75rem; }

.diag-features { display: flex; flex-direction: column; gap: 0.5rem; }
.diag-feat {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--accent-light);
}
.diag-feat svg { flex-shrink: 0; }

/* Quiz */
.quiz-container {
  background: var(--bg-dark-alt);
  border-radius: var(--radius-xl);
  padding: 2rem;
  border: 1px solid var(--border-dark);
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(0,0,0,0.3);
}
.quiz-container::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0.5;
}

.quiz-step { display: none; }
.quiz-step.active { display: block; animation: fadeSlideUp 0.4s cubic-bezier(0.16,1,0.3,1); }
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.quiz-step-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-light);
  margin-bottom: 0.875rem;
}
.quiz-question {
  font-size: 1.05rem;
  font-weight: 600;
  color: #F7F5F2;
  margin-bottom: 1.5rem;
  line-height: 1.5;
}
.quiz-options { display: flex; flex-direction: column; gap: 0.625rem; }
.quiz-opt {
  padding: 0.875rem 1.125rem;
  background: rgba(255,255,255,0.04);
  color: rgba(247,245,242,0.75);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  font-weight: 500;
  text-align: left;
  transition: var(--transition);
  cursor: pointer;
  font-family: var(--font-body);
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.quiz-opt:hover {
  background: rgba(92,122,78,0.15);
  border-color: rgba(92,122,78,0.3);
  color: #F7F5F2;
  transform: translateX(4px);
}
.qo-icon { font-size: 1.1rem; flex-shrink: 0; }

.quiz-result { text-align: center; padding: 0.5rem 0; }
.quiz-result-icon { font-size: 2.5rem; margin-bottom: 0.875rem; }
.quiz-result h4 { font-size: 1.3rem; font-weight: 700; color: #F7F5F2; margin-bottom: 0.625rem; line-height: 1.3; }
.quiz-result p { color: rgba(247,245,242,0.6); font-size: 0.9rem; line-height: 1.65; }

.quiz-progress { margin-top: 1.5rem; height: 2px; background: rgba(255,255,255,0.07); border-radius: 1px; overflow: hidden; }
.quiz-progress-bar { height: 100%; background: var(--accent); border-radius: 1px; transition: width 0.5s cubic-bezier(0.4,0,0.2,1); }

/* ——————————————————
   DIFERENCIAIS
—————————————————— */
.section-diferenciais { padding: 6rem 0; background: var(--bg); }

.diferenciais-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.diferencial-card {
  padding: 1.75rem;
  background: var(--bg-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}
.diferencial-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(92,122,78,0.06), transparent);
  opacity: 0;
  transition: var(--transition);
}
.diferencial-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
  border-color: rgba(92,122,78,0.2);
}
.diferencial-card:hover::after { opacity: 1; }
.diferencial-card.dc-featured {
  background: linear-gradient(135deg, rgba(92,122,78,0.08), rgba(92,122,78,0.03));
  border-color: rgba(92,122,78,0.15);
}

.dc-icon {
  width: 46px; height: 46px;
  background: rgba(92,122,78,0.1);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  margin-bottom: 1.25rem;
  transition: var(--transition);
  position: relative;
  z-index: 1;
}
.diferencial-card:hover .dc-icon { background: rgba(92,122,78,0.15); transform: scale(1.08); }

.diferencial-card h4 { font-size: 0.975rem; font-weight: 700; color: var(--text); margin-bottom: 0.5rem; position: relative; z-index: 1; }
.diferencial-card p { font-size: 0.85rem; color: var(--text-muted); line-height: 1.65; position: relative; z-index: 1; }

/* ——————————————————
   SOBRE
—————————————————— */
.section-sobre { padding: 6rem 0; background: var(--bg-alt); }
.sobre-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.sobre-visual { position: relative; }
.sobre-img-wrap { position: relative; border-radius: var(--radius-xl); overflow: hidden; }
.sobre-img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: saturate(0.85) brightness(0.95);
  transition: var(--transition);
}
.sobre-img-wrap:hover .sobre-img { transform: scale(1.02); filter: saturate(0.9) brightness(1); }
.sobre-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(28,25,23,0.2), transparent 50%);
}

.sobre-tag {
  position: absolute;
  bottom: 1.25rem; left: 1.25rem;
  background: rgba(247,245,242,0.96);
  backdrop-filter: blur(10px);
  padding: 0.75rem 1.125rem;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  box-shadow: var(--shadow-md);
}
.sobre-tag-dot {
  width: 8px; height: 8px;
  background: var(--accent);
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(92,122,78,0.2);
  animation: pulseDot 2s ease-in-out infinite;
}
.sobre-tag strong { display: block; font-size: 0.875rem; color: var(--text); }
.sobre-tag span { font-size: 0.72rem; color: var(--text-muted); }

.sobre-award {
  position: absolute;
  top: 1.25rem; right: 1.25rem;
  background: var(--text);
  color: rgba(247,245,242,0.85);
  padding: 0.5rem 0.875rem;
  border-radius: 50px;
  font-size: 0.72rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.sobre-award svg { color: var(--accent-gold); }

.sobre-h2 { margin-bottom: 1.25rem; }
.sobre-lead { font-size: 1.1rem; font-weight: 500; color: var(--text); margin-bottom: 1rem; line-height: 1.65; }
.sobre-body { font-size: 0.95rem; color: var(--text-muted); line-height: 1.8; margin-bottom: 1.25rem; }

.sobre-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--text-muted);
  border-left: 3px solid var(--accent);
  padding: 0.75rem 0 0.75rem 1.25rem;
  margin: 1.5rem 0;
  line-height: 1.65;
  background: rgba(92,122,78,0.04);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.sobre-quote cite { font-style: normal; font-weight: 700; color: var(--accent); display: block; margin-top: 0.3rem; font-size: 0.82rem; }
.sobre-tagline { font-size: 0.9rem; font-weight: 600; color: var(--text); }

/* ——————————————————
   CONTATO
—————————————————— */
.section-contato { padding: 6rem 0; background: var(--bg-dark); }
.contato-inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 4rem;
  align-items: start;
}

.contato-title {
  font-size: clamp(2rem, 3.5vw, 2.8rem);
  font-weight: 700;
  color: #F7F5F2;
  line-height: 1.15;
  margin-bottom: 1rem;
  letter-spacing: -0.02em;
}
.contato-sub { font-size: 1rem; color: rgba(247,245,242,0.55); line-height: 1.7; margin-bottom: 2rem; }

.contato-direct { display: flex; flex-direction: column; gap: 0.75rem; margin-bottom: 2rem; }
.contact-link {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.875rem 1.125rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dark);
  background: rgba(255,255,255,0.03);
  transition: var(--transition);
}
.contact-link:hover { background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.18); }
.contact-link div { display: flex; flex-direction: column; gap: 0.1rem; }
.contact-link strong { font-size: 0.875rem; color: #F7F5F2; font-weight: 600; }
.contact-link span { font-size: 0.78rem; color: rgba(247,245,242,0.45); }
.whatsapp-link { color: #25D366; }
.whatsapp-link:hover { border-color: rgba(37,211,102,0.3); }
.email-link { color: rgba(247,245,242,0.6); }

.contato-trust {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.contato-trust span {
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(247,245,242,0.35);
}

/* Form */
.contato-form {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius-xl);
  padding: 2rem;
  transition: var(--transition);
}
.contato-form:hover { border-color: rgba(255,255,255,0.12); }

.form-header { margin-bottom: 1.5rem; }
.form-header h4 { font-size: 1.05rem; font-weight: 700; color: #F7F5F2; margin-bottom: 0.3rem; }
.form-header p { font-size: 0.8rem; color: rgba(247,245,242,0.4); }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { margin-bottom: 1rem; }
.form-group label {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  color: rgba(247,245,242,0.45);
  letter-spacing: 0.07em;
  text-transform: uppercase;
  margin-bottom: 0.4rem;
}
.form-group input,
.form-group textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-sm);
  color: #F7F5F2;
  font-family: var(--font-body);
  font-size: 0.875rem;
  transition: var(--transition);
  outline: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: rgba(247,245,242,0.2); }
.form-group input:focus,
.form-group textarea:focus {
  border-color: rgba(92,122,78,0.4);
  background: rgba(255,255,255,0.07);
  box-shadow: 0 0 0 3px rgba(92,122,78,0.08);
}
.form-group textarea { resize: vertical; min-height: 110px; }

.btn-form-submit {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  background: var(--accent);
  color: #fff;
  padding: 0.875rem;
  border-radius: var(--radius-sm);
  font-size: 0.925rem;
  font-weight: 600;
  font-family: var(--font-body);
  cursor: pointer;
  transition: var(--transition);
  border: none;
  margin-top: 0.5rem;
  position: relative;
  overflow: hidden;
}
.btn-form-submit::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.12);
  opacity: 0;
  transition: var(--transition);
}
.btn-form-submit:hover::after { opacity: 1; }
.btn-form-submit:hover { transform: translateY(-2px); box-shadow: 0 8px 25px rgba(92,122,78,0.4); }
.btn-form-submit > * { position: relative; z-index: 1; }

.form-status { margin-top: 0.75rem; font-size: 0.82rem; text-align: center; color: rgba(247,245,242,0.6); }

/* ——————————————————
   FOOTER — light premium
—————————————————— */
.footer { background: var(--bg-alt); border-top: 1px solid var(--border); padding: 3.5rem 0 2rem; }
.footer-inner {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 3rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 1.5rem;
}

.footer-logo { margin-bottom: 0.875rem; }
.footer-logo-img { height: 34px; width: auto; }

.footer-tagline { font-size: 0.84rem; color: var(--text-muted); line-height: 1.65; max-width: 280px; margin-bottom: 1.25rem; }

.footer-wa {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: #16a34a;
  transition: var(--transition);
}
.footer-wa:hover { opacity: 0.75; }

.footer-links { display: flex; gap: 3rem; justify-content: flex-end; }
.footer-col { display: flex; flex-direction: column; gap: 0.6rem; }
.footer-col h5 {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-light);
  margin-bottom: 0.25rem;
}
.footer-col a { font-size: 0.82rem; color: var(--text-muted); transition: var(--transition); }
.footer-col a:hover { color: var(--text); }

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.72rem;
  color: var(--text-light);
}

/* ——————————————————
   WHATSAPP FLOAT
—————————————————— */
.wa-float {
  position: fixed;
  bottom: 1.75rem; right: 1.75rem;
  width: 54px; height: 54px;
  background: #25D366;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999;
  box-shadow: 0 4px 20px rgba(37,211,102,0.4);
  transition: var(--transition);
}
.wa-float:hover { transform: translateY(-4px) scale(1.08); box-shadow: 0 10px 32px rgba(37,211,102,0.5); }
.wa-float:hover .wa-tooltip { opacity: 1; transform: translateX(0); pointer-events: auto; }

.wa-tooltip {
  position: absolute;
  right: calc(100% + 0.75rem);
  background: var(--text);
  color: var(--bg);
  padding: 0.4rem 0.875rem;
  border-radius: 50px;
  font-size: 0.78rem;
  font-weight: 600;
  white-space: nowrap;
  opacity: 0;
  transform: translateX(6px);
  transition: var(--transition);
  pointer-events: none;
}

/* ——————————————————
   SCROLL ANIMATIONS
—————————————————— */
.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s cubic-bezier(0.16,1,0.3,1), transform 0.7s cubic-bezier(0.16,1,0.3,1);
}
.fade-in.visible { opacity: 1; transform: translateY(0); }

/* Stagger delays for grid children */
.diferenciais-grid .diferencial-card:nth-child(1) { transition-delay: 0.0s; }
.diferenciais-grid .diferencial-card:nth-child(2) { transition-delay: 0.08s; }
.diferenciais-grid .diferencial-card:nth-child(3) { transition-delay: 0.16s; }
.diferenciais-grid .diferencial-card:nth-child(4) { transition-delay: 0.24s; }
.diferenciais-grid .diferencial-card:nth-child(5) { transition-delay: 0.32s; }
.diferenciais-grid .diferencial-card:nth-child(6) { transition-delay: 0.40s; }


/* ——————————————————
   RESPONSIVE
—————————————————— */
@media (max-width: 1024px) {
  .hero-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .hero-right { display: none; }
  .presenca-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .servico-row, .servico-row.reverse { grid-template-columns: 1fr; direction: ltr; gap: 2rem; }
  .sobre-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .contato-inner { grid-template-columns: 1fr; gap: 3rem; }
  .diagnostico-inner { grid-template-columns: 1fr; gap: 3rem; }
  .diferenciais-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { grid-template-columns: 1fr; gap: 2rem; }
  .footer-links { justify-content: flex-start; }
}

@media (max-width: 768px) {
  :root { --header-h: 64px; }

  .main-nav {
    display: none;
    position: absolute;
    top: var(--header-h);
    left: 0; right: 0;
    background: rgba(247,245,242,0.97);
    backdrop-filter: blur(20px);
    flex-direction: column;
    padding: 0.75rem 5% 1.25rem;
    gap: 0;
    border-bottom: 1px solid var(--border);
  }
  .main-nav.open { display: flex; }
  .main-nav a { padding: 0.875rem 0.5rem; border-radius: 0; border-bottom: 1px solid var(--border); }
  .main-nav a:last-child { border-bottom: none; }
  .main-nav a.nav-cta { margin-left: 0; margin-top: 0.75rem; border-bottom: none; text-align: center; border-radius: 50px; }
  .main-nav a::after { display: none; }
  .menu-toggle { display: flex; }

  .hero-headline { font-size: 2.4rem; }
  .hero-ctas { flex-direction: column; }
  .btn-primary, .btn-ghost { justify-content: center; }

  .proof-inner { flex-direction: column; align-items: flex-start; gap: 0.75rem; }
  .proof-items { gap: 0.5rem; }

  .como-steps { flex-direction: column; }
  .como-connector { display: none; }

  .diferenciais-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }

  .footer-bottom { flex-direction: column; gap: 0.5rem; text-align: center; }
  .footer-links { flex-wrap: wrap; gap: 2rem; }

}

@media (max-width: 480px) {
  section { --section-pad: 4rem; }
  .section-presenca, .section-servicos, .section-como,
  .section-diagnostico, .section-diferenciais,
  .section-sobre, .section-contato { padding: 4rem 0; }

  .como-img { height: 300px; }
  .sobre-img { height: 340px; }
  .servico-visual { display: none; }
  .dm-chart { height: 90px; }
}

