/* ============================================================
   VAREJO SUPERMERCADISTA — Global Design System
   Prof. Fred Gorgulho | varejosupermercadista.com.br
   ============================================================ */

/* Fontes carregadas via <link> no HTML (preconnect + stylesheet) */
/* ---- TOKENS ---- */
:root {
  --black:       #09090b;
  --dark-1:      #111113;
  --dark-2:      #18181c;
  --dark-3:      #222226;
  --dark-4:      #2e2e34;
  --muted-1:     #4a4a54;
  --muted-2:     #7a7a88;
  --muted-3:     #a8a0a0;
  --white:       #f5f0eb;
  --white-dim:   #c8c0b8;
  --orange:      #d4af37;
  --orange-light:#e8cb5a;
  --orange-dark: #a88a1a;
  --orange-glow: rgba(212,175,55,0.18);
  --orange-thin: rgba(212,175,55,0.08);
  /* cores do anel laser dos cards — um pouco mais amarelas que o dourado base */
  --laser-dark:  #c0a022;
  --laser-mid:   #e6c635;
  --laser-light: #f5db4d;
  --laser-tip:   #fff3ad;
  --glass-bg:    rgba(255,255,255,0.04);
  --glass-bg-h:  rgba(255,255,255,0.07);
  --glass-border:rgba(255,255,255,0.08);
  --glass-border-o:rgba(212,175,55,0.25);
  --shadow-card: 0 4px 32px rgba(0,0,0,0.5);
  --shadow-glow: 0 0 40px rgba(212,175,55,0.15);
  --radius-sm:   6px;
  --radius-md:   12px;
  --radius-lg:   20px;
  --radius-xl:   32px;
  --font-display:'Fraunces', Georgia, serif;
  --font-body:   'Plus Jakarta Sans', system-ui, sans-serif;
  --transition:  cubic-bezier(0.25,0.46,0.45,0.94);
  --transition-bounce: cubic-bezier(0.34,1.56,0.64,1);
}

/* ---- RESET ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
  background: var(--black);
  color: var(--white);
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
ul { list-style: none; }
input, textarea, select { font-family: inherit; }

/* ---- TYPOGRAPHY ---- */
h1, h2, h3, h4, h5 {
  font-family: var(--font-display);
  line-height: 1.15;
  letter-spacing: -0.02em;
  font-weight: 700;
}
h1 { font-size: clamp(2.4rem, 6vw, 5.5rem); }
h2 { font-size: clamp(2rem, 4.5vw, 3.6rem); }
h3 { font-size: clamp(1.4rem, 3vw, 2.2rem); }
h4 { font-size: clamp(1.1rem, 2vw, 1.5rem); }
p  { color: var(--muted-3); font-size: 1.05rem; }

.text-orange { color: var(--orange); }
.text-dim    { color: var(--muted-2); }
.text-center { text-align: center; }
.italic      { font-style: italic; }

/* ---- LAYOUT ---- */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(1.2rem, 5vw, 3rem);
}
.container-wide {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 clamp(1.2rem, 4vw, 4rem);
}
section { padding: clamp(5rem,10vw,9rem) 0; }
.section-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 1.2rem;
}
.section-tag::before,
.section-tag::after {
  content: '';
  display: block;
  width: 24px;
  height: 2px;
  background: var(--orange);
  border-radius: 2px;
}
.section-title {
  margin-bottom: 1rem;
  max-width: 720px;
}
.section-sub {
  max-width: 620px;
  margin-bottom: 3rem;
  font-size: 1.1rem;
}

/* ---- REGRA GLOBAL: chamadas e tópicos centralizados em todas as páginas ---- */
.section-tag { display: flex; justify-content: center; }
.breadcrumb { justify-content: center; }
.section-title,
.section-tag + h1,
.section-tag + h2,
.section-tag + h3 {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.section-sub,
.section-tag + h1 + p,
.section-tag + h2 + p,
.section-tag + h3 + p,
.section-title + p {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* ---- HEADER / NAV ---- */
#header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 1.32rem 0;
  transition: background 0.4s var(--transition), padding 0.4s var(--transition), box-shadow 0.4s;
}
#header.scrolled {
  background: rgba(9,9,11,0.82);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  padding: 0.84rem 0;
  box-shadow: 0 1px 0 var(--glass-border), 0 8px 32px rgba(0,0,0,0.4);
}
.nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}
.nav-logo {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}
.nav-logo .logo-main {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--white);
}
.nav-logo .logo-main span { color: var(--orange); }
.nav-logo .logo-sub {
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted-2);
}
.nav-links {
  display: flex;
  align-items: center;
  gap: 2rem;
}
.nav-links a {
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--muted-3);
  letter-spacing: 0.02em;
  transition: color 0.2s;
  position: relative;
}
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0;
  width: 0; height: 1.5px;
  background: var(--orange);
  transition: width 0.3s var(--transition);
}
.nav-links a:hover, .nav-links a.active { color: var(--white); }
.nav-links a:hover::after, .nav-links a.active::after { width: 100%; }
.nav-cta {
  padding: 0.55rem 1.4rem;
  background: var(--orange);
  color: var(--black) !important;
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  border-radius: var(--radius-sm);
  transition: background 0.2s, transform 0.2s var(--transition-bounce) !important;
  white-space: nowrap;
}
.nav-cta::after { display: none !important; }
.nav-cta:hover { background: var(--orange-light) !important; transform: translateY(-1px); }

/* hamburger */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  width: 28px;
  padding: 2px;
  z-index: 1001;
}
.hamburger span {
  display: block;
  height: 2px;
  background: var(--white);
  border-radius: 2px;
  transition: all 0.3s var(--transition);
  transform-origin: center;
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* mobile nav */
.mobile-nav {
  position: fixed;
  inset: 0;
  z-index: 999;
  background: rgba(9,9,11,0.97);
  backdrop-filter: blur(16px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s var(--transition);
}
.mobile-nav.open { opacity: 1; pointer-events: all; }
.mobile-nav a {
  font-family: var(--font-display);
  font-size: clamp(1.8rem,6vw,3rem);
  font-weight: 700;
  color: var(--white-dim);
  transition: color 0.2s;
}
.mobile-nav a:hover { color: var(--orange); }
.mobile-nav .m-cta {
  margin-top: 1rem;
  padding: 0.8rem 2.5rem;
  background: var(--orange);
  color: var(--black);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: var(--radius-sm);
}

/* ---- BUTTONS ---- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.85rem 2rem;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  border-radius: var(--radius-sm);
  transition: all 0.25s var(--transition);
  cursor: pointer;
}
.btn-primary {
  background: var(--orange);
  color: var(--black);
  border: 2px solid var(--orange);
}
.btn-primary:hover {
  background: var(--orange-light);
  border-color: var(--orange-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(232,116,32,0.35);
}
.btn-outline {
  background: transparent;
  color: var(--white);
  border: 2px solid var(--glass-border);
}
.btn-outline:hover {
  border-color: var(--orange);
  color: var(--orange);
  transform: translateY(-2px);
}
.btn-ghost {
  background: transparent;
  color: var(--orange);
  border: 2px solid transparent;
  padding-left: 0;
  padding-right: 0;
}
.btn-ghost:hover { gap: 1rem; }
.btn svg { flex-shrink: 0; transition: transform 0.2s; }
.btn:hover svg { transform: translateX(3px); }

/* ---- CARDS ---- */
.card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 2.2rem;
  transition: background 0.3s, border-color 0.3s, transform 0.3s var(--transition);
}
.card:hover {
  background: var(--glass-bg-h);
  border-color: var(--glass-border-o);
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
}
.card-icon {
  width: 52px; height: 52px;
  background: var(--orange-thin);
  border: 1px solid var(--glass-border-o);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.4rem;
  color: var(--orange);
  transition: background 0.3s, box-shadow 0.3s;
}
.card:hover .card-icon {
  background: var(--orange-glow);
  box-shadow: 0 0 20px rgba(232,116,32,0.2);
}
.card h4 { color: var(--white); margin-bottom: 0.6rem; font-size: 1.2rem; }

/* ---- DIVIDER ---- */
.divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--glass-border), transparent);
}
.divider-orange {
  background: linear-gradient(90deg, transparent, rgba(232,116,32,0.4), transparent);
}

/* ---- GRAIN OVERLAY ---- */
.grain::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  opacity: 0.5;
  z-index: 1;
}

/* ---- NUMBER STATS ---- */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 2px;
}
.stat-item {
  padding: 2.5rem 2rem;
  background: var(--dark-2);
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: background 0.3s;
}
.stat-item::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 100%; height: 2px;
  background: linear-gradient(90deg, transparent, var(--orange), transparent);
  transform: scaleX(0);
  transition: transform 0.5s var(--transition);
}
.stat-item:hover { background: var(--dark-3); }
.stat-item:hover::before { transform: scaleX(1); }
.stat-num {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  color: var(--white);
  line-height: 1;
  margin-bottom: 0.4rem;
}
.stat-num span { color: var(--orange); }
.stat-label { font-size: 0.85rem; color: var(--muted-2); letter-spacing: 0.04em; }

/* ---- LOGOS BAND ---- */
.logos-band {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1rem 2rem;
}
.logo-badge {
  padding: 0.6rem 1.4rem;
  background: var(--dark-3);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--muted-2);
  transition: all 0.25s;
  text-transform: uppercase;
}
.logo-badge:hover { border-color: var(--orange); color: var(--orange); }

/* ---- FORM ---- */
.form-group { margin-bottom: 1.4rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
label {
  display: block;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted-2);
  margin-bottom: 0.5rem;
}
input, textarea, select {
  width: 100%;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.85rem 1.1rem;
  color: #000;
  font-size: 0.95rem;
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
  appearance: none;
}
input::placeholder, textarea::placeholder { color: #555; }
input:focus, textarea:focus, select:focus {
  border-color: var(--orange);
  box-shadow: 0 0 0 3px rgba(232,116,32,0.12);
  background: #fff;
}
input.error, textarea.error { border-color: #e84040; }
.field-error { color: #e84040; font-size: 0.8rem; margin-top: 0.3rem; }
textarea { resize: vertical; min-height: 120px; }
select option { background: #fff; color: #000; }
.form-lgpd {
  display: flex;
  align-items: flex-start;
  gap: 0.8rem;
  padding: 1.2rem;
  background: var(--dark-3);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  margin-bottom: 1.6rem;
}
.form-lgpd input[type="checkbox"] {
  width: 18px;
  height: 18px;
  min-width: 18px;
  accent-color: var(--orange);
  margin-top: 2px;
}
.form-lgpd p { font-size: 0.82rem; color: var(--muted-2); margin: 0; }
.form-lgpd a { color: var(--orange); text-decoration: underline; }

/* ---- FORM SUCCESS MESSAGE ---- */
.form-success-msg {
  display: none;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1.1rem;
  padding: 3.5rem 1.5rem;
  animation: fsmFade 0.5s ease;
}
.form-success-msg.show { display: flex; }
.form-success-msg .fsm-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--orange-thin);
  border: 1px solid var(--glass-border-o);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--orange);
}
.form-success-msg h3 { color: var(--white); font-size: 1.3rem; margin: 0; }
.form-success-msg p { color: var(--muted-2); font-size: 0.95rem; margin: 0; max-width: 380px; line-height: 1.6; }
/* Sobre fundo dourado (diagnóstico), o cinza padrão fica ilegível — ajusta contraste */
.diagnostic-form .form-success-msg p, .diag-form-box .form-success-msg p { color: rgba(0,0,0,0.72); }
.diagnostic-form .form-success-msg .fsm-icon, .diag-form-box .form-success-msg .fsm-icon {
  background: rgba(0,0,0,0.15);
  border-color: rgba(0,0,0,0.25);
  color: var(--white);
}
@keyframes fsmFade {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ---- PAGE HERO (inner pages) ---- */
.page-hero {
  padding: clamp(8rem,15vw,13rem) 0 clamp(4rem,8vw,7rem);
  background: var(--dark-1);
  position: relative;
  overflow: hidden;
}
/* LEFT corner fan — top-left origin */
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(212,175,55,0.32) 0%, rgba(212,175,55,0.12) 14%, rgba(212,175,55,0.03) 30%, transparent 44%),
    linear-gradient(112deg, rgba(212,175,55,0.18) 0%, rgba(212,175,55,0.05) 20%, transparent 36%),
    linear-gradient(90deg,  rgba(212,175,55,0.15) 0%, rgba(212,175,55,0.04) 24%, transparent 40%),
    linear-gradient(158deg, rgba(212,175,55,0.13) 0%, rgba(212,175,55,0.03) 17%, transparent 32%),
    linear-gradient(180deg, rgba(212,175,55,0.10) 0%, rgba(212,175,55,0.02) 14%, transparent 28%);
  -webkit-mask-image: radial-gradient(ellipse 72% 72% at 0% 0%, black 0%, black 18%, rgba(0,0,0,0.55) 42%, rgba(0,0,0,0.15) 62%, transparent 82%);
  mask-image: radial-gradient(ellipse 72% 72% at 0% 0%, black 0%, black 18%, rgba(0,0,0,0.55) 42%, rgba(0,0,0,0.15) 62%, transparent 82%);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  animation: cornerGlow 16s ease-in-out infinite;
  animation-delay: 0s;
}
.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(225deg, rgba(212,175,55,0.32) 0%, rgba(212,175,55,0.12) 14%, rgba(212,175,55,0.03) 30%, transparent 44%),
    linear-gradient(248deg, rgba(212,175,55,0.18) 0%, rgba(212,175,55,0.05) 20%, transparent 36%),
    linear-gradient(270deg, rgba(212,175,55,0.15) 0%, rgba(212,175,55,0.04) 24%, transparent 40%),
    linear-gradient(202deg, rgba(212,175,55,0.13) 0%, rgba(212,175,55,0.03) 17%, transparent 32%),
    linear-gradient(180deg, rgba(212,175,55,0.10) 0%, rgba(212,175,55,0.02) 14%, transparent 28%);
  -webkit-mask-image: radial-gradient(ellipse 72% 72% at 100% 0%, black 0%, black 18%, rgba(0,0,0,0.55) 42%, rgba(0,0,0,0.15) 62%, transparent 82%);
  mask-image: radial-gradient(ellipse 72% 72% at 100% 0%, black 0%, black 18%, rgba(0,0,0,0.55) 42%, rgba(0,0,0,0.15) 62%, transparent 82%);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  animation: cornerGlow 16s ease-in-out infinite;
  animation-delay: 6s;
}
.page-hero .container { position: relative; z-index: 2; }
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  color: var(--muted-2);
  margin-bottom: 1.4rem;
}
.breadcrumb a:hover { color: var(--orange); }
.breadcrumb span { color: var(--muted-1); }

/* ---- FOOTER ---- */
#footer {
  background: linear-gradient(160deg, #1e1600 0%, #0e0a00 45%, #140e00 100%);
  border-top: 1px solid rgba(212,175,55,0.26);
  position: relative;
  overflow: hidden;
}
#footer::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(212,175,55,0.34) 0%, rgba(212,175,55,0.13) 14%, rgba(212,175,55,0.04) 30%, transparent 44%),
    linear-gradient(112deg, rgba(212,175,55,0.20) 0%, rgba(212,175,55,0.06) 20%, transparent 36%),
    linear-gradient(90deg,  rgba(212,175,55,0.17) 0%, rgba(212,175,55,0.04) 24%, transparent 40%),
    linear-gradient(158deg, rgba(212,175,55,0.14) 0%, rgba(212,175,55,0.04) 17%, transparent 32%),
    linear-gradient(180deg, rgba(212,175,55,0.11) 0%, rgba(212,175,55,0.02) 14%, transparent 28%);
  -webkit-mask-image: radial-gradient(ellipse 75% 80% at 0% 0%, black 0%, black 15%, rgba(0,0,0,0.6) 38%, rgba(0,0,0,0.18) 60%, transparent 80%);
  mask-image: radial-gradient(ellipse 75% 80% at 0% 0%, black 0%, black 15%, rgba(0,0,0,0.6) 38%, rgba(0,0,0,0.18) 60%, transparent 80%);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  animation: cornerGlow 16s ease-in-out infinite;
  animation-delay: 0s;
}
#footer::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(225deg, rgba(212,175,55,0.34) 0%, rgba(212,175,55,0.13) 14%, rgba(212,175,55,0.04) 30%, transparent 44%),
    linear-gradient(248deg, rgba(212,175,55,0.20) 0%, rgba(212,175,55,0.06) 20%, transparent 36%),
    linear-gradient(270deg, rgba(212,175,55,0.17) 0%, rgba(212,175,55,0.04) 24%, transparent 40%),
    linear-gradient(202deg, rgba(212,175,55,0.14) 0%, rgba(212,175,55,0.04) 17%, transparent 32%),
    linear-gradient(180deg, rgba(212,175,55,0.11) 0%, rgba(212,175,55,0.02) 14%, transparent 28%);
  -webkit-mask-image: radial-gradient(ellipse 75% 80% at 100% 0%, black 0%, black 15%, rgba(0,0,0,0.6) 38%, rgba(0,0,0,0.18) 60%, transparent 80%);
  mask-image: radial-gradient(ellipse 75% 80% at 100% 0%, black 0%, black 15%, rgba(0,0,0,0.6) 38%, rgba(0,0,0,0.18) 60%, transparent 80%);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  animation: cornerGlow 16s ease-in-out infinite;
  animation-delay: 6s;
}
#footer > .container { position: relative; z-index: 1; }
@keyframes cornerGlow {
  0%   { opacity: 0; }
  10%  { opacity: 0.85; }
  26%  { opacity: 1; }
  36%  { opacity: 0.8; }
  44%  { opacity: 0; }
  100% { opacity: 0; }
}
.footer-light-sweep { display: none; }
.footer-main {
  padding: 5rem 0 3rem;
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
  gap: 3.5rem;
}
.footer-brand .logo-main {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 0.3rem;
}
.footer-brand .logo-main span { color: var(--orange); }
.footer-brand .logo-sub {
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--muted-2);
  margin-bottom: 1.2rem;
}
.footer-brand p { font-size: 0.9rem; max-width: 280px; color: #9898a6; line-height: 1.7; }
.footer-social {
  display: flex;
  gap: 0.8rem;
  margin-top: 1.4rem;
}
.footer-social a {
  width: 38px; height: 38px;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted-2);
  transition: all 0.25s;
  font-size: 0.9rem;
}
.footer-social a:hover { border-color: var(--orange); color: var(--orange); background: var(--orange-thin); }
.footer-col h5 {
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--white);
  margin-bottom: 1.4rem;
}
.footer-col ul { display: flex; flex-direction: column; gap: 0.6rem; }
.footer-col li a {
  font-size: 0.9rem;
  color: #9898a6;
  transition: color 0.2s;
}
.footer-col li a:hover { color: var(--orange); }
.footer-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  font-size: 0.88rem;
  color: #9898a6;
  margin-bottom: 0.8rem;
}
.footer-contact-item svg { color: var(--orange); flex-shrink: 0; margin-top: 2px; }
.footer-contact-item a:hover { color: var(--orange); }
.footer-bottom {
  border-top: 1px solid var(--glass-border);
  padding: 1.5rem 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}
.footer-bottom p {
  font-size: 0.8rem;
  color: #5e5e6a;
  margin: 0;
}
.footer-bottom a { color: var(--orange); }
.footer-legal {
  display: flex;
  gap: 1.5rem;
}
.footer-legal a {
  font-size: 0.8rem;
  color: #5e5e6a;
  transition: color 0.2s;
}
.footer-legal a:hover { color: var(--orange); }

/* ---- BACK TO TOP ---- */
#back-to-top {
  position: fixed;
  bottom: calc(2rem + 58px + 2.8rem);
  right: 2rem;
  z-index: 900;
  width: 48px;
  height: 48px;
  background: rgba(9,9,11,0.82);
  border: 1.5px solid rgba(212,175,55,0.45);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(14px);
  transition: opacity 0.38s var(--transition), transform 0.38s var(--transition),
              visibility 0.38s, border-color 0.3s, background 0.3s;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
#back-to-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
#back-to-top:hover {
  background: rgba(212,175,55,0.10);
  border-color: rgba(212,175,55,0.85);
  transform: translateY(-4px);
  box-shadow: 0 6px 24px rgba(212,175,55,0.18);
}
#back-to-top svg {
  color: #d4af37;
  width: 20px;
  height: 20px;
  transition: transform 0.3s var(--transition-bounce);
}
#back-to-top:hover svg {
  transform: translateY(-2px);
}

/* ---- WHATSAPP FLOAT ---- */
@keyframes wa-shake {
  0%       { transform: rotate(0deg) scale(1); }
  2%       { transform: rotate(-14deg) scale(1.08); }
  4%       { transform: rotate(14deg) scale(1.08); }
  6%       { transform: rotate(-11deg) scale(1.06); }
  8%       { transform: rotate(11deg) scale(1.06); }
  10%      { transform: rotate(-7deg) scale(1.02); }
  12%      { transform: rotate(7deg) scale(1.02); }
  14%      { transform: rotate(-3deg) scale(1); }
  16%,100% { transform: rotate(0deg) scale(1); }
}
@keyframes wa-ring {
  0%   { box-shadow: 0 0 0 0 rgba(37,211,102,0.7), 0 3px 10px rgba(0,0,0,0.25); }
  20%  { box-shadow: 0 0 0 18px rgba(37,211,102,0), 0 3px 10px rgba(0,0,0,0.25); }
  21%,100% { box-shadow: 0 0 0 0 rgba(37,211,102,0), 0 3px 10px rgba(0,0,0,0.25); }
}
#whatsapp-float {
  position: fixed;
  bottom: 2rem; right: 2rem;
  z-index: 900;
  width: 58px; height: 58px;
  background: #25d366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
  animation: wa-ring 3s ease-out 1s infinite,
             wa-shake 3s ease-in-out 1s infinite;
  transform-origin: center center;
}
#whatsapp-float:hover {
  background-color: #1da851;
  animation: none;
  transform: scale(1.1);
  transition: transform 0.2s ease, background-color 0.2s ease;
}

/* ---- COOKIE BANNER ---- */
#cookie-banner {
  position: fixed;
  bottom: 1.5rem; left: 50%;
  transform: translateX(-50%) translateY(200%);
  z-index: 950;
  max-width: 600px;
  width: calc(100% - 3rem);
  background: var(--dark-3);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.8rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  box-shadow: 0 8px 48px rgba(0,0,0,0.6);
  transition: transform 0.5s var(--transition-bounce);
}
#cookie-banner.show { transform: translateX(-50%) translateY(0); }
#cookie-banner p { font-size: 0.85rem; color: var(--muted-2); margin: 0; flex: 1; }
#cookie-banner a { color: var(--orange); }
.cookie-actions { display: flex; gap: 0.6rem; flex-shrink: 0; }

/* ---- SCROLL ANIMATIONS ---- */
[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s var(--transition), transform 0.7s var(--transition);
}
[data-reveal="left"]  { transform: translateX(-30px); }
[data-reveal="right"] { transform: translateX(30px); }
[data-reveal="scale"] { transform: scale(0.94); }
[data-reveal].revealed { opacity: 1; transform: none; }

/* ---- UTILITY ---- */
.relative { position: relative; }
.overflow-hidden { overflow: hidden; }
.flex     { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-sm   { gap: 1rem; }
.gap-md   { gap: 2rem; }
.gap-lg   { gap: 3rem; }
.grid-2   { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; }
.grid-3   { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.grid-4   { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; }
.mt-sm    { margin-top: 1rem; }
.mt-md    { margin-top: 2rem; }
.mt-lg    { margin-top: 3.5rem; }
.mb-sm    { margin-bottom: 1rem; }
.mb-md    { margin-bottom: 2rem; }
.highlight-block {
  border-left: 3px solid var(--orange);
  padding: 1.2rem 1.6rem;
  background: var(--orange-thin);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  color: var(--muted-3);
  font-size: 1.05rem;
  line-height: 1.7;
}
.badge {
  display: inline-block;
  padding: 0.3rem 0.9rem;
  background: var(--orange-thin);
  border: 1px solid var(--glass-border-o);
  border-radius: 2rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--orange);
  text-transform: uppercase;
}

/* ---- RESPONSIVE ---- */
@media (max-width: 1024px) {
  .footer-main { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
  .grid-4      { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .nav-links   { display: none; }
  .hamburger   { display: flex; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .form-row    { grid-template-columns: 1fr; }
  .footer-main { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; text-align: center; }
  #cookie-banner { flex-direction: column; text-align: center; }
  .cookie-actions { justify-content: center; }
  .stats-grid  { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .stats-grid  { grid-template-columns: 1fr; }
  #whatsapp-float { bottom: 1.2rem; right: 1.2rem; width: 52px; height: 52px; }
}

/* ---- LOGO IMAGES ---- */
.nav-logo-img {
  height: 64px;
  width: auto;
  max-width: 240px;
  object-fit: contain;
  display: block;
  transition: opacity 0.2s;
}
.nav-logo:hover .nav-logo-img { opacity: 0.85; }
#header.scrolled .nav-logo-img { height: 55px; }

.footer-logo-img {
  height: 60px;
  width: auto;
  max-width: 240px;
  object-fit: contain;
  display: block;
  margin-bottom: 1rem;
  filter: brightness(1.05);
}

@media (max-width: 768px) {
  .nav-logo-img { height: 52px; }
  .footer-logo-img { height: 50px; }
}

/* ---- PAGE-TRANSITION OVERLAY ---- */
#page-overlay {
  position: fixed;
  inset: 0;
  background: var(--black);
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.35s var(--transition);
}
#page-overlay.active { opacity: 1; pointer-events: all; }

/* ---- LEGAL PAGES ---- */
.legal-content h2 { font-size: 1.6rem; margin: 2.5rem 0 0.8rem; color: var(--white); }
.legal-content h3 { font-size: 1.2rem; margin: 2rem 0 0.6rem; color: var(--white-dim); }
.legal-content p  { margin-bottom: 1rem; }
.legal-content ul { padding-left: 1.5rem; margin-bottom: 1rem; }
.legal-content ul li { color: var(--muted-3); margin-bottom: 0.4rem; list-style: disc; }
.legal-content a  { color: var(--orange); }
.legal-update {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.82rem;
  color: var(--muted-2);
  background: var(--dark-3);
  padding: 0.4rem 1rem;
  border-radius: 2rem;
  margin-bottom: 2rem;
}

/* ============================================================
   CURSOR PERSONALIZADO — Carrinho de supermercado
   Site é predominantemente escuro -> carrinho CLARO como padrão;
   superfícies claras (cards de logo, botões dourados) -> carrinho ESCURO.
   ============================================================ */
html, body { cursor: url("../images/cursor-cart-light.png") 5 4, auto; }
/* elementos clicáveis mantêm o carrinho (cursor de navegação) */
a, button, .btn, label.wiz-choice, .subject-tab, .hamburger, summary,
input[type="checkbox"], input[type="radio"], select, [onclick] {
  cursor: url("../images/cursor-cart-light.png") 5 4, pointer;
}
/* campos de texto mantêm o cursor de digitação */
input[type="text"], input[type="email"], input[type="tel"],
input[type="number"], input[type="date"], textarea {
  cursor: text;
}
/* superfícies CLARAS -> carrinho escuro (visibilidade) */
.conv-logo, .conv-logo *,
.btn-primary, .btn-primary *,
.nav-cta, .m-cta,
.subject-tab.active,
.cookie-actions .btn-primary,
.wiz-choice:has(input:checked),
.wiz-choice:has(input:checked) * {
  cursor: url("../images/cursor-cart-dark.png") 5 4, pointer;
}
/* toques/sem mouse: sem cursor custom */
@media (hover: none), (pointer: coarse) {
  html, body, a, button, .btn { cursor: auto; }
}

/* Animação de clique — anel dourado expandindo */
.cart-ripple {
  position: fixed; width: 16px; height: 16px; margin: -8px 0 0 -8px;
  border: 2px solid var(--orange); border-radius: 50%;
  pointer-events: none; z-index: 99998; opacity: 0.85;
  animation: cartRipple 0.55s var(--transition) forwards;
}
@keyframes cartRipple { to { transform: scale(3.6); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .cart-ripple { display: none; } }

/* ============================================================
   LEAD WIZARD — Formulário multi-etapas (Raio-X do Cliente)
   ============================================================ */
.wizard-section { background: var(--dark-1); position: relative; overflow: hidden; }
.wizard-section::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 80% 0%, rgba(212,175,55,0.06), transparent 60%);
  pointer-events: none;
}
.wizard-shell {
  max-width: 880px; margin: 0 auto; position: relative; z-index: 1;
  background: var(--dark-2);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: 3rem 3.2rem 3.2rem;
}
.wizard-shell .wiz-intro { text-align: center; margin-bottom: 2.2rem; }
.wizard-shell .wiz-intro h2 { font-size: clamp(1.5rem,3vw,2.1rem); color: var(--white); margin: 0.5rem 0 0.6rem; }
.wizard-shell .wiz-intro p { color: var(--muted-2); font-size: 1rem; max-width: 560px; margin: 0 auto; }
.wizard-shell .wiz-intro .section-tag { justify-content: center; }

/* ---- Progress (5 passos) ---- */
.wiz-progress { display: flex; align-items: flex-start; justify-content: space-between; position: relative; margin: 0 auto 2.6rem; max-width: 620px; }
.wiz-progress::before {
  content: ''; position: absolute; top: 19px; left: 8%; right: 8%; height: 2px;
  background: var(--glass-border); z-index: 0;
}
.wiz-progress-fill {
  content: ''; position: absolute; top: 19px; left: 8%; height: 2px;
  background: linear-gradient(90deg, var(--orange), var(--orange-light));
  z-index: 1; width: 0; transition: width 0.45s var(--transition);
}
.wiz-step { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 0.5rem; flex: 1; }
.wiz-step .wiz-dot {
  width: 40px; height: 40px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--dark-3); border: 2px solid var(--glass-border);
  color: var(--muted-2); font-weight: 700; font-size: 0.95rem;
  font-family: var(--font-display);
  transition: all 0.35s var(--transition);
}
.wiz-step .wiz-dot svg { width: 18px; height: 18px; display: none; }
.wiz-step .wiz-step-label { font-size: 0.7rem; text-align: center; color: var(--muted-2); letter-spacing: 0.03em; max-width: 90px; line-height: 1.25; transition: color 0.3s; }
.wiz-step.active .wiz-dot { border-color: var(--orange); color: var(--orange); box-shadow: 0 0 0 5px rgba(212,175,55,0.1); }
.wiz-step.active .wiz-step-label { color: var(--white); font-weight: 600; }
.wiz-step.done .wiz-dot { background: var(--orange); border-color: var(--orange); color: var(--black); }
.wiz-step.done .wiz-dot .wiz-num { display: none; }
.wiz-step.done .wiz-dot svg { display: block; }

/* ---- Panels ---- */
.wiz-panel { display: none; animation: wizFade 0.4s var(--transition); }
.wiz-panel.active { display: block; }
@keyframes wizFade { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.wiz-panel-head { margin-bottom: 1.6rem; }
.wiz-panel-head h3 { color: var(--white); font-size: 1.3rem; margin-bottom: 0.3rem; }
.wiz-panel-head p { color: var(--muted-2); font-size: 0.9rem; }
.wiz-panel-head .wiz-kicker { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: var(--orange); display: block; margin-bottom: 0.4rem; }

/* ---- Choice cards (selecionáveis) ---- */
.wiz-choices { display: grid; gap: 0.8rem; margin-bottom: 1.4rem; }
.wiz-choices.cols-2 { grid-template-columns: 1fr 1fr; }
.wiz-choices.cols-3 { grid-template-columns: repeat(3, 1fr); }
.wiz-choice {
  position: relative; display: flex; align-items: center; gap: 0.8rem;
  padding: 0.95rem 1.1rem; cursor: pointer;
  background: var(--dark-3); border: 1px solid var(--glass-border);
  border-radius: var(--radius-md); transition: all 0.2s var(--transition);
}
.wiz-choice:hover { border-color: var(--orange); transform: translateY(-2px); }
.wiz-choice input { position: absolute; opacity: 0; pointer-events: none; }
.wiz-choice .wiz-check {
  width: 22px; height: 22px; min-width: 22px; border-radius: 6px;
  border: 2px solid var(--glass-border-o); display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; color: transparent;
}
.wiz-choice input[type="radio"] + .wiz-check { border-radius: 50%; }
.wiz-choice .wiz-choice-txt { font-size: 0.9rem; color: var(--white-dim); line-height: 1.3; }
.wiz-choice .wiz-choice-txt small { display: block; font-size: 0.76rem; color: var(--muted-2); margin-top: 0.1rem; }
.wiz-choice:has(input:checked) { border-color: var(--orange); background: var(--orange-thin); }
.wiz-choice:has(input:checked) .wiz-check { background: var(--orange); border-color: var(--orange); color: var(--black); }
.wiz-choice:has(input:checked) .wiz-choice-txt { color: var(--white); }

/* ---- Nav buttons ---- */
.wiz-nav { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: 2rem; padding-top: 1.6rem; border-top: 1px solid var(--glass-border); }
.wiz-nav .wiz-count { font-size: 0.82rem; color: var(--muted-2); }
.wiz-nav .wiz-count b { color: var(--orange); }
.wiz-btn-prev {
  background: transparent; border: 1px solid var(--glass-border); color: var(--muted-3);
  padding: 0.7rem 1.3rem; border-radius: var(--radius-sm); font-weight: 600; font-size: 0.9rem;
  cursor: pointer; display: inline-flex; align-items: center; gap: 0.5rem; transition: all 0.2s;
}
.wiz-btn-prev:hover { border-color: var(--orange); color: var(--orange); }
.wiz-nav .wiz-spacer { flex: 1; }

@media (max-width: 768px) {
  .wizard-shell { padding: 2rem 1.4rem 2.2rem; }
  .wiz-choices.cols-2, .wiz-choices.cols-3 { grid-template-columns: 1fr; }
  .wiz-step .wiz-step-label { display: none; }
  .wiz-progress { max-width: 320px; }
  .wiz-progress::before, .wiz-progress-fill { top: 19px; }
}

/* ============================================================
   LASER BORDER GLOW — anel de luz dourado giratório nos cards
   Regra global: vale para os cards de todas as páginas.
   Borda suave girando em repouso; no hover acende e brilha.
   ============================================================ */
@property --laser-angle-card {
  syntax: '<angle>';
  inherits: false;
  initial-value: 0deg;
}
/* Gira uma volta completa e depois SEGURA 4s antes de girar de novo.
   Cards comuns: giro ~3s + pausa 4s (total 7s → giro termina em 42.86%). */
@keyframes laserSpinPause {
  0%      { --laser-angle-card: 0deg; }
  42.86%  { --laser-angle-card: 360deg; }
  100%    { --laser-angle-card: 360deg; }
}
/* Cards de foto: giro 25% mais lento (~3.75s) + pausa 4s
   (total 7.75s → giro termina em 48.39%). */
@keyframes laserSpinPausePhoto {
  0%      { --laser-angle-card: 0deg; }
  48.39%  { --laser-angle-card: 360deg; }
  100%    { --laser-angle-card: 360deg; }
}

/* garante contexto de posicionamento em todo card */
.card, .company-card, .contact-card, .talk-card, .audience-card,
.training-card, .method-step, .book-card,
.pain-card, .ct-card, .solution-card,
.testimonial-card, .plan-highlight { position: relative; }

/* anel de luz giratório — usa ::before na maioria;
   ::after nos cards cujo ::before já está ocupado
   (.testimonial-card e .plan-highlight) */
.card::before, .company-card::before, .contact-card::before,
.talk-card::before, .audience-card::before, .training-card::before,
.method-step::before, .book-card::before,
.pain-card::before, .ct-card::before, .solution-card::before,
.train-carousel::before,
.testimonial-card::after, .plan-highlight::after {
  content: '';
  position: absolute;
  inset: 0;
  padding: 1.5px;                 /* espessura da borda */
  border-radius: inherit;
  background: conic-gradient(
    from var(--laser-angle-card),
    transparent 0deg,
    transparent 150deg,
    rgba(230,198,53,0.15) 200deg,
    var(--laser-dark) 250deg,
    var(--laser-mid) 300deg,
    var(--laser-light) 340deg,
    var(--laser-mid) 360deg
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  pointer-events: none;
  z-index: 10;
  opacity: 0;                     /* invisível em repouso — só aparece no hover */
  animation: laserSpinPause 7s linear infinite;
  animation-play-state: paused;   /* parado em repouso */
  transition: opacity 0.3s, filter 0.3s;
}

/* no hover: acende, brilha e a animação (giro + pausa de 4s) roda */
.card:hover::before, .company-card:hover::before, .contact-card:hover::before,
.talk-card:hover::before, .audience-card:hover::before, .training-card:hover::before,
.method-step:hover::before, .book-card:hover::before,
.pain-card:hover::before, .ct-card:hover::before, .solution-card:hover::before,
.train-carousel:hover::before,
.testimonial-card:hover::after, .plan-highlight:hover::after {
  opacity: 1;
  filter: drop-shadow(0 0 4px rgba(245,219,77,0.4));
  animation-play-state: running;
}

@media (prefers-reduced-motion: reduce) {
  .card::before, .company-card::before, .contact-card::before,
  .talk-card::before, .audience-card::before, .training-card::before,
  .method-step::before, .book-card::before,
  .pain-card::before, .ct-card::before, .solution-card::before,
  .train-carousel::before,
  .testimonial-card::after, .plan-highlight::after { animation: none; }
}

/* ============================================================
   CARDS DE FOTO (quem-somos / consultoria)
   Apenas o anel laser giratório (hover, com pausa de 4s).
   Sombra estática só para dar profundidade — sem animação extra.
   ============================================================ */
.photo-frame, .photo-card {
  position: relative;
  box-shadow: 0 18px 45px rgba(0,0,0,0.45);
}

/* anel de luz giratório — só aparece e anima no hover */
.photo-frame::before, .photo-card::before {
  content: '';
  position: absolute;
  inset: 0;
  padding: 2px;
  border-radius: inherit;
  background: conic-gradient(
    from var(--laser-angle-card),
    transparent 0deg,
    transparent 120deg,
    rgba(230,198,53,0.20) 180deg,
    var(--laser-dark) 230deg,
    var(--laser-mid) 290deg,
    var(--laser-light) 335deg,
    var(--laser-tip) 354deg,
    #fffbe6 360deg
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  pointer-events: none;
  z-index: 10;
  opacity: 0;                     /* invisível em repouso — só aparece no hover */
  animation: laserSpinPausePhoto 7.75s linear infinite;
  animation-play-state: paused;   /* parado em repouso */
  transition: opacity 0.3s, filter 0.3s;
}
.photo-frame:hover::before, .photo-card:hover::before {
  opacity: 1;
  filter: drop-shadow(0 0 8px rgba(255,243,173,0.7)); /* ponta mais brilhante no hover */
  animation-play-state: running;
}

@media (prefers-reduced-motion: reduce) {
  .photo-frame, .photo-card,
  .photo-frame::before, .photo-card::before { animation: none; }
}

/* ============================================================
   FAQ (PERGUNTAS FREQUENTES)
   ============================================================ */
.faq-section {
  background: var(--dark-1);
  padding: 4rem 0;
}
.faq-container {
  max-width: 800px;
  margin: 0 auto;
}
.faq-item {
  background: var(--dark-2);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  margin-bottom: 1rem;
  overflow: hidden;
  transition: all 0.3s;
}
.faq-item:hover {
  border-color: var(--glass-border-o);
}
.faq-item[open] {
  border-color: var(--orange);
  background: var(--dark-3);
}
.faq-question {
  padding: 1.5rem;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--white);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none; /* remove seta padrao */
}
.faq-question::-webkit-details-marker {
  display: none; /* remove seta webkit */
}
.faq-question::after {
  content: '+';
  font-size: 1.5rem;
  color: var(--orange);
  transition: transform 0.3s;
}
.faq-item[open] .faq-question::after {
  content: '−';
  transform: rotate(180deg);
}
.faq-answer {
  padding: 0 1.5rem 1.5rem;
  font-size: 0.95rem;
  color: var(--white-dim);
  line-height: 1.6;
}
.faq-answer p {
  margin-bottom: 0.8rem;
}
.faq-answer p:last-child {
  margin-bottom: 0;
}


/* ---- Profile Glow Pulse ---- */
@keyframes pulseYellowGlow {
  0% { box-shadow: 0 0 15px rgba(212, 175, 55, 0.4); }
  50% { box-shadow: 0 0 35px rgba(212, 175, 55, 0.9), 0 0 60px rgba(212, 175, 55, 0.6); }
  100% { box-shadow: 0 0 15px rgba(212, 175, 55, 0.4); }
}
.profile-pulse {
  animation: pulseYellowGlow 4s infinite ease-in-out;
}

/* ============================================================
   DIAGNOSTIC FORM SYSTEM
   ============================================================ */
.diagnostic-section {
  background: var(--dark-1);
  position: relative;
  overflow: hidden;
}
.diagnostic-section::before {
  content: '';
  position: absolute;
  right: -10%;
  top: -30%;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(212,175,55,0.08), transparent 70%);
  pointer-events: none;
}
.diagnostic-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;
}
.diagnostic-grid > * {
  min-width: 0; /* previne grid blowout — item não pode vazar além da coluna */
  max-width: 100%;
  box-sizing: border-box;
}
.diagnostic-benefits {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2rem;
}
.diag-benefit {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  font-size: 0.95rem;
  color: var(--muted-3);
}
.diag-benefit svg {
  color: var(--orange);
  flex-shrink: 0;
}
.diagnostic-form, .diag-form-box {
  background-color: var(--orange) !important;
  background-image: linear-gradient(to bottom, #a88621 0%, transparent 220px) !important;
  border: none !important;
  border-radius: var(--radius-xl);
  padding: 3rem;
  box-shadow: 0 20px 50px rgba(0,0,0,0.4);
  position: relative;
  z-index: 1;
}
.diagnostic-form h4, .diag-form-box h4 {
  color: var(--white);
  margin-bottom: 2rem;
  font-size: 1.4rem;
  font-weight: 600;
  text-align: center;
}
.diagnostic-form label, .diag-form-box label {
  color: var(--white);
  font-weight: 600;
  margin-bottom: 0.5rem;
  display: block;
  font-size: 0.7rem !important;
}
.diagnostic-form input, .diagnostic-form select, .diagnostic-form textarea,
.diag-form-box input, .diag-form-box select, .diag-form-box textarea {
  background-color: #f7eed2 !important;
  color: #aaa596 !important;
  border: none !important;
  border-radius: var(--radius-sm);
  padding: 0.6rem !important;
  width: 100%;
  font-size: 0.75rem !important;
  font-weight: 500;
  transition: all 0.3s;
}
.diagnostic-form select option, .diag-form-box select option {
  background: #111 !important;
  color: #fff !important;
}
.diagnostic-form input::placeholder, .diagnostic-form textarea::placeholder,
.diag-form-box input::placeholder, .diag-form-box textarea::placeholder {
  color: #aaa596 !important;
}
.diagnostic-form input:focus, .diagnostic-form select:focus, .diagnostic-form textarea:focus,
.diag-form-box input:focus, .diag-form-box select:focus, .diag-form-box textarea:focus {
  background-color: #fff !important;
  color: #9f8329 !important;
  outline: none;
  box-shadow: 0 0 10px rgba(255, 255, 255, 0.3) !important;
}

/* LGPD Box */
.diagnostic-form .form-lgpd, .diag-form-box .form-lgpd {
  background-color: #9f8329 !important;
  padding: 1rem;
  border-radius: 8px;
  margin-top: 1rem;
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 12px;
}
.diagnostic-form .form-lgpd p, .diag-form-box .form-lgpd p,
.diagnostic-form .form-lgpd p a, .diag-form-box .form-lgpd p a {
  color: #ffffff !important;
  font-size: 0.65rem !important;
  line-height: 1.3 !important;
  margin: 0;
  cursor: pointer;
}

/* Custom Checkbox (Botão Concordo) */
.diagnostic-form .form-lgpd input[type="checkbox"], 
.diag-form-box .form-lgpd input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 24px !important;
  height: 24px !important;
  min-width: 24px !important;
  min-height: 24px !important;
  background-color: #fff !important;
  border-radius: 50% !important;
  border: 2px solid #fff !important;
  cursor: pointer;
  flex-shrink: 0 !important;
  position: relative;
  display: inline-block;
  pointer-events: auto !important;
}
.diagnostic-form .form-lgpd input[type="checkbox"]:checked, 
.diag-form-box .form-lgpd input[type="checkbox"]:checked {
  background-color: #937417 !important;
  border-color: #fff !important;
}
.diagnostic-form .form-lgpd input[type="checkbox"]:checked::after, 
.diag-form-box .form-lgpd input[type="checkbox"]:checked::after {
  content: "✔";
  position: absolute;
  color: #fff;
  font-size: 14px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* Submit Button */
.diagnostic-form button.btn-primary, .diag-form-box button.btn-primary {
  background-color: #937417 !important;
  color: #ffffff !important;
  border-color: #937417 !important;
  font-weight: bold;
  text-align: center;
  justify-content: center;
  width: 100%;
  padding: 1rem;
  animation: pulseButton4s 4s infinite;
}
.diagnostic-form button.btn-primary:hover, .diag-form-box button.btn-primary:hover {
  background-color: #7a5f11 !important;
  border-color: #7a5f11 !important;
  color: #ffffff !important;
}

/* ---- DIAGNOSTIC MOBILE RESPONSIVE ---- */
@media (max-width: 768px) {
  .diagnostic-grid {
    grid-template-columns: 1fr !important;
    gap: 2.5rem !important;
  }
  .diagnostic-form, .diag-form-box {
    padding: 1.5rem !important;
    border-radius: var(--radius-lg) !important;
  }
}
