/* ───────────────────────────────────────────────────────────────────────
   sharp-demo.css — estilos do Modo Demo (overlay do tour + paginas
   de entrada/fim). Carregar DEPOIS de sharp-cyber.css (usa os tokens).
─────────────────────────────────────────────────────────────────────── */

/* ─── PAGINA DE INTRO / FIM ─── */
.demo-intro, .demo-end { max-width: 960px; }
.demo-intro-title {
  font-size: clamp(30px, 4.6vw, 52px);
  font-weight: 700; line-height: 1.06;
  color: var(--text); margin: 8px 0 16px;
  text-wrap: pretty;
}
.demo-intro-sub {
  font-size: 16px; color: var(--mid);
  line-height: 1.6; max-width: 560px; margin-bottom: 28px;
}

.demo-notrial { padding: 18px 20px; border-left: 2px solid var(--b3); }
.demo-notrial-label {
  font-size: 10px; letter-spacing: 2px;
  color: var(--red); margin-bottom: 8px;
}
.demo-notrial p { font-size: 13px; color: var(--mid); line-height: 1.6; }

.demo-prev-label { margin-bottom: 14px !important; }
.demo-prev-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 8px; margin-bottom: 24px;
}
.demo-prev-step { display: flex; gap: 14px; padding: 14px 16px; align-items: flex-start; }
.demo-prev-num {
  font-size: 22px; color: var(--red); opacity: .55;
  line-height: 1; flex-shrink: 0;
}
.demo-prev-title { font-size: 14px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.demo-prev-helper { font-size: 10px; line-height: 1.5; }

.demo-disclaimer { margin-bottom: 24px; }

.demo-intro-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ─── ECRA FINAL ─── */
.demo-end-cards {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 12px; margin-bottom: 20px;
}
.demo-end-card { padding: 24px; display: flex; flex-direction: column; }
.demo-end-founder { border-color: var(--b2); background: rgba(255,69,0,.03); }
.demo-end-kicker { font-size: 9px; letter-spacing: 2px; color: var(--red); margin-bottom: 10px; }
.demo-end-title { font-size: 20px; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.demo-end-copy { font-size: 13px; color: var(--mid); line-height: 1.6; margin-bottom: 18px; flex: 1; }
.demo-end-replay { display: flex; justify-content: center; }

/* ─── BADGE DEMO (slot na topbar dos ecras do tour) ─── */
.demo-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 8px; cursor: pointer;
  border: 1px solid var(--b3);
  background: rgba(255,69,0,.08);
}
.demo-badge .mono { font-size: 9px; letter-spacing: 2px; color: var(--red); }
.demo-badge-dot {
  width: 6px; height: 6px; background: var(--red);
  border-radius: 50%; animation: demo-pulse 1.6s ease-in-out infinite;
}
.demo-badge-close { font-size: 12px; color: var(--dim); }
.demo-badge:hover .demo-badge-close { color: var(--text); }
@keyframes demo-pulse { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

/* ─── OVERLAY DO TOUR (painel fixo no fundo) ─── */
.demo-overlay {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 250;
  background: var(--s1);
  border-top: 1px solid var(--b3);
  box-shadow: 0 -8px 32px rgba(0,0,0,.5);
}
.demo-overlay-inner {
  max-width: 1100px; margin: 0 auto;
  padding: 14px 24px 16px;
}
.demo-overlay-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.demo-progress { display: flex; gap: 6px; }
.demo-progress-dot {
  width: 28px; height: 4px; padding: 0;
  background: var(--s2); border: 1px solid var(--b1);
  cursor: pointer; transition: background .15s, border-color .15s;
}
.demo-progress-dot.done { background: var(--b3); border-color: var(--b3); }
.demo-progress-dot.active { background: var(--red); border-color: var(--red); }
.demo-overlay-skip {
  font-size: 9px; letter-spacing: 2px;
  background: none; border: 1px solid var(--b2);
  color: var(--dim); padding: 4px 10px; cursor: pointer;
}
.demo-overlay-skip:hover { border-color: var(--b3); color: var(--text); }

.demo-overlay-body { margin-bottom: 12px; }
.demo-step-meta { font-size: 9px; letter-spacing: 1.5px; margin-bottom: 6px; }
.demo-step-title { font-size: 18px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.demo-step-body { font-size: 13px; color: var(--mid); line-height: 1.6; max-width: 720px; }
.demo-step-helper { font-size: 10px; line-height: 1.5; margin-top: 6px; }

.demo-overlay-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
}
.demo-data-note { font-size: 9px; letter-spacing: 1px; text-align: center; flex: 1; }
.demo-btn-prev:disabled { opacity: .35; cursor: not-allowed; }

/* o conteudo do tour nao fica escondido atras do overlay */
body.demo-tour-active { padding-bottom: 200px; }

@media (max-width: 768px) {
  .demo-end-cards { grid-template-columns: 1fr; }
  .demo-overlay-inner { padding: 12px 16px 14px; }
  .demo-overlay-foot { flex-wrap: wrap; }
  .demo-data-note { order: 3; width: 100%; flex: none; }
  body.demo-tour-active { padding-bottom: 280px; }
}
