/* ─────────────────────────────────────────────────────────────
   WEBINAR OPT3 — CSS COMPLETO PARA WP CODER
   Apague tudo que existe na aba CSS e cole este arquivo inteiro
   ───────────────────────────────────────────────────────────── */

/* 1. Remove margens do WordPress */
html { margin-top: 0 !important; }
body { margin-top: 0 !important; padding-top: 0 !important; }
.wp-site-blocks,.wp-site-blocks > *,.site,.site-content,
.site-main,main,article,.entry-content,.page-content,
.wp-block-post-content,.is-layout-flow,.wp-block-group,.alignfull {
  padding:0 !important; margin:0 !important;
  max-width:none !important; width:100% !important;
}

/* 2. Variáveis e reset global */
#op3lp {
  --blue: #1D87EB;
  --green: #86DC5E;
  --bg: #060D18;
  --bg2: #091520;
  --card: rgba(255,255,255,.03);
  --border: rgba(255,255,255,.07);
  --text: #E8F2ED;
  --muted: rgba(200,220,240,.82);
  color: #E8F2ED;
  font-family: 'DM Sans', sans-serif;
  -webkit-font-smoothing: antialiased;
}
#op3lp *, #op3lp *::before, #op3lp *::after {
  box-sizing: border-box; margin: 0; padding: 0;
}
#op3lp a { color: inherit; text-decoration: none; }
#op3lp img { max-width: 100%; display: block; }

/* 3. Barra de progresso */
#op3lp #prog {
  position: fixed; top: 0; left: 0; height: 3px;
  background: linear-gradient(90deg, var(--blue), var(--green));
  z-index: 200; transition: width .1s; width: 0;
}

/* 4. Nav */
#op3lp nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: rgba(6,13,24,.92); backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  height: 64px; padding: 0 48px;
  display: flex; align-items: center; justify-content: space-between;
}
#op3lp nav svg { height: 43px; width: auto; }
#op3lp .nav-links { display: flex; gap: 28px; list-style: none; }
#op3lp .nav-links a {
  font-size: 13px; color: rgba(232,242,237,.55);
  text-decoration: none; letter-spacing: .02em;
  transition: color .2s;
}
#op3lp .nav-links a:hover { color: var(--text); }
#op3lp .nav-cta {
  font-size: 12px; font-weight: 600; letter-spacing: .06em;
  text-transform: uppercase; color: var(--blue);
  border: 1px solid rgba(29,135,235,.35);
  padding: 8px 20px; border-radius: 6px;
  transition: all .2s;
}
#op3lp .nav-cta:hover {
  background: rgba(29,135,235,.08);
  border-color: var(--blue);
}

/* 5. Animações de entrada */
#op3lp .rv {
  opacity: 0; transform: translateY(22px);
  transition: opacity .65s cubic-bezier(.22,1,.36,1),
              transform .65s cubic-bezier(.22,1,.36,1);
}
#op3lp .rv.in { opacity: 1; transform: none; }
#op3lp .d1 { transition-delay: .05s; }
#op3lp .d2 { transition-delay: .12s; }
#op3lp .d3 { transition-delay: .2s; }
#op3lp .d4 { transition-delay: .28s; }
#op3lp .r1 { transition-delay: .04s; }
#op3lp .r2 { transition-delay: .1s; }
#op3lp .r3 { transition-delay: .16s; }
#op3lp .r4 { transition-delay: .22s; }
#op3lp .r5 { transition-delay: .28s; }
@keyframes op3fu {
  from { opacity:0; transform:translateY(18px); }
  to   { opacity:1; transform:none; }
}
#op3lp .fu { animation: op3fu .7s cubic-bezier(.22,1,.36,1) both; }

/* 6. HERO — FIX: <p> vazios do WordPress quebram o grid */
#op3lp #hero > p,
#op3lp #hero > br {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

#op3lp #hero {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  position: relative;
  overflow: hidden;
  background: var(--bg);
}
#op3lp .hero-left  { grid-column: 1 !important; }
#op3lp .hero-right { grid-column: 2 !important; }

#op3lp #hero::before {
  content: ''; position: absolute; inset: 0;
  pointer-events: none; z-index: 0;
  background:
    radial-gradient(70% 60% at 20% 55%, rgba(29,135,235,.07) 0%, transparent 65%),
    radial-gradient(50% 70% at 75% 75%, rgba(134,220,94,.05) 0%, transparent 65%);
}
#op3lp #hero::after {
  content: ''; position: absolute; inset: 0;
  pointer-events: none; z-index: 0;
  background-image:
    linear-gradient(rgba(29,135,235,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(29,135,235,.04) 1px, transparent 1px);
  background-size: 64px 64px;
}

#op3lp .hero-left {
  position: relative; z-index: 2;
  padding: 120px 56px 80px 60px;
  display: flex; flex-direction: column; justify-content: center;
}
#op3lp .hero-left::after {
  content: ''; position: absolute; right: 0; top: 10%; bottom: 10%;
  width: 1px;
  background: linear-gradient(transparent, rgba(29,135,235,.4), transparent);
}
#op3lp .hero-right {
  position: relative; z-index: 2;
  padding: 120px 60px 80px 48px;
  display: flex; flex-direction: column; justify-content: center;
}

/* Live badge */
#op3lp .live-badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 10px; font-weight: 600; letter-spacing: .14em;
  text-transform: uppercase; color: var(--green);
  border: 1px solid rgba(134,220,94,.25);
  background: rgba(134,220,94,.05);
  padding: 6px 14px; border-radius: 100px;
  margin-bottom: 28px; width: fit-content;
}
#op3lp .live-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 0 rgba(134,220,94,.5);
  animation: op3pulse 1.8s infinite;
}
@keyframes op3pulse {
  0%   { box-shadow: 0 0 0 0 rgba(134,220,94,.5); }
  70%  { box-shadow: 0 0 0 7px rgba(134,220,94,0); }
  100% { box-shadow: 0 0 0 0 rgba(134,220,94,0); }
}

/* Hero heading */
#op3lp .hh {
  font-size: clamp(36px,4.5vw,62px);
  font-weight: 800; letter-spacing: -.035em;
  line-height: 1.05; margin-bottom: 22px;
  color: var(--text);
}
#op3lp .hh em {
  font-style: normal; color: var(--blue);
}
#op3lp .hero-desc {
  font-size: 16px; font-weight: 300;
  color: var(--muted); line-height: 1.8;
  max-width: 460px; margin-bottom: 32px;
}
#op3lp .hero-desc b { font-weight: 600; color: var(--text); }

/* Date bar */
#op3lp .date-bar {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 28px;
}
#op3lp .dbi {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; color: var(--muted);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  padding: 7px 14px; border-radius: 8px;
}
#op3lp .dbi .hi { color: var(--text); font-weight: 600; }

/* Tags */
#op3lp .tag-row { display: flex; flex-wrap: wrap; gap: 8px; }
#op3lp .tg {
  font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; padding: 5px 12px; border-radius: 100px;
}
#op3lp .tg-b {
  background: rgba(29,135,235,.1); color: #7BBFF7;
  border: 1px solid rgba(29,135,235,.2);
}
#op3lp .tg-g {
  background: rgba(134,220,94,.08); color: #A4E87A;
  border: 1px solid rgba(134,220,94,.2);
}
#op3lp .tg-w {
  background: rgba(255,255,255,.05); color: rgba(232,242,237,.7);
  border: 1px solid rgba(255,255,255,.1);
}

/* 7. FORM */
#op3lp .form-wrap {
  background: rgba(10,22,40,.85);
  border: 1px solid rgba(29,135,235,.25);
  border-radius: 16px;
  padding: 32px;
  position: relative;
  backdrop-filter: blur(12px);
}
#op3lp .form-wrap::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--blue), var(--green));
  border-radius: 16px 16px 0 0;
}
#op3lp .form-ey {
  font-size: 10px; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--green);
  margin-bottom: 8px;
}
#op3lp .form-ttl {
  font-size: 22px; font-weight: 700; letter-spacing: -.02em;
  color: var(--text); margin-bottom: 6px;
}
#op3lp .form-sub {
  font-size: 13px; color: var(--muted);
  line-height: 1.6; margin-bottom: 20px;
}

/* Vagas */
#op3lp .vagas {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 20px;
}
#op3lp .vl {
  font-size: 11px; color: var(--green); font-weight: 600;
  white-space: nowrap;
}
#op3lp .vt {
  flex: 1; height: 4px; background: rgba(255,255,255,.08);
  border-radius: 2px; overflow: hidden;
}
#op3lp .vf {
  width: 74%; height: 100%;
  background: linear-gradient(90deg, var(--blue), var(--green));
}
#op3lp .vp { font-size: 11px; color: var(--muted); white-space: nowrap; }

/* Form grid — FIX: alinhamento das caixas */
#op3lp .fg {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 16px;
  align-items: end;
}
#op3lp .fg .field {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
#op3lp .fg .field label {
  display: block;
  font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: rgba(200,220,240,.5);
  margin-bottom: 7px; min-height: 20px;
}
#op3lp .fg .field input,
#op3lp .fg .field select,
#op3lp .fg .field .sw {
  height: 44px !important;
  min-height: 44px !important;
  box-sizing: border-box !important;
}
#op3lp .field input,
#op3lp .field select {
  width: 100%; height: 44px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  color: var(--text); font-family: 'DM Sans', sans-serif;
  font-size: 14px; padding: 0 14px;
  outline: none;
  transition: border-color .2s, background .2s;
  box-sizing: border-box;
  -webkit-appearance: none; appearance: none;
}
#op3lp .field input::placeholder { color: rgba(200,220,240,.25); }
#op3lp .field input:focus,
#op3lp .field select:focus {
  border-color: var(--blue);
  background: rgba(29,135,235,.06);
  box-shadow: 0 0 0 3px rgba(29,135,235,.12);
}
#op3lp .sw { position: relative; }
#op3lp .sw::after {
  content: '';
  position: absolute; right: 14px; top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid rgba(200,220,240,.45);
}
#op3lp .sw select { padding-right: 36px; cursor: pointer; width: 100%; }
#op3lp .sw select option { background: #0D1F35; color: var(--text); }

/* Submit button */
#op3lp .btn-sub {
  width: 100%; height: 50px;
  background: linear-gradient(135deg, var(--blue), #1167C0);
  border: none; border-radius: 10px;
  color: #fff; font-family: 'DM Sans', sans-serif;
  font-size: 14px; font-weight: 700; letter-spacing: .03em;
  cursor: pointer; transition: all .2s;
  margin-bottom: 12px;
}
#op3lp .btn-sub:hover {
  background: rgb(23,135,192);
  transform: translateY(-1px);
  box-shadow: 0 0 28px rgba(29,135,235,.55);
}
#op3lp .form-priv {
  font-size: 12px; color: rgba(200,220,240,.45); text-align: center;
}
#op3lp .form-priv a { color: var(--blue); }

/* Success state */
#op3lp .success-state {
  display: none; flex-direction: column;
  align-items: center; text-align: center;
  padding: 20px 0; gap: 12px;
}
#op3lp .suc-icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(134,220,94,.1);
  display: flex; align-items: center; justify-content: center;
}
#op3lp .suc-ttl {
  font-size: 18px; font-weight: 700;
  color: var(--text); letter-spacing: -.01em;
}
#op3lp .suc-desc {
  font-size: 13px; color: var(--muted); line-height: 1.65;
}

/* 8. SPEAKERS */
#op3lp #speakers {
  background: var(--bg); padding: 100px 0;
  border-bottom: 1px solid var(--border);
}
#op3lp .sp-inner {
  max-width: 1140px; margin: 0 auto; padding: 0 60px;
}
#op3lp .sp-label {
  font-size: 10px; font-weight: 700; letter-spacing: .16em;
  text-transform: uppercase; color: var(--blue);
  margin-bottom: 40px;
  display: flex; align-items: center; gap: 10px;
}
#op3lp .sp-label::before {
  content: ''; width: 24px; height: 1.5px; background: var(--blue);
}
#op3lp .sp-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
}
#op3lp .sp-card {
  display: flex; align-items: center; gap: 24px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px; padding: 24px;
  transition: border-color .2s;
}
#op3lp .sp-card:hover { border-color: rgba(29,135,235,.3); }
#op3lp .sp-photo {
  width: 88px; height: 88px; border-radius: 12px;
  overflow: hidden; flex-shrink: 0; position: relative;
}
#op3lp .sp-photo img {
  width: 100%; height: 100%; object-fit: cover;
}
#op3lp .sp-photo-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--overlay, rgba(29,135,235,.3)) 0%, transparent 60%);
}
#op3lp .sp-name { font-size: 17px; font-weight: 700; margin-bottom: 2px; }
#op3lp .sp-co { font-size: 11px; color: var(--green); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 4px; }
#op3lp .sp-role { font-size: 13px; color: var(--muted); }

/* 9. SEC INNER helper */
#op3lp .sec-inner {
  max-width: 1140px; margin: 0 auto; padding: 0 60px;
}
#op3lp .ey {
  font-size: 10px; font-weight: 700; letter-spacing: .16em;
  text-transform: uppercase; color: var(--blue);
  margin-bottom: 16px;
  display: flex; align-items: center; gap: 10px;
}
#op3lp .ey::before {
  content: ''; width: 24px; height: 1.5px; background: var(--blue);
}

/* 10. DOR */
#op3lp #dor {
  background: #071018; padding: 110px 0;
  border-bottom: 1px solid var(--border);
}
#op3lp .dor-h {
  font-size: clamp(26px,3vw,42px); font-weight: 700;
  letter-spacing: -.03em; line-height: 1.15;
  margin-bottom: 52px; max-width: 680px;
}
#op3lp .dor-h em { font-style: normal; color: var(--blue); }
#op3lp .pain-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 20px;
}
#op3lp .pc {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 16px; padding: 32px 28px;
  transition: background .2s;
}
#op3lp .pc:hover { background: rgba(29,135,235,.04); }
#op3lp .pc-n {
  font-size: 64px; font-weight: 900; line-height: 1;
  letter-spacing: -.05em; margin-bottom: 16px;
  background: linear-gradient(135deg, var(--num-c1,var(--blue)), var(--num-c2,var(--green)));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
#op3lp .pc-bar { width: 28px; height: 3px; border-radius: 2px; margin-bottom: 20px; }
#op3lp .pc-ttl { font-size: 16px; font-weight: 700; margin-bottom: 10px; letter-spacing: -.01em; }
#op3lp .pc-txt { font-size: 14px; color: var(--muted); line-height: 1.7; }

/* 11. APRENDA */
#op3lp #aprenda {
  padding: 110px 0;
  background: var(--bg2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
#op3lp .ap-grid {
  display: grid; grid-template-columns: 380px 1fr;
  gap: 80px; align-items: start; margin-top: 52px;
}
#op3lp .ap-sticky { position: sticky; top: 100px; }
#op3lp .stat-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 28px 0 24px; }
#op3lp .stat {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; padding: 20px 16px;
}
#op3lp .stat-n { font-size: 36px; font-weight: 900; letter-spacing: -.04em; line-height: 1; margin-bottom: 6px; }
#op3lp .stat-d { font-size: 12px; color: var(--muted); line-height: 1.5; }
#op3lp .insight {
  background: rgba(29,135,235,.05);
  border: 1px solid rgba(29,135,235,.18);
  border-radius: 12px; padding: 20px;
}
#op3lp .ins-lbl { font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--blue); margin-bottom: 8px; }
#op3lp .ins-txt { font-size: 14px; color: var(--muted); line-height: 1.7; }
#op3lp .ins-txt em { font-style: normal; color: var(--text); font-weight: 600; }

#op3lp .steps { display: flex; flex-direction: column; gap: 0; }
#op3lp .step {
  display: flex; gap: 20px; align-items: flex-start;
  padding: 24px 0; border-bottom: 1px solid var(--border);
}
#op3lp .step:last-child { border-bottom: none; }
#op3lp .st-n {
  font-size: 12px; font-weight: 700; color: var(--blue);
  letter-spacing: .06em; min-width: 28px; margin-top: 2px;
}
#op3lp .st-ttl { font-size: 15px; font-weight: 600; margin-bottom: 6px; color: var(--text); }
#op3lp .st-txt { font-size: 13px; color: var(--muted); line-height: 1.65; margin-bottom: 10px; }
#op3lp .st-tag { padding: 3px 10px; border-radius: 100px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }

/* 12. PARA QUEM */
#op3lp #quem {
  padding: 110px 0;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}
#op3lp .qg {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 16px; margin-top: 40px;
}
#op3lp .qc {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px; padding: 24px;
  transition: border-color .2s;
}
#op3lp .qc:hover { border-color: rgba(29,135,235,.25); }
#op3lp .qc-ico {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
#op3lp .qc-role { font-size: 14px; font-weight: 700; margin-bottom: 8px; color: var(--text); }
#op3lp .qc-desc { font-size: 13px; color: var(--muted); line-height: 1.65; }

/* 13. CTA FINAL */
#op3lp #cta {
  padding: 110px 0;
  background: var(--bg2);
}
#op3lp .cta-inner {
  max-width: 660px; margin: 0 auto; padding: 0 24px; text-align: center;
}
#op3lp .cta-big {
  font-size: clamp(28px,3.5vw,48px); font-weight: 800;
  letter-spacing: -.04em; line-height: 1.1;
  margin-bottom: 18px; color: var(--text);
}
#op3lp .cta-big em { font-style: normal; color: var(--blue); }
#op3lp .cta-desc {
  font-size: 16px; color: var(--muted); line-height: 1.75;
  margin-bottom: 36px;
}
#op3lp .cta-form .form-wrap { text-align: left; }

/* 14. FOOTER */
#op3lp footer {
  background: var(--bg);
  border-top: 1px solid var(--border);
  padding: 40px 60px;
  display: flex; align-items: center;
  justify-content: space-between;
  flex-wrap: wrap; gap: 16px;
}
#op3lp .ft-l { display: flex; align-items: center; gap: 16px; }
#op3lp .ft-sep { width: 1px; height: 28px; background: var(--border); }
#op3lp .ft-tag {
  font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(232,242,237,.3);
}
#op3lp .ft-links { display: flex; gap: 24px; }
#op3lp .ft-links a {
  font-size: 12px; color: rgba(232,242,237,.35);
  text-decoration: none; transition: color .2s;
}
#op3lp .ft-links a:hover { color: var(--text); }
#op3lp .ft-copy { font-size: 12px; color: rgba(232,242,237,.25); }

/* 15. RESPONSIVE */
@media (max-width: 1024px) {
  #op3lp #hero { grid-template-columns: 1fr; }
  #op3lp .hero-left  { grid-column: 1 !important; padding: 100px 32px 40px; }
  #op3lp .hero-right { grid-column: 1 !important; padding: 0 32px 80px; }
  #op3lp .hero-left::after { display: none; }
  #op3lp .pain-grid { grid-template-columns: 1fr; }
  #op3lp .ap-grid { grid-template-columns: 1fr; gap: 40px; }
  #op3lp .ap-sticky { position: static; }
  #op3lp .sp-grid { grid-template-columns: 1fr; }
  #op3lp .qg { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  #op3lp nav { padding: 0 20px; }
  #op3lp .nav-links { display: none; }
  #op3lp .sec-inner { padding: 0 20px; }
  #op3lp .sp-inner { padding: 0 20px; }
  #op3lp #dor, #op3lp #aprenda, #op3lp #quem, #op3lp #cta, #op3lp #speakers { padding: 72px 0; }
  #op3lp .fg { grid-template-columns: 1fr; }
  #op3lp .sp-card { flex-direction: column; text-align: center; }
  #op3lp .qg { grid-template-columns: 1fr; }
  #op3lp footer { flex-direction: column; align-items: flex-start; padding: 32px 20px; }
  #op3lp .stat-pair { grid-template-columns: 1fr; }
  #op3lp .cta-inner { padding: 0 16px; }
}
/* Fix 1 — Remove as laterais brancas do Elementor */
.e-con-inner {
  max-width: 100% !important;
  padding: 0 !important;
}
.elementor-element.e-flex {
  padding: 0 !important;
}
body {
  background: #060D18 !important;
}

/* Fix 2 — Remove <p> vazios que quebram o grid de palestrantes */
#op3lp .sp-grid > p,
#op3lp .sp-inner > p,
#op3lp section > p {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
selector {
  visibility: hidden !important;
  position: absolute !important;
  height: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

/* ── CTA Final Button ── */
#op3lp .cta-btn-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
}
#op3lp .cta-inscricao-btn {
  display: inline-block;
  background: linear-gradient(135deg, #1D87EB, #1167C0);
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: .03em;
  padding: 16px 48px;
  border-radius: 10px;
  text-decoration: none;
  transition: all .2s;
  box-shadow: 0 4px 24px rgba(29,135,235,.35);
}
#op3lp .cta-inscricao-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(29,135,235,.55);
}


/* Hide Elementor form container */
.elementor-element-198b6b9 { display: none !important; }
[data-id="198b6b9"] { display: none !important; }

/* Hide orphan vagas text and Elementor form at bottom */
.vp, .vl, .vt, .vf { display: none !important; }
.elementor-element-198b6b9,
[data-id="198b6b9"] { display: none !important; }
/* Remove texto 74% do formulario */
#op3lp .form-wrap .vp,
#op3lp .form-wrap .vl,
#op3lp .form-wrap .vt,
#op3lp .cta-inner .vp,
#op3lp .cta-inner .vl,
#op3lp .cta-inner .vt {
  display: none !important;
}


/* ═══════════════════════════════════════════════════════════════
   SEÇÕES FORA DO #op3lp — CSS COMPLETO
   (speakers, dor, aprenda, quem, cta estão em containers Elementor)
   ═══════════════════════════════════════════════════════════════ */

/* ── Variáveis e base para todas as seções externas ── */
#speakers, #dor, #aprenda, #quem, #cta {
  --blue: #1D87EB;
  --green: #86DC5E;
  --bg: #060D18;
  --bg2: #091520;
  --card: rgba(255,255,255,.04);
  --border: rgba(255,255,255,.08);
  --text: #E8F2ED;
  --muted: rgba(200,220,240,.75);
  --blue-dim: rgba(29,135,235,.12);
  color: #E8F2ED;
  font-family: 'DM Sans', sans-serif;
  -webkit-font-smoothing: antialiased;
  width: 100%;
}

/* Remove padding extra dos containers Elementor */
#speakers .e-con-inner, #dor .e-con-inner, #aprenda .e-con-inner,
#quem .e-con-inner, #cta .e-con-inner {
  padding: 0 !important;
  max-width: none !important;
  width: 100% !important;
}

/* .ey — label de seção (eyebrow) */
#speakers .ey, #dor .ey, #aprenda .ey, #quem .ey, #cta .ey {
  font-family: 'DM Mono', monospace;
  font-size: 10px; font-weight: 700; letter-spacing: .18em;
  text-transform: uppercase; color: var(--green);
  display: flex !important; align-items: center; gap: 10px;
  margin-bottom: 14px;
}
#speakers .ey::before, #dor .ey::before, #aprenda .ey::before,
#quem .ey::before, #cta .ey::before {
  content: ''; display: inline-block;
  width: 20px; height: 1.5px; background: var(--green); flex-shrink: 0;
}

/* .sec-inner / .sp-inner / .cta-inner — max-width centralizado */
#speakers .sp-inner, #dor .sec-inner, #aprenda .sec-inner,
#quem .sec-inner, #cta .cta-inner {
  max-width: 1100px; margin: 0 auto; width: 100%;
}

/* Esconde <p> sem classe injetados pelo WP — preserva filhos com classe */
#speakers > p:not([class]), #dor > p:not([class]), #aprenda > p:not([class]),
#quem > p:not([class]), #cta > p:not([class]):not(:has(.cta-inscricao-btn)),
#speakers .sp-inner > p:not([class]), #dor .sec-inner > p:not([class]),
#aprenda .sec-inner > p:not([class]), #quem .sec-inner > p:not([class]),
#cta .cta-inner > p:not([class]):not(:has(.cta-inscricao-btn)),
#speakers .sp-grid > p:not([class]) {
  display: none !important; margin: 0 !important; padding: 0 !important;
}

/* ══════════════ SPEAKERS ══════════════ */
#speakers {
  background: var(--bg);
  padding: 80px 60px;
}
#speakers .sp-label {
  font-family: 'DM Mono', monospace;
  font-size: 10px; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--green);
  display: flex !important; align-items: center; gap: 10px;
  margin-bottom: 36px;
}
#speakers .sp-label::before {
  content: ''; display: inline-block;
  width: 24px; height: 1.5px; background: var(--green); flex-shrink: 0;
}
#speakers .sp-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 24px !important;
}
#speakers .sp-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px; overflow: hidden;
  display: flex !important; align-items: flex-end;
  min-height: 380px; position: relative;
  transition: border-color .2s;
}
#speakers .sp-card:hover { border-color: rgba(29,135,235,.35); }
#speakers .sp-photo { position: absolute; inset: 0; }
#speakers .sp-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
#speakers .sp-photo-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(6,13,24,1) 0%, rgba(6,13,24,.5) 50%, transparent 100%);
}
#speakers .sp-info { position: relative; z-index: 2; padding: 28px; width: 100%; }
#speakers .sp-name { font-size: 18px; font-weight: 700; margin-bottom: 3px; color: var(--text); }
#speakers .sp-co { font-size: 11px; color: var(--green); font-weight: 600; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 5px; }
#speakers .sp-role { font-size: 13px; color: var(--muted); }

/* ══════════════ DOR (O PROBLEMA) ══════════════ */
#dor {
  background: var(--bg2);
  padding: 80px 60px;
}
#dor .dor-h {
  font-family: 'Syne', sans-serif;
  font-size: clamp(28px, 3vw, 42px) !important;
  font-weight: 800 !important; letter-spacing: -.025em;
  line-height: 1.1; color: var(--text) !important;
  margin-bottom: 8px; display: block !important;
}
#dor .dor-h em { font-style: italic; color: var(--muted); font-weight: 400; }
#dor .pain-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important; margin-top: 48px;
}
#dor .pc {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 28px 24px !important;
  transition: border-color .2s, transform .2s;
}
#dor .pc:hover { border-color: rgba(29,135,235,.3) !important; transform: translateY(-3px); }
#dor .pc-n {
  font-family: 'DM Mono', monospace;
  font-size: 11px; font-weight: 700; letter-spacing: .12em;
  color: var(--blue); margin-bottom: 12px; display: block !important;
}
#dor .pc-bar {
  width: 32px; height: 2px; background: var(--blue);
  margin-bottom: 16px; display: block !important;
  border-radius: 2px;
}
#dor .pc-ttl {
  font-family: 'Syne', sans-serif;
  font-size: 16px; font-weight: 700;
  color: var(--text); margin-bottom: 10px;
  display: block !important;
}
#dor .pc-txt {
  font-size: 14px; color: var(--muted);
  line-height: 1.65; display: block !important;
}

/* ══════════════ APRENDA (CONTEÚDO) ══════════════ */
#aprenda {
  background: var(--bg);
  padding: 80px 60px;
}
#aprenda h2, #aprenda .rv:is(h2) {
  font-family: 'Syne', sans-serif !important;
  font-size: clamp(32px, 3.5vw, 50px) !important;
  font-weight: 800 !important; letter-spacing: -.025em;
  line-height: 1.08 !important; color: var(--text) !important;
  margin-bottom: 12px; display: block !important;
}
#aprenda h2 em, #aprenda .rv:is(h2) em { font-style: normal; color: var(--blue); }
#aprenda .ap-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 64px !important; align-items: start;
  margin-top: 52px;
}
/* Left side */
#aprenda .ap-sticky > p {
  font-size: 16px !important; color: var(--muted) !important;
  line-height: 1.75 !important; display: block !important;
  margin-bottom: 36px;
}
#aprenda .stat-pair {
  display: flex; gap: 32px; margin-bottom: 36px;
}
#aprenda .stat {
  display: flex; flex-direction: column;
}
#aprenda .stat-n {
  font-family: 'Syne', sans-serif;
  font-size: 42px; font-weight: 800; line-height: 1;
  color: var(--blue); margin-bottom: 4px;
  display: block !important;
}
#aprenda .stat-d {
  font-size: 13px; color: var(--muted);
  line-height: 1.4; display: block !important;
}
#aprenda .insight {
  background: rgba(29,135,235,.08);
  border: 1px solid rgba(29,135,235,.2);
  border-radius: 12px; padding: 20px 22px;
}
#aprenda .ins-lbl {
  font-family: 'DM Mono', monospace;
  font-size: 9px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--blue); margin-bottom: 8px; display: block !important;
}
#aprenda .ins-txt {
  font-size: 14px; color: var(--muted); line-height: 1.6;
  display: block !important;
}
/* Right side — items list */
#aprenda .ap-item {
  display: flex !important; gap: 20px; align-items: flex-start;
  padding: 22px 0; border-bottom: 1px solid var(--border);
}
#aprenda .ap-item:last-child { border-bottom: none; }
#aprenda .ap-n {
  font-family: 'DM Mono', monospace;
  font-size: 11px; font-weight: 700; color: var(--blue);
  letter-spacing: .08em; min-width: 28px; padding-top: 2px;
  display: block !important;
}
#aprenda .ap-body { flex: 1; }
#aprenda .ap-tag {
  font-family: 'DM Mono', monospace;
  font-size: 9px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--green); margin-bottom: 5px;
  display: block !important;
}
#aprenda .ap-ttl {
  font-size: 15px; font-weight: 600; color: var(--text);
  margin-bottom: 5px; display: block !important;
}
#aprenda .ap-txt {
  font-size: 13px; color: var(--muted); line-height: 1.6;
  display: block !important;
}

/* ══════════════ QUEM (PARA QUEM) ══════════════ */
#quem {
  background: var(--bg2);
  padding: 80px 60px;
}
#quem h2, #quem .rv:is(h2) {
  font-family: 'Syne', sans-serif !important;
  font-size: clamp(28px, 3vw, 44px) !important;
  font-weight: 800 !important; letter-spacing: -.025em;
  color: var(--text) !important; margin-bottom: 10px;
  display: block !important;
}
#quem h2 em, #quem .rv:is(h2) em { font-style: normal; color: var(--green); }
#quem .rv:is(p) {
  font-size: 16px; color: var(--muted); line-height: 1.7;
  margin-bottom: 48px; display: block !important;
}
#quem .qg {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 16px !important;
}
#quem .qc {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px; padding: 26px 22px;
  transition: border-color .2s, transform .2s;
  display: block !important;
}
#quem .qc:hover { border-color: rgba(29,135,235,.3) !important; transform: translateY(-3px); }
#quem .qc-ico {
  width: 42px; height: 42px; border-radius: 10px;
  background: rgba(29,135,235,.1); border: 1px solid rgba(29,135,235,.2);
  display: flex !important; align-items: center; justify-content: center;
  margin-bottom: 16px; font-size: 19px;
}
#quem .qc-role {
  font-family: 'DM Mono', monospace;
  font-size: 10px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--blue);
  margin-bottom: 9px; display: block !important;
}
#quem .qc-desc {
  font-size: 14px; color: var(--muted);
  line-height: 1.65; display: block !important;
}

/* ══════════════ CTA FINAL ══════════════ */
#cta {
  background: var(--bg);
  padding: 100px 60px;
  text-align: center;
  position: relative; overflow: hidden;
}
#cta::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(60% 50% at 50% 80%, rgba(29,135,235,.1) 0%, transparent 65%),
    radial-gradient(40% 40% at 50% 20%, rgba(134,220,94,.05) 0%, transparent 60%);
}
#cta .cta-inner {
  max-width: 720px; margin: 0 auto;
  position: relative; z-index: 1;
}
#cta .ey { justify-content: center; margin-bottom: 20px; }
#cta .cta-big {
  font-family: 'Syne', sans-serif !important;
  font-size: clamp(32px, 4vw, 52px) !important;
  font-weight: 800 !important; letter-spacing: -.03em !important;
  line-height: 1.08 !important; color: var(--text) !important;
  margin-bottom: 20px;
  display: block !important; visibility: visible !important; opacity: 1 !important;
}
#cta .cta-big em { font-style: normal; color: var(--blue); }
#cta .cta-desc {
  font-size: 17px !important; color: var(--muted) !important;
  line-height: 1.75 !important; margin-bottom: 44px !important;
  display: block !important; visibility: visible !important; opacity: 1 !important;
}
#cta .cta-btn-wrap {
  display: flex !important; justify-content: center;
}
/* Botão — tanto dentro do cta-btn-wrap quanto no <p> solto */
#cta .cta-inscricao-btn,
#cta > p > .cta-inscricao-btn,
#cta .cta-inner > p > .cta-inscricao-btn {
  display: inline-flex !important; align-items: center; gap: 10px;
  background: var(--blue) !important; color: #fff !important;
  font-size: 16px !important; font-weight: 700 !important;
  padding: 18px 44px !important; border-radius: 10px !important;
  text-decoration: none !important;
  box-shadow: 0 8px 32px rgba(29,135,235,.35) !important;
  transition: opacity .2s, transform .15s, box-shadow .2s;
  margin-top: 8px;
}
#cta .cta-inscricao-btn:hover,
#cta > p > .cta-inscricao-btn:hover {
  opacity: .9; transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(29,135,235,.45) !important;
}
/* Esconder o segundo formulário Elementor (duplicado) */
.elementor-element-0912c9f { display: none !important; }

/* fw1 — formulário Elementor real, dentro do card unificado */
#op3lp #fw1 {
  position: static !important;
  left: auto !important;
  top: auto !important;
  width: 100% !important;
  height: auto !important;
  overflow: visible !important;
  pointer-events: auto !important;
  padding: 0 32px 28px !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
}

/* form-wrap: só o header, sem borda própria — o hero-right é o card */
#op3lp .form-wrap {
  padding: 32px 32px 0 32px !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  backdrop-filter: none !important;
}
#op3lp .form-wrap::before { display: none !important; }

/* hero-right: É O CARD — compacto, alinhado ao topo */
#op3lp .hero-right {
  display: block !important;
  background: rgba(10,22,40,0.85) !important;
  backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(29,135,235,.25) !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  position: relative;
  align-self: center !important;
  height: fit-content !important;
  margin-top: 0;
  padding: 0 !important;
}
/* Linha colorida no topo do card (substitui o ::before do form-wrap) */
#op3lp .hero-right::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, #1D87EB, #86DC5E);
  z-index: 3;
}

/* Garantia extra: cta-big e cta-desc sempre visíveis */
#cta .cta-big, #cta .cta-desc {
  display: block !important; opacity: 1 !important; visibility: visible !important;
}


/* ═══════════════════════════════════════════════════════════════
   PATCH — Hero título + Aprenda steps
   ═══════════════════════════════════════════════════════════════ */

/* HERO — reduz font-size para o título não quebrar em 3 linhas */
#op3lp #hero .hh {
  font-size: clamp(38px, 4.2vw, 58px) !important;
  line-height: 1.06 !important;
  letter-spacing: -.03em !important;
}
/* Remove o <br> inline forçando quebra de "mais" — via word-spacing melhorado */
#op3lp #hero .hh br { display: inline !important; content: ' '; }

/* APRENDA — Steps do lado direito */
#aprenda .steps {
  display: flex; flex-direction: column;
  gap: 0;
}
#aprenda .step {
  display: flex !important;
  gap: 20px;
  padding: 22px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.07) !important;
  align-items: flex-start;
  transition: background .15s;
}
#aprenda .step:last-child { border-bottom: none !important; }
#aprenda .step > p:not([class]) { display: none !important; }

/* Número do step */
#aprenda .st-n {
  font-family: 'DM Mono', monospace !important;
  font-size: 11px !important; font-weight: 700 !important;
  letter-spacing: .1em !important;
  color: var(--blue, #1D87EB) !important;
  min-width: 28px; padding-top: 3px;
  display: block !important;
  flex-shrink: 0;
}

/* Div interna sem classe — o "body" do step */
#aprenda .step > div:not(.st-n) {
  flex: 1;
}

/* Tag label (Contexto, Pilar Inform, etc.) */
#aprenda .step > div:not(.st-n) > p:not([class]) {
  display: inline-block !important;
  font-family: 'DM Mono', monospace;
  font-size: 9px !important; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--green, #86DC5E) !important;
  margin-bottom: 6px;
  background: rgba(134,220,94,.08);
  border: 1px solid rgba(134,220,94,.2);
  border-radius: 20px; padding: 3px 10px;
}

/* Título do step */
#aprenda .st-ttl {
  font-size: 14px !important; font-weight: 600 !important;
  color: var(--text, #E8F2ED) !important;
  line-height: 1.4; margin-bottom: 5px;
  display: block !important;
}

/* Descrição do step */
#aprenda .st-txt {
  font-size: 13px !important;
  color: var(--muted, rgba(200,220,240,.75)) !important;
  line-height: 1.6; display: block !important;
}
