/* ============================================================
   OMEO — POS-VENDA (overview slides + wizard universal)
   ============================================================ */

/* ----- TOKENS ----- */
:root {
  --primary:       #8B00F5;
  --primary-soft:  #A93BFF;
  --secondary:     #4E64BA;
  --accent:        #00E58F;
  --accent-warm:   #FF7A1A;
  --gold:          #E8B923;
  --gold-soft:     #FBDB74;

  --tier-starter:      #99A5D6;
  --tier-essence:      #D39CC8;
  --tier-professional: #FBDB74;
  --tier-fullstack:    #A8CCA3;

  --bg:        #07090A;
  --bg-card:   #0E1316;
  --bg-card-2: #131A1F;
  --bg-elev:   #182026;
  --border:    rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.16);

  --text:      #F4F6F7;
  --text-muted:#98A1A8;
  --text-dim:  #6B747C;

  --grad-primary: linear-gradient(135deg,#8B00F5 0%,#4E64BA 100%);
  --grad-soft:    linear-gradient(160deg,rgba(139,0,245,.18),rgba(78,100,186,.06));

  --shadow-card: 0 18px 60px -20px rgba(139,0,245,.25),0 6px 20px -8px rgba(0,0,0,.4);
  --shadow-glow: 0 0 80px -10px rgba(139,0,245,.4);

  --radius-sm: 8px;
  --radius:    14px;
  --radius-lg: 22px;
  --radius-xl: 32px;
  --ease:      cubic-bezier(0.22,1,0.36,1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { height:100%; }
body {
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
  height:100%;
}
button { font-family:inherit; background:none; border:none; cursor:pointer; color:inherit; }
a { color:inherit; text-decoration:none; }
ul,ol { list-style:none; }

/* ----- AMBIENT BACKGROUND ----- */
.ambient-bg {
  position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden;
}
.ambient-orb {
  position:absolute; border-radius:50%;
  filter:blur(120px); opacity:.3;
  animation:orbFloat 18s ease-in-out infinite;
}
.ambient-orb--1 {
  width:700px; height:700px;
  background:radial-gradient(circle,var(--primary) 0%,transparent 70%);
  top:-200px; right:-150px;
}
.ambient-orb--2 {
  width:600px; height:600px;
  background:radial-gradient(circle,var(--secondary) 0%,transparent 70%);
  bottom:-200px; left:-150px;
  animation-delay:-9s;
}
.ambient-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);
}
@keyframes orbFloat {
  0%,100% { transform:translate(0,0) scale(1); }
  50% { transform:translate(40px,-30px) scale(1.1); }
}

/* ============================================================
   MODO A — DECK DE SLIDES
   ============================================================ */
.mode-slides { position:relative; z-index:1; width:100%; height:100vh; overflow:hidden; }
.mode-slides.is-hidden { display:none; }

.deck { width:100%; height:100%; overflow:hidden; }
.slide {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  padding:64px 72px 110px;
  opacity:0; visibility:hidden;
  transform:translateX(40px);
  transition:opacity .5s var(--ease),transform .6s var(--ease),visibility .5s;
  overflow-y:auto; overflow-x:hidden;
}
.slide.is-active { opacity:1; visibility:visible; transform:translateX(0); }
.slide.is-prev  { transform:translateX(-40px); }
.slide-inner { width:100%; max-width:1280px; margin:0 auto; }
.slide::-webkit-scrollbar { width:6px; }
.slide::-webkit-scrollbar-track { background:transparent; }
.slide::-webkit-scrollbar-thumb { background:var(--border-strong); border-radius:3px; }

/* ----- Tipografia compartilhada ----- */
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Space Grotesk',sans-serif;
  font-size:12px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:var(--primary-soft);
  padding:6px 12px;
  background:rgba(139,0,245,.12);
  border:1px solid rgba(139,0,245,.3);
  border-radius:100px; margin-bottom:18px;
}
.slide-head { margin-bottom:32px; }
.slide-head--center { text-align:center; }
.slide-title {
  font-family:'Space Grotesk','Inter',sans-serif;
  font-size:clamp(28px,3.8vw,52px);
  font-weight:900; letter-spacing:-.02em; line-height:1.05;
  text-transform:uppercase; margin-bottom:12px;
}
.slide-title--big { font-size:clamp(36px,5vw,68px); }
.slide-lead {
  font-size:clamp(14px,1.2vw,17px); color:var(--text-muted); max-width:760px; line-height:1.6;
}
.slide-head--center .slide-lead { margin:0 auto; }
.hl {
  background:var(--grad-primary);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ----- SLIDE 1: HERO ----- */
.slide--hero { align-items:center; }
.hero-stage { text-align:center; max-width:880px; margin:0 auto; }
.hero-logos {
  display:flex; align-items:center; justify-content:center; gap:20px; margin-bottom:28px;
}
.hero-logos img { height:48px; width:auto; }
.hero-sep { width:1px; height:36px; background:var(--border-strong); }
.tier-badge {
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Space Grotesk',sans-serif;
  font-size:12px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  padding:6px 16px; border-radius:100px;
  margin-bottom:22px;
}
.tier-badge--starter { background:rgba(153,165,214,.15); border:1px solid rgba(153,165,214,.4); color:var(--tier-starter); }
.tier-badge--essence { background:rgba(211,156,200,.15); border:1px solid rgba(211,156,200,.4); color:var(--tier-essence); }
.tier-badge--professional { background:rgba(251,219,116,.15); border:1px solid rgba(251,219,116,.4); color:var(--tier-professional); }
.tier-badge--fullstack { background:rgba(168,204,163,.15); border:1px solid rgba(168,204,163,.4); color:var(--tier-fullstack); }
.hero-title {
  font-family:'Space Grotesk','Inter',sans-serif;
  font-size:clamp(36px,5.5vw,72px);
  font-weight:900; line-height:.95; letter-spacing:-.03em;
  text-transform:uppercase; margin-bottom:20px;
}
.hero-title .line { display:block; }
.hero-title .line--grad {
  background:var(--grad-primary);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-sub {
  font-size:clamp(14px,1.3vw,18px); color:var(--text-muted);
  max-width:560px; margin:0 auto 36px; line-height:1.55;
}
.hero-ready-chip {
  display:inline-flex; align-items:center; gap:10px;
  background:rgba(0,229,143,.1); border:1px solid rgba(0,229,143,.3);
  border-radius:100px; padding:10px 20px;
  font-size:13px; font-weight:600; color:var(--accent);
  margin-bottom:32px;
}
.hero-ready-dot {
  width:8px; height:8px; border-radius:50%; background:var(--accent);
  animation:dotBlink 2s ease-in-out infinite;
}
@keyframes dotBlink { 0%,100% { opacity:1; } 50% { opacity:.3; } }
.scroll-hint {
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; color:var(--text-dim); letter-spacing:.05em; text-transform:uppercase;
  animation:hintPulse 2s ease-in-out infinite;
}
@keyframes hintPulse { 0%,100% { opacity:.6; } 50% { opacity:1; } }

/* ----- SLIDE 2: PILARES ----- */
.pillars-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
.pillar-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:24px 20px;
  transition:border-color .2s, box-shadow .2s, transform .2s;
}
.pillar-card:hover {
  border-color:rgba(139,0,245,.4);
  box-shadow:0 0 28px -8px rgba(139,0,245,.25);
  transform:translateY(-2px);
}
.pillar-icon {
  width:44px; height:44px; border-radius:12px;
  background:rgba(139,0,245,.15); color:var(--primary-soft);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; margin-bottom:14px;
}
.pillar-card h3 { font-size:15px; font-weight:700; margin-bottom:6px; }
.pillar-card p { font-size:13px; color:var(--text-muted); line-height:1.55; }

/* ----- SLIDE 3: INFORMACOES ----- */
.info-layout { display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:start; }
.info-block { display:flex; flex-direction:column; gap:12px; }
.info-block-title {
  font-family:'Space Grotesk',sans-serif;
  font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--text-dim); padding-bottom:10px; border-bottom:1px solid var(--border);
}
.info-item {
  display:flex; align-items:flex-start; gap:12px;
  padding:14px 16px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius);
}
.info-item-icon {
  width:34px; height:34px; border-radius:8px; flex-shrink:0;
  background:rgba(139,0,245,.12); color:var(--primary-soft);
  display:flex; align-items:center; justify-content:center; font-size:14px;
}
.info-item h4 { font-size:13px; font-weight:700; margin-bottom:3px; }
.info-item p { font-size:12px; color:var(--text-muted); line-height:1.5; }

/* ----- SLIDES CONDICIONAIS: MODULOS ----- */
.module-layout { display:grid; grid-template-columns:1fr 1.2fr; gap:32px; align-items:center; }
.module-steps { display:flex; flex-direction:column; gap:14px; }
.mstep {
  display:flex; align-items:flex-start; gap:14px;
  padding:16px 18px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius);
  transition:border-color .2s;
}
.mstep:hover { border-color:rgba(139,0,245,.35); }
.mstep-num {
  width:28px; height:28px; border-radius:50%; flex-shrink:0;
  background:rgba(139,0,245,.15); color:var(--primary-soft);
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700;
}
.mstep h4 { font-size:13px; font-weight:700; margin-bottom:4px; }
.mstep p { font-size:12px; color:var(--text-muted); line-height:1.5; }
.module-visual {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-xl); padding:28px;
}
.chat-mock-head {
  display:flex; align-items:center; gap:12px;
  padding:14px 18px; border-bottom:1px solid var(--border);
  background:var(--bg-card-2); border-radius:var(--radius) var(--radius) 0 0;
  margin:-28px -28px 18px;
}
.cm-avatar {
  width:36px; height:36px; border-radius:50%;
  background:var(--grad-primary);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; color:#fff; flex-shrink:0;
}
.cm-name { font-size:13px; font-weight:700; }
.cm-status { display:flex; align-items:center; gap:5px; font-size:11px; color:var(--text-muted); }
.dot-online { width:7px; height:7px; border-radius:50%; background:var(--accent); flex-shrink:0; animation:dotBlink 2s ease-in-out infinite; }
.chat-bubbles { display:flex; flex-direction:column; gap:8px; }
.bubble {
  max-width:82%; padding:10px 14px; border-radius:16px;
  font-size:12px; line-height:1.5;
}
.bubble--in {
  background:rgba(255,255,255,.06); border:1px solid var(--border);
  border-radius:4px 16px 16px 16px; align-self:flex-start;
}
.bubble--out {
  background:var(--grad-primary);
  border-radius:16px 16px 4px 16px; align-self:flex-end; color:#fff;
}
.bubble--sys {
  align-self:center; background:rgba(0,229,143,.1);
  border:1px solid rgba(0,229,143,.25); color:var(--accent);
  font-size:11px; padding:6px 12px; border-radius:100px;
}

/* funil horizontal */
.funnel-h {
  display:flex; align-items:center; gap:0; overflow-x:auto;
  padding:8px 0; margin-bottom:24px;
}
.funnel-step {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  padding:14px 12px; min-width:100px;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); flex-shrink:0;
  transition:border-color .2s, transform .2s;
}
.funnel-step:hover { border-color:rgba(139,0,245,.4); transform:translateY(-2px); }
.funnel-step--done .funnel-icon { background:rgba(0,229,143,.15); color:var(--accent); }
.funnel-icon {
  width:40px; height:40px; border-radius:10px;
  background:rgba(139,0,245,.12); color:var(--primary-soft);
  display:flex; align-items:center; justify-content:center; font-size:16px;
}
.funnel-label { font-size:11px; font-weight:700; text-align:center; letter-spacing:.02em; }
.funnel-desc { font-size:10px; color:var(--text-dim); text-align:center; }
.funnel-arrow { color:var(--border-strong); font-size:14px; flex-shrink:0; padding:0 4px; }

/* feature list */
.feat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.feat-item {
  display:flex; align-items:flex-start; gap:12px;
  padding:14px 16px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius);
}
.feat-item i { color:var(--primary-soft); margin-top:2px; flex-shrink:0; }
.feat-item h4 { font-size:13px; font-weight:700; margin-bottom:3px; }
.feat-item p { font-size:12px; color:var(--text-muted); line-height:1.5; }

/* ----- SLIDE DASHBOARD ----- */
.dash-layout { display:grid; grid-template-columns:200px 1fr; gap:0; border:1px solid var(--border); border-radius:var(--radius-xl); overflow:hidden; background:var(--bg-card); }
.dash-sidebar { background:var(--bg-card-2); border-right:1px solid var(--border); padding:16px 0; }
.dash-nav-item {
  display:flex; align-items:center; gap:10px;
  padding:10px 18px; font-size:13px; color:var(--text-muted);
  cursor:pointer; transition:all .15s;
}
.dash-nav-item i { width:16px; text-align:center; flex-shrink:0; }
.dash-nav-item:hover, .dash-nav-item.is-active {
  color:var(--text); background:rgba(139,0,245,.1);
}
.dash-nav-item.is-active { border-left:2px solid var(--primary); }
.dash-main { padding:20px 24px; overflow:hidden; }
.dash-view { display:none; }
.dash-view.is-active { display:block; }
.dash-kpi-row { display:flex; gap:12px; margin-bottom:16px; }
.kpi-card {
  flex:1; background:var(--bg-elev); border:1px solid var(--border);
  border-radius:var(--radius); padding:14px;
}
.kpi-val {
  font-family:'Space Grotesk',sans-serif;
  font-size:24px; font-weight:900;
  background:var(--grad-primary); -webkit-background-clip:text; background-clip:text; color:transparent;
  line-height:1; margin-bottom:4px;
}
.kpi-label { font-size:11px; color:var(--text-muted); letter-spacing:.04em; text-transform:uppercase; }
.kanban-mini { display:flex; gap:10px; }
.kanban-col { flex:1; }
.kanban-col-head { font-size:11px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--text-muted); margin-bottom:8px; }
.kanban-card-mini {
  background:var(--bg-elev); border:1px solid var(--border);
  border-radius:8px; padding:10px 12px; margin-bottom:8px; font-size:12px;
}
.kanban-card-mini .kc-name { font-weight:700; margin-bottom:2px; }
.kanban-card-mini .kc-sub { color:var(--text-muted); }

/* ----- SLIDE PLANOS ----- */
.tier-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.tier-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:20px 16px;
  opacity:.6; transition:all .2s;
}
.tier-card.is-active {
  border-color:var(--primary);
  box-shadow:0 0 32px -8px rgba(139,0,245,.4);
  opacity:1;
  transform:translateY(-4px);
}
.tier-card.is-active .tier-name { color:var(--primary-soft); }
.tier-name {
  font-family:'Space Grotesk',sans-serif;
  font-size:14px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  margin-bottom:4px;
}
.tier-sub { font-size:11px; color:var(--text-muted); margin-bottom:14px; }
.tier-feat-list { display:flex; flex-direction:column; gap:7px; }
.tier-feat {
  display:flex; align-items:center; gap:8px;
  font-size:12px; color:var(--text-muted);
}
.tier-feat i.on { color:var(--accent); }
.tier-feat i.off { color:var(--text-dim); opacity:.5; }
.tier-feat.is-included { color:var(--text); }
.tier-badge-owned {
  display:inline-flex; align-items:center; gap:6px;
  font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:4px 10px; border-radius:100px; margin-bottom:14px;
}

/* ----- SLIDE CTA ----- */
.cta-stage { text-align:center; max-width:740px; margin:0 auto; }
.cta-btn-primary {
  display:inline-flex; align-items:center; gap:12px;
  background:var(--grad-primary);
  color:#fff; font-family:'Space Grotesk',sans-serif;
  font-size:16px; font-weight:700; letter-spacing:.02em;
  padding:18px 40px; border-radius:100px;
  transition:transform .2s, box-shadow .2s; cursor:pointer;
  border:none;
}
.cta-btn-primary:hover { transform:translateY(-2px); box-shadow:0 12px 40px -8px rgba(139,0,245,.5); }
.cta-next-steps {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:32px;
}
.cta-ns {
  display:flex; align-items:flex-start; gap:12px;
  padding:18px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius);
  text-align:left;
}
.cta-ns-num {
  width:28px; height:28px; border-radius:50%; flex-shrink:0;
  background:rgba(139,0,245,.15); color:var(--primary-soft);
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700;
}
.cta-ns h4 { font-size:13px; font-weight:700; margin-bottom:4px; }
.cta-ns p { font-size:12px; color:var(--text-muted); line-height:1.5; }

/* ----- NAVEGAÇÃO SLIDES ----- */
.nav-bar {
  position:fixed; bottom:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 32px;
  background:linear-gradient(0deg,rgba(7,9,10,.95) 0%,rgba(7,9,10,.6) 100%);
  backdrop-filter:blur(12px);
}
.nav-btn {
  display:flex; align-items:center; gap:8px;
  padding:10px 20px; border-radius:100px;
  font-size:13px; font-weight:600;
  transition:all .2s; cursor:pointer;
}
.nav-btn--prev {
  background:rgba(255,255,255,.06);
  border:1px solid var(--border); color:var(--text-muted);
}
.nav-btn--prev:hover { color:var(--text); border-color:var(--border-strong); }
.nav-btn--next {
  background:var(--grad-primary); color:#fff; border:none;
}
.nav-btn--next:hover { transform:translateY(-1px); box-shadow:0 8px 24px -6px rgba(139,0,245,.5); }
.nav-dots { display:flex; align-items:center; gap:6px; }
.nav-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--border-strong);
  transition:all .25s;
}
.nav-dot.is-active { width:22px; border-radius:4px; background:var(--primary-soft); }
.slide-counter { font-size:12px; color:var(--text-dim); min-width:40px; text-align:center; }

/* ============================================================
   MODO B — WIZARD DE SETUP
   ============================================================ */
.mode-wizard {
  position:fixed; inset:0; z-index:200;
  background:var(--bg);
  overflow-y:auto; overflow-x:hidden;
  display:none;
}
.mode-wizard.is-open { display:block; }

.wiz-wrap { max-width:820px; margin:0 auto; padding:48px 32px 80px; position:relative; z-index:1; }

/* stepper */
.wiz-stepper {
  display:flex; align-items:center; gap:0; margin-bottom:40px;
  overflow-x:auto; padding-bottom:4px;
}
.wiz-stepper::-webkit-scrollbar { height:4px; }
.wiz-stepper::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }
.ws-item {
  display:flex; align-items:center; gap:0; flex-shrink:0;
}
.ws-dot {
  width:32px; height:32px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700;
  background:var(--bg-card); border:1px solid var(--border); color:var(--text-dim);
  transition:all .25s;
}
.ws-dot.is-done { background:var(--primary); border-color:var(--primary); color:#fff; }
.ws-dot.is-active { border-color:var(--primary); color:var(--primary-soft); box-shadow:0 0 16px -4px rgba(139,0,245,.5); }
.ws-label {
  font-size:11px; color:var(--text-dim); white-space:nowrap;
  margin:0 6px; letter-spacing:.03em;
  transition:color .25s;
}
.ws-label.is-active { color:var(--text); }
.ws-line { width:32px; height:1px; background:var(--border); flex-shrink:0; }
.ws-line.is-done { background:var(--primary); }

/* steps */
.wiz-step { display:none; }
.wiz-step.is-active { display:block; }

.wiz-step-head { margin-bottom:32px; }
.wiz-step-title {
  font-family:'Space Grotesk','Inter',sans-serif;
  font-size:clamp(22px,2.5vw,32px);
  font-weight:900; letter-spacing:-.02em; text-transform:uppercase; margin-bottom:8px;
}
.wiz-step-desc { font-size:14px; color:var(--text-muted); line-height:1.6; }

/* form elements */
.form-section { margin-bottom:28px; }
.form-section-title {
  font-family:'Space Grotesk',sans-serif;
  font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--text-dim); padding-bottom:10px; border-bottom:1px solid var(--border);
  margin-bottom:16px;
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-row--3 { grid-template-columns:1fr 1fr 1fr; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group--full { grid-column:1/-1; }
label {
  font-size:12px; font-weight:700; letter-spacing:.04em;
  color:var(--text-muted);
}
label .req { color:var(--primary-soft); margin-left:3px; }
input[type=text], input[type=email], input[type=tel], input[type=number],
input[type=time], textarea, select {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:10px 14px;
  color:var(--text); font-family:inherit; font-size:14px;
  width:100%; transition:border-color .2s, box-shadow .2s;
  outline:none;
}
input:focus, textarea:focus, select:focus {
  border-color:rgba(139,0,245,.5);
  box-shadow:0 0 0 3px rgba(139,0,245,.12);
}
input::placeholder, textarea::placeholder { color:var(--text-dim); }
textarea { resize:vertical; min-height:88px; }
select { cursor:pointer; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2398A1A8' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }

/* radio/checkbox custom */
.radio-group, .check-group { display:flex; flex-wrap:wrap; gap:8px; }
.radio-option, .check-option {
  display:flex; align-items:center; gap:8px;
  padding:8px 14px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  cursor:pointer; font-size:13px; transition:all .15s;
  user-select:none;
}
.radio-option:hover, .check-option:hover { border-color:rgba(139,0,245,.4); }
.radio-option input, .check-option input { display:none; }
.radio-option.is-selected, .check-option.is-checked {
  border-color:rgba(139,0,245,.6);
  background:rgba(139,0,245,.1); color:var(--text);
}
.radio-option i, .check-option i { color:var(--text-dim); font-size:13px; }
.radio-option.is-selected i, .check-option.is-checked i { color:var(--primary-soft); }

/* toggle */
.toggle-group { display:flex; flex-direction:column; gap:10px; }
.toggle-item {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius);
}
.toggle-item-info h4 { font-size:13px; font-weight:700; margin-bottom:3px; }
.toggle-item-info p { font-size:12px; color:var(--text-muted); }
.toggle-switch {
  width:44px; height:24px; border-radius:12px;
  background:var(--bg-elev); border:1px solid var(--border);
  position:relative; cursor:pointer; transition:all .2s; flex-shrink:0;
}
.toggle-switch::after {
  content:''; position:absolute; top:3px; left:3px;
  width:16px; height:16px; border-radius:50%;
  background:var(--text-dim); transition:all .2s;
}
.toggle-switch.is-on { background:rgba(139,0,245,.3); border-color:var(--primary); }
.toggle-switch.is-on::after { background:var(--primary-soft); transform:translateX(20px); }

/* schedule builder */
.schedule-builder { display:flex; flex-direction:column; gap:8px; }
.sched-row {
  display:flex; align-items:center; gap:12px;
  padding:10px 14px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius-sm);
}
.sched-day {
  width:80px; font-size:12px; font-weight:700;
  color:var(--text-muted); flex-shrink:0;
}
.sched-toggle {
  width:36px; height:20px; border-radius:10px;
  background:var(--bg-elev); border:1px solid var(--border);
  position:relative; cursor:pointer; flex-shrink:0; transition:all .2s;
}
.sched-toggle::after {
  content:''; position:absolute; top:2px; left:2px;
  width:14px; height:14px; border-radius:50%;
  background:var(--text-dim); transition:all .2s;
}
.sched-toggle.is-on { background:rgba(139,0,245,.25); border-color:var(--primary); }
.sched-toggle.is-on::after { background:var(--primary-soft); transform:translateX(16px); }
.sched-times {
  display:flex; align-items:center; gap:8px; flex:1;
}
.sched-times input[type=time] {
  flex:1; max-width:110px; padding:6px 10px; font-size:13px;
}
.sched-times span { font-size:12px; color:var(--text-dim); }
.sched-closed { font-size:12px; color:var(--text-dim); display:none; }
.sched-row:not(.is-open) .sched-times { display:none; }
.sched-row:not(.is-open) .sched-closed { display:block; }

/* add-list (profissionais, lojas, perguntas) */
.add-list { display:flex; flex-direction:column; gap:12px; }
.add-item {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
}
.add-item-head {
  display:flex; align-items:center; gap:12px;
  padding:12px 16px; cursor:pointer;
  transition:background .15s;
}
.add-item-head:hover { background:rgba(255,255,255,.03); }
.add-item-num {
  width:26px; height:26px; border-radius:50%; flex-shrink:0;
  background:rgba(139,0,245,.15); color:var(--primary-soft);
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700;
}
.add-item-name { flex:1; font-size:13px; font-weight:700; }
.add-item-toggle { font-size:12px; color:var(--text-dim); transition:transform .2s; }
.add-item.is-open .add-item-toggle { transform:rotate(180deg); }
.add-item-body { padding:16px; border-top:1px solid var(--border); display:none; }
.add-item.is-open .add-item-body { display:block; }
.add-item-body .form-group { margin-bottom:12px; }
.add-item-remove {
  color:rgba(255,80,80,.6); font-size:12px; cursor:pointer;
  transition:color .15s;
}
.add-item-remove:hover { color:rgba(255,80,80,1); }
.btn-add-item {
  display:flex; align-items:center; gap:8px;
  padding:10px 16px;
  background:rgba(139,0,245,.08); border:1px dashed rgba(139,0,245,.3);
  border-radius:var(--radius); color:var(--primary-soft);
  font-size:13px; font-weight:600; cursor:pointer;
  transition:all .2s;
}
.btn-add-item:hover { background:rgba(139,0,245,.15); border-style:solid; }

/* ----- REVISÃO ----- */
.review-area {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:24px; margin-bottom:24px;
  font-size:13px; line-height:1.7; color:var(--text-muted);
  white-space:pre-wrap; max-height:320px; overflow-y:auto;
}
.review-area strong { color:var(--text); }
.review-actions { display:flex; gap:12px; flex-wrap:wrap; }

/* wizard footer nav */
.wiz-footer {
  display:flex; align-items:center; justify-content:space-between;
  margin-top:40px; padding-top:24px; border-top:1px solid var(--border);
}
.wiz-btn {
  display:flex; align-items:center; gap:8px;
  padding:12px 24px; border-radius:100px;
  font-size:14px; font-weight:700; cursor:pointer;
  transition:all .2s;
}
.wiz-btn--prev {
  background:rgba(255,255,255,.06);
  border:1px solid var(--border); color:var(--text-muted);
}
.wiz-btn--prev:hover { color:var(--text); border-color:var(--border-strong); }
.wiz-btn--next {
  background:var(--grad-primary); color:#fff; border:none;
}
.wiz-btn--next:hover { transform:translateY(-1px); box-shadow:0 8px 24px -6px rgba(139,0,245,.5); }
.wiz-btn--submit {
  background:linear-gradient(135deg,#00E58F 0%,#4E64BA 100%);
  color:#fff; border:none;
}
.wiz-btn--submit:hover { transform:translateY(-1px); box-shadow:0 8px 24px -6px rgba(0,229,143,.4); }
.wiz-btn--action {
  background:var(--bg-card); border:1px solid var(--border);
  color:var(--text-muted); font-size:13px;
}
.wiz-btn--action:hover { border-color:var(--border-strong); color:var(--text); }

/* submit status */
#submit-status { font-size:13px; color:var(--text-muted); }
#submit-success {
  display:none; text-align:center; padding:32px;
}
#submit-success .success-icon { font-size:48px; color:var(--accent); margin-bottom:16px; }
#submit-success h3 {
  font-family:'Space Grotesk',sans-serif;
  font-size:24px; font-weight:900; margin-bottom:10px;
}
#submit-success p { font-size:14px; color:var(--text-muted); max-width:420px; margin:0 auto; line-height:1.6; }

/* ----- RESPONSIVO ----- */
@media (max-width:900px) {
  .slide { padding:40px 28px 100px; }
  .pillars-grid { grid-template-columns:1fr 1fr; }
  .module-layout { grid-template-columns:1fr; }
  .module-visual { display:none; }
  .tier-grid { grid-template-columns:1fr 1fr; }
  .cta-next-steps { grid-template-columns:1fr; }
  .info-layout { grid-template-columns:1fr; }
  .feat-grid { grid-template-columns:1fr; }
  .dash-layout { grid-template-columns:1fr; }
  .dash-sidebar { display:none; }
}
@media (max-width:600px) {
  .pillars-grid { grid-template-columns:1fr; }
  .tier-grid { grid-template-columns:1fr 1fr; }
  .form-row { grid-template-columns:1fr; }
  .form-row--3 { grid-template-columns:1fr; }
  .nav-bar { padding:12px 16px; }
  .wiz-wrap { padding:32px 16px 60px; }
}

/* ============================================================
   ELEMENTOS GERADOS PELO JS
   ============================================================ */

/* ----- BARRA DE PROGRESSO GLOBAL ----- */
.global-progress {
  position:fixed; top:0; left:0; right:0; z-index:999;
  height:3px; background:rgba(255,255,255,.06);
}
.gp-bar {
  height:100%; width:0%;
  background:var(--grad-primary);
  transition:width .6s var(--ease);
  border-radius:0 2px 2px 0;
}

/* ----- MÓDULOS DESBLOQUEADOS (hero) ----- */
.unlocked-modules {
  display:flex; flex-direction:column; align-items:center; gap:10px;
  margin-top:24px;
}
.um-label {
  font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--accent); display:flex; align-items:center; gap:6px;
}
.um-chips { display:flex; flex-wrap:wrap; justify-content:center; gap:7px; }
.um-chip {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 14px; border-radius:100px;
  background:rgba(0,229,143,.1); border:1px solid rgba(0,229,143,.25);
  color:var(--accent); font-size:12px; font-weight:600;
  animation:chipIn .4s var(--ease) both;
}
.um-chip i { font-size:10px; }
@keyframes chipIn { from { opacity:0; transform:scale(.8); } to { opacity:1; transform:scale(1); } }

/* ----- UNLOCK BADGE (eyebrow em slides condicionais) ----- */
.eyebrow.unlock-badge {
  background:rgba(0,229,143,.1);
  border-color:rgba(0,229,143,.3);
  color:var(--accent);
}

/* ----- CONFIG READINESS (slide CTA) ----- */
.config-readiness {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:20px 24px;
  margin-bottom:32px; text-align:left;
}
.cr-label {
  font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--text-dim); margin-bottom:14px;
}
.cr-items { display:flex; flex-wrap:wrap; gap:10px; }
.cr-item {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px; border-radius:100px;
  background:rgba(139,0,245,.08); border:1px solid rgba(139,0,245,.2);
  font-size:12px; font-weight:600; color:var(--text-muted);
}
.cr-item i { color:var(--primary-soft); font-size:11px; }

/* ----- WELCOME CHECKLIST ----- */
.welcome-checklist {
  display:flex; flex-direction:column; gap:10px;
  max-width:480px; margin:0 auto 28px;
}
.wc-item {
  display:flex; align-items:center; gap:12px;
  padding:12px 16px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius);
  font-size:14px;
}
.wc-item i { color:var(--accent); font-size:16px; flex-shrink:0; }
.save-note {
  display:flex; align-items:center; justify-content:center; gap:8px;
  font-size:12px; color:var(--text-dim);
  padding:12px; background:rgba(255,255,255,.03);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  max-width:420px; margin:0 auto;
}
.save-note i { color:var(--primary-soft); }

/* ----- WIZARD STEPPER GRUPO ----- */
.ws-group {
  display:flex; flex-direction:column; align-items:center; gap:4px; flex-shrink:0;
}

/* ----- TIER CARD CONTEÚDO (gerado pelo JS) ----- */
.tier-card-head { /* wrapper gerado inline */ }
.tier-active-badge {
  display:inline-flex; align-items:center;
  font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:4px 10px; border-radius:100px; margin-bottom:8px;
}
.tier-price {
  font-family:'Space Grotesk',sans-serif;
  font-size:20px; font-weight:900; margin-bottom:4px;
}
.tier-features {
  list-style:none; display:flex; flex-direction:column; gap:7px; padding:0; margin:0;
}
.tier-features li {
  display:flex; align-items:center; gap:8px;
  font-size:12px; color:var(--text-muted); line-height:1.4;
}
.tier-features li i { font-size:10px; flex-shrink:0; }

/* ----- REVISÃO (gerado pelo JS) ----- */
.review-area { white-space:normal; } /* override pre-wrap — conteúdo é HTML */
.review-section { margin-bottom:18px; }
.review-section-title {
  font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--text-dim); margin-bottom:8px;
  padding-bottom:6px; border-bottom:1px solid var(--border);
}
.review-row {
  display:flex; align-items:flex-start; justify-content:space-between; gap:16px;
  padding:6px 0; border-bottom:1px solid rgba(255,255,255,.03);
  font-size:13px;
}
.review-key { color:var(--text-dim); flex-shrink:0; min-width:140px; }
.review-val { color:var(--text); text-align:right; word-break:break-word; }

/* ----- ADD-ITEM body sempre visível ----- */
.add-item.is-open .add-item-body { display:block; }
.add-item-remove {
  margin-left:auto; color:rgba(255,80,80,.5); cursor:pointer;
  transition:color .15s; padding:4px 6px;
}
.add-item-remove:hover { color:rgba(255,80,80,1); }
