/* =============================================================
   PRESENÇA ONLINE — main.css
   Editável sem tocar no index.html.

   ÍNDICE
   00. Variáveis & Tokens
   01. Reset & Base
   02. Scrollbar
   03. Background animado
   04. Layout base
   05. Navbar & Logo SVG
   06. Botões
   07. Menu mobile
   08. Hero
   09. Section header
   10. Produtos + Preços
   11. Preview / Phone mockup
   12. Diferenciais
   13. Setores (carrossel)
   14. CTA Final
   15. Footer
   16. Keyframes & Scroll Reveal
   17. Responsive — Tablet (≤900px)
   18. Responsive — Mobile (≤480px)
   19. Reduced Motion
============================================================= */


/* ─────────────────────────────────────────────────────────────
   00. VARIÁVEIS & TOKENS
───────────────────────────────────────────────────────────── */
:root {
  --gold:        #FDEB9E;
  --teal-light:  #7AE2CF;
  --teal-mid:    #077A7D;
  --dark:        #06202B;
  --dark-2:      #081E29;
  --dark-3:      #0a2c3b;

  --gold-glow:   rgba(253,235,158,0.18);
  --teal-glow:   rgba(122,226,207,0.15);

  --text-main:   #F0F8F7;
  --text-sub:    rgba(240,248,247,0.60);
  --text-dim:    rgba(240,248,247,0.32);

  --wa:          #25D366;

  --border:      rgba(122,226,207,0.12);
  --border-gold: rgba(253,235,158,0.18);

  --font:        'Space Mono', monospace;
  --radius:      12px;
  --radius-lg:   20px;
  --transition:  0.3s cubic-bezier(0.4,0,0.2,1);
}


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

html {
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}

body {
  font-family:var(--font);
  background:var(--dark);
  color:var(--text-main);
  overflow-x:hidden;
  line-height:1.6;
  /* Prevent any horizontal overflow on mobile */
  width:100%;
  max-width:100vw;
}

::selection { background:var(--teal-mid); color:var(--gold); }


/* ─────────────────────────────────────────────────────────────
   02. SCROLLBAR
───────────────────────────────────────────────────────────── */
::-webkit-scrollbar       { width:4px; }
::-webkit-scrollbar-track { background:var(--dark); }
::-webkit-scrollbar-thumb { background:var(--teal-mid); border-radius:4px; }


/* ─────────────────────────────────────────────────────────────
   03. BACKGROUND ANIMADO
───────────────────────────────────────────────────────────── */
.bg-layer {
  position:fixed; inset:0; z-index:0;
  pointer-events:none; overflow:hidden;
}

.bg-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(122,226,207,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(122,226,207,0.04) 1px, transparent 1px);
  background-size:48px 48px;
}

.orb {
  position:absolute; border-radius:50%;
  filter:blur(80px);
  animation:orb-drift 18s ease-in-out infinite;
}
.orb-1 { width:480px; height:480px; background:radial-gradient(circle,rgba(7,122,125,.28) 0%,transparent 70%); top:-120px; right:-120px; animation-delay:0s; }
.orb-2 { width:360px; height:360px; background:radial-gradient(circle,rgba(122,226,207,.14) 0%,transparent 70%); bottom:15%; left:-80px; animation-delay:-6s; }
.orb-3 { width:280px; height:280px; background:radial-gradient(circle,rgba(253,235,158,.10) 0%,transparent 70%); top:45%; right:10%; animation-delay:-11s; }

.grain {
  position:absolute; inset:-50%; width:200%; height:200%;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.08'/%3E%3C/svg%3E");
  opacity:.5; animation:grain-move 0.8s steps(2) infinite;
}

.streak {
  position:absolute; width:1px;
  background:linear-gradient(to bottom,transparent,var(--teal-light),transparent);
  opacity:0; animation:streak-rise 8s linear infinite;
}
.streak:nth-child(1) { left:15%; height:180px; animation-delay:0s;    }
.streak:nth-child(2) { left:38%; height:120px; animation-delay:-2.5s; }
.streak:nth-child(3) { left:62%; height:200px; animation-delay:-5s;   }
.streak:nth-child(4) { left:82%; height:140px; animation-delay:-1.5s; }


/* ─────────────────────────────────────────────────────────────
   04. LAYOUT BASE
───────────────────────────────────────────────────────────── */
.site-wrapper { position:relative; z-index:1; }

.container {
  max-width:1140px;
  margin:0 auto;
  padding:0 24px;
  /* Safety net — never overflow on mobile */
  width:100%;
}

section { padding:100px 0; }


/* ─────────────────────────────────────────────────────────────
   05. NAVBAR & LOGO SVG
───────────────────────────────────────────────────────────── */
.navbar {
  position:fixed; top:0; left:0; right:0;
  z-index:100; padding:18px 0;
  transition:var(--transition);
}
.navbar.scrolled {
  background:rgba(6,32,43,0.95);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:14px 0;
}

.nav-inner { display:flex; align-items:center; justify-content:space-between; }

/* ── LOGO ── */
.nav-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }

.nav-logo-svg {
  flex-shrink:0;
  transition:transform 0.5s cubic-bezier(0.34,1.56,0.64,1);
}
.nav-logo:hover .nav-logo-svg { transform:scale(1.12); }

.nav-logo-text {
  font-size:14px; font-weight:700;
  color:var(--text-main); letter-spacing:0.04em; line-height:1.1;
}
.nav-logo-text span {
  display:block; font-size:10px; font-weight:400;
  color:var(--teal-light); letter-spacing:0.12em; text-transform:uppercase;
}

.nav-links { display:flex; gap:32px; list-style:none; }
.nav-links a {
  text-decoration:none; font-size:12px; letter-spacing:0.08em;
  text-transform:uppercase; color:var(--text-sub); transition:color var(--transition);
}
.nav-links a:hover { color:var(--gold); }

.nav-cta { display:flex; gap:12px; align-items:center; }

.hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:8px; border-radius:8px;
  background:none; border:none; flex-shrink:0;
}
.hamburger span {
  display:block; width:22px; height:2px;
  background:var(--text-main); border-radius:2px; transition:var(--transition);
}
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px);   }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0);               }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }


/* ─────────────────────────────────────────────────────────────
   06. BOTÕES
───────────────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 20px; border-radius:var(--radius);
  font-family:var(--font); font-size:12px; font-weight:700;
  letter-spacing:0.06em; text-transform:uppercase;
  text-decoration:none; cursor:pointer; border:none;
  transition:var(--transition);
  position:relative; overflow:hidden; white-space:nowrap; min-height:44px;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);
  opacity:0; transition:opacity var(--transition);
}
.btn:hover::after { opacity:1; }

.btn-primary { background:linear-gradient(135deg,var(--teal-mid),#0a9499); color:var(--dark); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(7,122,125,.4); }

.btn-ghost { background:transparent; color:var(--text-main); border:1px solid var(--border); }
.btn-ghost:hover { border-color:var(--teal-light); color:var(--teal-light); transform:translateY(-1px); }

.btn-wa { background:var(--wa); color:#fff; }
.btn-wa:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(37,211,102,.35); }

.btn-lg { padding:16px 28px; font-size:13px; min-height:52px; border-radius:14px; }


/* ─────────────────────────────────────────────────────────────
   07. MENU MOBILE
───────────────────────────────────────────────────────────── */
.mobile-menu {
  display:none; position:fixed; inset:0; z-index:99;
  background:rgba(6,32,43,.97); backdrop-filter:blur(24px);
  flex-direction:column; align-items:center; justify-content:center;
  gap:28px; padding:40px 24px;
}
.mobile-menu.open { display:flex; animation:menu-in 0.3s ease; }

.mobile-menu a {
  text-decoration:none; font-size:22px; font-weight:700;
  color:var(--text-main); letter-spacing:0.06em; text-transform:uppercase;
  transition:color var(--transition); padding:8px 0;
}
.mobile-menu a:hover { color:var(--gold); }

.mobile-menu-actions { display:flex; flex-direction:column; gap:12px; width:100%; margin-top:12px; }
.mobile-menu-actions .btn { width:100%; justify-content:center; font-size:14px; padding:16px; }


/* ─────────────────────────────────────────────────────────────
   08. HERO
   — Desktop: 2 colunas (texto | phone)
   — Mobile:  1 coluna, texto centralizado, phone abaixo reduzido
───────────────────────────────────────────────────────────── */
.hero {
  min-height:100svh; display:flex; align-items:center;
  padding-top:80px; position:relative;
  /* Extra bottom padding so phone mockup has breathing room */
  padding-bottom:40px;
}

.hero-inner {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}

/* Badge */
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px; border-radius:999px;
  border:1px solid var(--border-gold); background:rgba(253,235,158,.06);
  font-size:11px; color:var(--gold); letter-spacing:0.1em; text-transform:uppercase;
  margin-bottom:24px; animation:fade-up 0.6s ease both;
}
.hero-badge-dot {
  width:6px; height:6px; border-radius:50%; background:var(--gold);
  animation:pulse-dot 2s ease infinite;
}

/* ── H1: tamanho fluido, nunca quebra feio ── */
.hero h1 {
  /* fluid: 32px no menor, sobe até 58px */
  font-size:clamp(32px, 4.5vw, 58px);
  font-weight:700;
  line-height:1.1;
  letter-spacing:-0.02em;
  margin-bottom:20px;
  animation:fade-up 0.6s 0.1s ease both;
  /* Prevent overflow on narrow screens */
  word-break:break-word;
  overflow-wrap:break-word;
}

.hero h1 .line-gold {
  /* inline — NÃO usa display:block para não quebrar linha de forma estranha */
  background:linear-gradient(90deg, var(--gold), var(--teal-light));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  /* Keeps it inline so the wrapping is natural */
  display:inline;
}

.hero p {
  font-size:15px; line-height:1.8; color:var(--text-sub);
  max-width:420px; margin-bottom:32px;
  animation:fade-up 0.6s 0.2s ease both;
}

.hero-actions {
  display:flex; gap:12px; flex-wrap:wrap;
  animation:fade-up 0.6s 0.3s ease both;
}

/* ── Visual side ── */
.hero-visual {
  position:relative; display:flex; align-items:center; justify-content:center;
  animation:fade-in 0.8s 0.3s ease both;
}

/* Phone frame */
.phone-frame {
  width:220px; height:440px; border-radius:36px;
  border:2px solid var(--border); background:rgba(6,32,43,.8);
  backdrop-filter:blur(20px); overflow:hidden; position:relative;
  box-shadow:
    0 0 0 1px rgba(122,226,207,.08),
    0 40px 80px rgba(0,0,0,.6),
    0 0 60px rgba(7,122,125,.2);
  animation:phone-float 5s ease-in-out infinite;
}
.phone-notch { width:70px; height:20px; background:var(--dark); border-radius:0 0 10px 10px; margin:0 auto 10px; }
.phone-content { padding:6px 12px; }
.phone-avatar {
  width:52px; height:52px; border-radius:50%;
  background:conic-gradient(var(--gold),var(--teal-light),var(--teal-mid),var(--gold));
  margin:0 auto 6px; position:relative;
  animation:ring-spin 4s linear infinite;
}
.phone-avatar::after { content:''; position:absolute; inset:3px; border-radius:50%; background:var(--dark-3); }

.phone-line { height:7px; border-radius:4px; background:rgba(122,226,207,.12); margin-bottom:6px; }
.phone-line.w-full { width:100%; }
.phone-line.w-70   { width:70%; }
.phone-line.w-50   { width:50%; }

.phone-btn-mock { height:32px; border-radius:9px; margin-bottom:5px; display:flex; align-items:center; justify-content:center; }
.phone-btn-mock.wa   { background:rgba(37,211,102,.18); border:1px solid rgba(37,211,102,.25); }
.phone-btn-mock.teal { background:rgba(7,122,125,.25);  border:1px solid rgba(7,122,125,.30);  }
.phone-btn-mock.gold { background:rgba(253,235,158,.08); border:1px solid rgba(253,235,158,.15); }
.phone-btn-text { font-family:var(--font); font-size:7px; color:var(--text-sub); letter-spacing:0.08em; }

/* Floating tags */
.hero-tag {
  position:absolute; padding:7px 12px;
  background:rgba(6,32,43,.92); border:1px solid var(--border); border-radius:10px;
  font-size:11px; color:var(--text-sub); backdrop-filter:blur(12px);
  white-space:nowrap; display:flex; align-items:center; gap:6px; font-family:var(--font);
}
.hero-tag i { width:12px; height:12px; color:var(--teal-light); }
.hero-tag-1 { top:5%;   right:-18%; animation:tag-float-1 4s ease-in-out infinite; }
.hero-tag-2 { bottom:15%; right:-22%; animation:tag-float-2 5s ease-in-out infinite; }
.hero-tag-3 { top:38%; left:-24%;  animation:tag-float-1 6s ease-in-out infinite reverse; }


/* ─────────────────────────────────────────────────────────────
   09. SECTION HEADER
───────────────────────────────────────────────────────────── */
.section-header { text-align:center; margin-bottom:56px; }

.section-tag {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 16px; border-radius:999px;
  border:1px solid var(--border); background:rgba(122,226,207,.04);
  font-size:11px; color:var(--teal-light); letter-spacing:0.12em;
  text-transform:uppercase; margin-bottom:20px;
}

.section-header h2 {
  font-size:clamp(26px,3.8vw,46px); font-weight:700;
  line-height:1.15; letter-spacing:-0.02em; margin-bottom:14px;
}
.section-header h2 em,
.preview-text h2 em {
  font-style:normal;
  background:linear-gradient(90deg,var(--gold),var(--teal-light));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.section-header p { font-size:15px; line-height:1.75; color:var(--text-sub); max-width:500px; margin:0 auto; }


/* ─────────────────────────────────────────────────────────────
   10. PRODUTOS + PREÇOS
───────────────────────────────────────────────────────────── */
.produtos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:start; }

.produto-card {
  border-radius:var(--radius-lg); border:1px solid var(--border);
  background:rgba(8,30,41,.6); padding:32px 26px;
  position:relative; overflow:hidden;
  transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition);
  backdrop-filter:blur(10px);
}
.produto-card:hover {
  border-color:rgba(122,226,207,.3);
  box-shadow:0 32px 64px rgba(0,0,0,.4),0 0 40px rgba(7,122,125,.15);
}

.produto-card.featured {
  border-color:rgba(253,235,158,.3);
  background:rgba(8,30,41,.8);
  transform:scale(1.03);
}
.produto-card.featured:hover {
  border-color:rgba(253,235,158,.5);
  box-shadow:0 32px 64px rgba(0,0,0,.5),0 0 60px rgba(253,235,158,.12);
}
.produto-card.featured::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

.featured-badge {
  position:absolute; top:18px; right:18px;
  padding:3px 10px; background:rgba(253,235,158,.10);
  border:1px solid rgba(253,235,158,.3); border-radius:999px;
  font-size:10px; color:var(--gold); letter-spacing:0.1em; text-transform:uppercase;
}

.produto-icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
.produto-icon i { width:24px; height:24px; }
.icon-teal    { background:rgba(7,122,125,.2);  border:1px solid rgba(7,122,125,.4);  color:var(--teal-light); }
.icon-gold    { background:rgba(253,235,158,.1); border:1px solid rgba(253,235,158,.3); color:var(--gold); }
.icon-premium { background:linear-gradient(135deg,rgba(7,122,125,.2),rgba(253,235,158,.1)); border:1px solid rgba(122,226,207,.25); color:var(--teal-light); }

.produto-card h3 { font-size:19px; font-weight:700; margin-bottom:4px; letter-spacing:-0.01em; }

.produto-sub {
  font-size:10px; color:var(--teal-light);
  letter-spacing:0.1em; text-transform:uppercase; margin-bottom:14px;
}

/* ── PREÇO ── */
.produto-preco {
  display:flex; align-items:baseline; gap:10px; flex-wrap:wrap;
  margin-bottom:18px; padding:12px 14px;
  border-radius:10px;
  background:rgba(122,226,207,.05);
  border:1px solid rgba(122,226,207,.12);
}
.featured-preco {
  background:rgba(253,235,158,.07);
  border-color:rgba(253,235,158,.2);
}

.preco-valor { font-size:13px; color:var(--text-sub); }
.preco-valor strong {
  font-size:21px; font-weight:700;
  color:var(--teal-light); letter-spacing:-0.02em;
}
.produto-card.featured .preco-valor strong { color:var(--gold); }

.preco-parcela {
  font-size:10px; color:var(--text-dim); letter-spacing:0.06em;
  text-transform:uppercase; padding:3px 8px; border-radius:6px;
  border:1px solid var(--border); white-space:nowrap;
}

.produto-desc { font-size:13px; line-height:1.75; color:var(--text-sub); margin-bottom:24px; }

.produto-features { list-style:none; display:flex; flex-direction:column; gap:9px; margin-bottom:28px; }
.produto-features li { display:flex; align-items:flex-start; gap:10px; font-size:13px; color:var(--text-sub); line-height:1.5; }
.check-icon { width:15px; height:15px; flex-shrink:0; color:var(--teal-light); margin-top:2px; }
.produto-card.featured .check-icon { color:var(--gold); }

.produto-cta {
  display:flex; align-items:center; gap:8px;
  font-size:11px; font-weight:700; color:var(--text-sub);
  text-transform:uppercase; letter-spacing:0.08em; text-decoration:none;
  transition:var(--transition); padding:12px 0; border-top:1px solid var(--border);
}
.produto-cta i { width:15px; height:15px; transition:transform var(--transition); }
.produto-cta:hover { color:var(--teal-light); }
.produto-cta:hover i { transform:translateX(4px); }
.produto-card.featured .produto-cta:hover { color:var(--gold); }


/* ─────────────────────────────────────────────────────────────
   11. PREVIEW / PHONE MOCKUP
───────────────────────────────────────────────────────────── */
.preview-section {
  background:rgba(8,30,41,.5);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.preview-inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }

.preview-text h2 { font-size:clamp(26px,3.2vw,42px); font-weight:700; line-height:1.15; letter-spacing:-0.02em; margin-bottom:18px; }
.preview-text p  { font-size:14px; line-height:1.8; color:var(--text-sub); margin-bottom:28px; }

.feature-list { display:flex; flex-direction:column; gap:14px; margin-bottom:36px; }
.feature-item { display:flex; gap:14px; align-items:flex-start; }

.feature-icon-wrap {
  width:38px; height:38px; border-radius:10px;
  background:rgba(7,122,125,.15); border:1px solid rgba(7,122,125,.3);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.feature-icon-wrap i { width:17px; height:17px; color:var(--teal-light); }

.feature-item-text h4 { font-size:13px; font-weight:700; color:var(--text-main); margin-bottom:3px; }
.feature-item-text p  { font-size:12px; color:var(--text-sub); line-height:1.6; margin:0; }

.preview-visual { position:relative; display:flex; justify-content:center; }
.phones-group { position:relative; height:480px; width:280px; }

.phone-mock {
  position:absolute; width:210px; height:400px; border-radius:28px;
  border:1.5px solid var(--border); background:var(--dark-2); overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.5);
}
.phone-mock.back  { top:40px; left:-20px; transform:rotate(-8deg); opacity:.6; filter:blur(1px); }
.phone-mock.front { top:0; right:-20px; transform:rotate(4deg); animation:phone-float 6s ease-in-out infinite; animation-delay:-2s; }

.mock-notch { width:56px; height:16px; background:var(--dark); border-radius:0 0 9px 9px; margin:0 auto 8px; }
.mock-header { padding:12px 10px 6px; background:rgba(7,122,125,.15); border-bottom:1px solid var(--border); text-align:center; }
.mock-avatar-wrap { width:44px; height:44px; margin:0 auto 5px; border-radius:50%; padding:2px; background:conic-gradient(var(--gold),var(--teal-light),var(--gold)); animation:ring-spin 4s linear infinite; }
.mock-avatar-inner { width:100%; height:100%; background:var(--dark-3); border-radius:50%; }
.mock-name { width:70px; height:6px; background:rgba(240,248,247,.25); border-radius:4px; margin:0 auto 4px; }
.mock-sub  { width:50px; height:5px; background:rgba(240,248,247,.12); border-radius:4px; margin:0 auto; }
.mock-body { padding:9px; display:flex; flex-direction:column; gap:5px; }
.mock-link-row { height:28px; border-radius:7px; background:rgba(122,226,207,.08); border:1px solid var(--border); }
.mock-link-row.wa { background:rgba(37,211,102,.15); border-color:rgba(37,211,102,.2); }


/* ─────────────────────────────────────────────────────────────
   12. DIFERENCIAIS
───────────────────────────────────────────────────────────── */
.diff-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }

.diff-card {
  padding:26px 22px; border-radius:var(--radius);
  border:1px solid var(--border); background:rgba(8,30,41,.4);
  transition:var(--transition); backdrop-filter:blur(8px);
}
.diff-card:hover { border-color:rgba(122,226,207,.25); transform:translateY(-4px); background:rgba(8,30,41,.7); }

.diff-icon { width:42px; height:42px; border-radius:11px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; background:rgba(7,122,125,.15); border:1px solid rgba(7,122,125,.25); }
.diff-icon i { width:19px; height:19px; color:var(--teal-light); }
.diff-card:nth-child(2n) .diff-icon { background:rgba(253,235,158,.08); border-color:rgba(253,235,158,.2); }
.diff-card:nth-child(2n) .diff-icon i { color:var(--gold); }
.diff-card h3 { font-size:14px; font-weight:700; margin-bottom:7px; color:var(--text-main); }
.diff-card p  { font-size:13px; line-height:1.65; color:var(--text-sub); }


/* ─────────────────────────────────────────────────────────────
   13. SETORES
───────────────────────────────────────────────────────────── */
.setores {
  padding:80px 0; overflow:hidden;
  background:rgba(8,30,41,.5);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.setores .section-header { margin-bottom:44px; }

.setor-track-wrapper { overflow:hidden; position:relative; margin-bottom:14px; }
.setor-track-wrapper::before,
.setor-track-wrapper::after {
  content:''; position:absolute; top:0; bottom:0; width:60px; z-index:2; pointer-events:none;
}
.setor-track-wrapper::before { left:0;  background:linear-gradient(to right,var(--dark),transparent); }
.setor-track-wrapper::after  { right:0; background:linear-gradient(to left, var(--dark),transparent); }

.setor-track { display:flex; gap:10px; width:max-content; animation:track-scroll 28s linear infinite; }
.setor-track-2 { animation-direction:reverse; animation-duration:34s; }

.setor-pill {
  display:flex; align-items:center; gap:8px;
  padding:9px 18px; border-radius:999px;
  border:1px solid var(--border); background:rgba(8,30,41,.6);
  font-size:13px; color:var(--text-sub); white-space:nowrap; flex-shrink:0;
}
.setor-pill i { width:13px; height:13px; color:var(--teal-light); }


/* ─────────────────────────────────────────────────────────────
   14. CTA FINAL
───────────────────────────────────────────────────────────── */
.cta-section { padding:120px 0; position:relative; text-align:center; }

.cta-glow {
  position:absolute; width:600px; height:400px;
  left:50%; top:50%; transform:translate(-50%,-50%);
  background:radial-gradient(ellipse,rgba(7,122,125,.15) 0%,transparent 70%);
  pointer-events:none;
}

.cta-box {
  max-width:640px; margin:0 auto; padding:56px 48px;
  border-radius:24px; border:1px solid rgba(253,235,158,.2);
  background:rgba(8,30,41,.7); backdrop-filter:blur(20px);
  position:relative; overflow:hidden;
}
.cta-box::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

.cta-box h2 { font-size:clamp(24px,3.5vw,38px); font-weight:700; line-height:1.2; letter-spacing:-0.02em; margin-bottom:14px; }
.cta-box h2 em { font-style:normal; background:linear-gradient(90deg,var(--gold),var(--teal-light)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.cta-box p { font-size:15px; line-height:1.75; color:var(--text-sub); margin-bottom:32px; }

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

.cta-contacts {
  display:flex; justify-content:center; gap:24px; flex-wrap:wrap;
  padding-top:20px; border-top:1px solid var(--border);
}
.cta-contact-item { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-sub); text-decoration:none; transition:color var(--transition); }
.cta-contact-item i { width:15px; height:15px; color:var(--teal-light); }
.cta-contact-item:hover { color:var(--text-main); }


/* ─────────────────────────────────────────────────────────────
   15. FOOTER
───────────────────────────────────────────────────────────── */
footer { border-top:1px solid var(--border); padding:40px 0; }

.footer-inner { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer-copy { font-size:12px; color:var(--text-dim); line-height:1.6; }
.footer-links { display:flex; gap:18px; }
.footer-links a { font-size:11px; color:var(--text-dim); text-decoration:none; letter-spacing:0.06em; text-transform:uppercase; transition:color var(--transition); }
.footer-links a:hover { color:var(--teal-light); }
.footer-address { font-size:11px; color:var(--text-dim); display:flex; align-items:center; gap:6px; }
.footer-address i { width:11px; height:11px; }


/* ─────────────────────────────────────────────────────────────
   16. KEYFRAMES & SCROLL REVEAL
───────────────────────────────────────────────────────────── */
@keyframes fade-up  { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes fade-in  { from{opacity:0} to{opacity:1} }
@keyframes orb-drift {
  0%,100%{transform:translate(0,0) scale(1)}
  33%    {transform:translate(40px,-30px) scale(1.08)}
  66%    {transform:translate(-20px,40px) scale(0.95)}
}
@keyframes grain-move {
  0%  {transform:translate(0,0)}   25%{transform:translate(-2%,-3%)}
  50% {transform:translate(3%,2%)} 75%{transform:translate(-1%,4%)}
  100%{transform:translate(2%,-1%)}
}
@keyframes streak-rise {
  0%  {opacity:0;transform:translateY(100vh)} 10%{opacity:.4}
  90% {opacity:.2} 100%{opacity:0;transform:translateY(-200px)}
}
@keyframes phone-float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }
@keyframes ring-spin   { to{transform:rotate(360deg)} }
@keyframes tag-float-1 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-7px)} }
@keyframes tag-float-2 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(7px)}  }
@keyframes track-scroll{ from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes menu-in  { from{opacity:0;transform:scale(0.97)} to{opacity:1;transform:scale(1)} }
@keyframes pulse-dot{ 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.5)} }

.reveal { opacity:0; transform:translateY(28px); transition:opacity 0.6s ease,transform 0.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; }


/* ─────────────────────────────────────────────────────────────
   17. RESPONSIVE — TABLET (≤900px)
───────────────────────────────────────────────────────────── */
@media (max-width:900px) {
  .nav-links,.nav-cta { display:none; }
  .hamburger { display:flex; }

  .hero-inner {
    grid-template-columns:1fr;
    gap:40px;
    text-align:center;
  }
  .hero p      { margin:0 auto 28px; max-width:100%; }
  .hero-actions{ justify-content:center; }
  .hero-visual { order:-1; }
  /* Hide the outer floating tags — keep phone visible */
  .hero-tag-1,.hero-tag-2,.hero-tag-3 { display:none; }

  .phone-frame { width:180px; height:360px; }

  .produtos-grid { grid-template-columns:1fr; gap:16px; }
  .produto-card.featured { transform:none; }
  .produto-card.featured:hover { transform:translateY(-4px); }

  .preview-inner  { grid-template-columns:1fr; gap:44px; }
  .preview-visual { order:-1; }

  .diff-grid { grid-template-columns:1fr 1fr; }
  .cta-box   { padding:40px 28px; }
}


/* ─────────────────────────────────────────────────────────────
   18. RESPONSIVE — MOBILE (≤480px)
   Tudo pensado para caber na mão e ser bonito.
───────────────────────────────────────────────────────────── */
@media (max-width:480px) {
  /* Base */
  .container { padding:0 18px; }
  section { padding:64px 0; }

  /* Navbar */
  .navbar { padding:14px 0; }

  /* Hero */
  .hero {
    padding-top:72px;
    padding-bottom:32px;
    min-height:auto;
  }
  .hero-inner { gap:32px; }

  .hero h1 {
    font-size:clamp(28px, 8vw, 38px);
    line-height:1.12;
    margin-bottom:16px;
  }
  .hero p {
    font-size:14px;
    line-height:1.75;
    margin-bottom:24px;
  }
  .hero-actions {
    flex-direction:column;
    align-items:stretch;
    gap:10px;
  }
  .hero-actions .btn {
    width:100%;
    justify-content:center;
  }

  /* Phone — menor e centralizado */
  .hero-visual {
    /* Let it take natural width without overflowing */
    width:100%;
    overflow:hidden;
  }
  .phone-frame {
    width:160px;
    height:320px;
    border-radius:28px;
  }
  .phone-avatar { width:44px; height:44px; }
  .phone-btn-mock { height:26px; }

  /* Section headers */
  .section-header { margin-bottom:36px; }
  .section-header h2 { font-size:clamp(22px,7vw,32px); }
  .section-header p  { font-size:14px; }

  /* Produtos */
  .produto-card { padding:24px 20px; }
  .produto-card h3 { font-size:17px; }
  .produto-desc { font-size:13px; }
  .produto-preco { flex-direction:column; gap:6px; align-items:flex-start; }
  .preco-valor strong { font-size:19px; }

  /* Preview phones — hidden on very small, show only text */
  .preview-visual { display:none; }
  .preview-inner  { grid-template-columns:1fr; gap:0; }

  /* Diferenciais */
  .diff-grid { grid-template-columns:1fr; gap:12px; }
  .diff-card { padding:20px 18px; }

  /* CTA */
  .cta-section { padding:80px 0; }
  .cta-box { padding:32px 20px; }
  .cta-box h2 { font-size:clamp(22px,7vw,30px); }
  .cta-actions { flex-direction:column; align-items:stretch; }
  .cta-actions .btn { width:100%; justify-content:center; }
  .cta-contacts { flex-direction:column; align-items:center; gap:14px; }

  /* Footer */
  .footer-inner { flex-direction:column; gap:20px; align-items:flex-start; }
  .footer-links { flex-wrap:wrap; gap:12px; }

  /* Phones-group (preview section) */
  .phones-group { height:320px; width:220px; }
  .phone-mock   { width:160px; height:300px; }
}


/* ─────────────────────────────────────────────────────────────
   19. REDUCED MOTION
───────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation:none !important; transition:none !important; }
  .reveal { opacity:1; transform:none; }
}
