/* ============================================================
   OMEO — BARBEARIA & SALÕES
   ============================================================ */

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

  --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-accent:  linear-gradient(135deg,#00E58F 0%,#4E64BA 100%);

  --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,body { height:100%; width:100%; overflow:hidden; }
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;
}
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:.35;
  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); }
}

/* ----- DECK & SLIDES ----- */
.deck { position:relative; z-index:1; width:100%; height:100vh; 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 ----- */
.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;
}
.hl-grad {
  background:linear-gradient(135deg,#00E58F 0%,#8B00F5 60%,#FF7A1A 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ============================================================
   SLIDE 1 - CAPA
   ============================================================ */
.slide--cover { align-items:center; }
.cover-stage { text-align:center; max-width:980px; margin:0 auto; }
.cover-logo { margin-bottom:28px; }
.cover-logo img { height:52px; width:auto; }
.cover-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Space Grotesk',sans-serif;
  font-size:13px; letter-spacing:.18em; color:#fff;
  text-transform:uppercase; margin-bottom:20px;
  background:var(--grad-primary); padding:8px 20px;
  border-radius:100px;
}
.cover-title {
  font-family:'Space Grotesk','Inter',sans-serif;
  font-size:clamp(40px,6vw,84px);
  font-weight:900; line-height:.95; letter-spacing:-.03em;
  text-transform:uppercase; margin-bottom:28px;
}
.title-line {
  display:block; opacity:0; transform:translateY(20px);
  animation:titleIn .8s var(--ease) forwards;
}
.title-line:nth-child(1) { animation-delay:.2s; }
.title-line:nth-child(2) { animation-delay:.4s; }
.title-line:nth-child(3) { animation-delay:.6s; }
.title-line--accent {
  background:var(--grad-primary); -webkit-background-clip:text; background-clip:text; color:transparent;
}
@keyframes titleIn { to { opacity:1; transform:translateY(0); } }
.cover-sub {
  font-size:clamp(15px,1.4vw,19px); color:var(--text-muted);
  max-width:600px; margin:0 auto 36px; line-height:1.5;
}
.cover-stats {
  display:inline-flex; align-items:center; gap:0;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-xl); padding:20px 36px; margin-bottom:36px;
}
.cs-item { text-align:center; padding:0 28px; }
.cs-val {
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(28px,3vw,40px); font-weight:900;
  background:var(--grad-primary); -webkit-background-clip:text; background-clip:text; color:transparent;
  line-height:1; margin-bottom:6px;
}
.cs-label { font-size:12px; color:var(--text-muted); letter-spacing:.05em; text-transform:uppercase; }
.cs-sep { width:1px; height:48px; background:var(--border); flex-shrink:0; }
.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 - CENÁRIO
   ============================================================ */
.silence-stage {
  display:grid; grid-template-columns:1.1fr 1fr; gap:28px; align-items:start;
}
.silence-hero {
  background:linear-gradient(150deg,rgba(139,0,245,.18),rgba(255,122,26,.08));
  border:1px solid rgba(139,0,245,.3);
  border-radius:var(--radius-xl); padding:44px 30px 32px;
  position:relative; overflow:hidden;
}
.silence-hero::before {
  content:''; position:absolute; top:-80px; right:-80px;
  width:240px; height:240px;
  background:radial-gradient(circle,rgba(255,122,26,.25),transparent 65%);
  filter:blur(40px);
}
.silence-big-num { display:flex; flex-direction:column; align-items:flex-start; margin-bottom:18px; position:relative; z-index:1; }
.sbn-prefix { font-size:13px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--text-muted); }
.sbn-value {
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(96px,12vw,160px); font-weight:900; line-height:1; letter-spacing:-.05em;
  background:linear-gradient(135deg,#FF7A1A 0%,#8B00F5 60%,#4E64BA 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.sbn-value small { font-size:.45em; }
.sbn-label { font-size:16px; font-weight:600; color:var(--text-muted); margin-top:4px; }
.silence-explain { font-size:14px; color:var(--text-muted); line-height:1.6; margin-bottom:18px; position:relative; z-index:1; }
.silence-explain strong { color:var(--text); }
.silence-tag {
  display:flex; align-items:flex-start; gap:10px; padding:14px 18px;
  background:rgba(255,122,26,.1); border:1px solid rgba(255,122,26,.25);
  border-radius:var(--radius); font-size:13px; color:var(--text-muted);
  position:relative; z-index:1;
}
.silence-tag i { color:#FF7A1A; margin-top:2px; flex-shrink:0; font-size:14px; }
.silence-pains { display:flex; flex-direction:column; gap:12px; }
.pain-card--mini {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); padding:18px 20px;
  transition:border-color .2s, box-shadow .2s;
}
.pain-card--mini:hover {
  border-color:rgba(139,0,245,.4);
  box-shadow:0 0 24px -8px rgba(139,0,245,.2);
}
.pain-card--mini h3 { font-size:14px; font-weight:700; margin-bottom:6px; }
.pain-card--mini h3 em { font-style:normal; color:var(--accent); }
.pain-card--mini p { font-size:13px; color:var(--text-muted); line-height:1.5; }
.pain-icon { font-size:18px; color:var(--primary-soft); margin-bottom:8px; }

/* ============================================================
   SLIDE 3 - ORB / INTRO
   ============================================================ */
.intro-stage {
  display:grid; grid-template-columns:1fr 1.4fr; gap:48px; align-items:center;
}
/* ORB */
.intro-orb-wrap { display:flex; align-items:center; justify-content:center; }
.intro-orb {
  position:relative; width:260px; height:260px;
  display:flex; align-items:center; justify-content:center;
}
.intro-orb-core {
  width:100px; height:100px; border-radius:50%;
  background:var(--grad-primary);
  box-shadow:var(--shadow-glow);
  display:flex; align-items:center; justify-content:center;
  font-size:40px; color:#fff;
  z-index:2; position:relative;
  animation:orbPulse 3s ease-in-out infinite;
}
@keyframes orbPulse {
  0%,100% { transform:scale(1); box-shadow:0 0 60px -10px rgba(139,0,245,.6); }
  50% { transform:scale(1.06); box-shadow:0 0 100px -10px rgba(139,0,245,.9); }
}
.orb-ring {
  position:absolute; border-radius:50%; border:1px solid;
  animation:ringExpand 3s ease-in-out infinite;
}
.orb-ring--1 { width:140px; height:140px; border-color:rgba(139,0,245,.5); animation-delay:0s; }
.orb-ring--2 { width:190px; height:190px; border-color:rgba(78,100,186,.4); animation-delay:.5s; }
.orb-ring--3 { width:240px; height:240px; border-color:rgba(0,229,143,.2); animation-delay:1s; }
@keyframes ringExpand {
  0%,100% { opacity:.6; transform:scale(1); }
  50% { opacity:1; transform:scale(1.04); }
}
.orb-particle {
  position:absolute; width:8px; height:8px; border-radius:50%;
  background:var(--accent); opacity:.8;
  animation:particleOrbit 6s linear infinite;
  transform-origin:0 0;
}
.orb-particle { animation-delay:calc(var(--i) * -1s); }
@keyframes particleOrbit {
  from { transform:rotate(calc(var(--i) * 60deg)) translateX(120px) scale(1); opacity:.8; }
  50%  { opacity:.4; }
  to   { transform:rotate(calc(var(--i) * 60deg + 360deg)) translateX(120px) scale(1); opacity:.8; }
}
/* INTRO COPY */
.intro-copy {}
.intro-lead { font-size:clamp(15px,1.3vw,18px); line-height:1.7; margin-bottom:24px; }
.intro-lead strong { color:var(--primary-soft); }
.intro-bullets { display:flex; flex-direction:column; gap:12px; margin-bottom:24px; }
.intro-bullets li {
  display:flex; align-items:flex-start; gap:12px;
  font-size:14px; color:var(--text-muted); line-height:1.5;
}
.intro-bullets li i { color:var(--accent); margin-top:2px; flex-shrink:0; }
.intro-bullets li span { color:var(--text); }
.intro-tag {
  display:flex; align-items:flex-start; gap:10px; padding:14px 18px;
  background:rgba(139,0,245,.1); border:1px solid rgba(139,0,245,.25);
  border-radius:var(--radius); font-size:13px; color:var(--text-muted);
}
.intro-tag i { color:var(--primary-soft); margin-top:2px; flex-shrink:0; }

/* ============================================================
   SLIDE 4 - PIPELINE GAMIFICADO
   ============================================================ */
.sophia-pipeline {
  display:flex; align-items:center; justify-content:center;
  flex-wrap:nowrap; gap:0; margin-bottom:32px;
  overflow-x:auto; padding:12px 0;
}
.sp-step {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  padding:18px 14px; min-width:110px;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg);
  transition:border-color .2s, box-shadow .2s, transform .2s;
  cursor:pointer;
}
.sp-step:hover {
  border-color:rgba(139,0,245,.5);
  box-shadow:0 0 28px -8px rgba(139,0,245,.3);
  transform:translateY(-2px);
}
.sp-step--final { border-color:rgba(0,229,143,.4); }
.sp-step--final .sp-icon { background:rgba(0,229,143,.15); color:var(--accent); }
.sp-icon {
  width:48px; height:48px; border-radius:14px;
  background:rgba(139,0,245,.15); color:var(--primary-soft);
  display:flex; align-items:center; justify-content:center; font-size:20px;
}
.sp-name { font-size:13px; font-weight:700; text-align:center; }
.sp-desc { font-size:11px; color:var(--text-dim); text-align:center; letter-spacing:.02em; }
.sp-line {
  width:40px; height:2px; background:var(--border-strong);
  position:relative; flex-shrink:0;
}
.sp-pulse {
  position:absolute; top:50%; left:0;
  width:10px; height:10px; border-radius:50%;
  background:var(--primary-soft);
  transform:translateY(-50%);
  animation:pulseMove 2s ease-in-out infinite;
  box-shadow:0 0 12px rgba(139,0,245,.8);
}
@keyframes pulseMove {
  0%   { left:0;   opacity:0; }
  20%  { opacity:1; }
  80%  { opacity:1; }
  100% { left:calc(100% - 10px); opacity:0; }
}
.pipeline-compare {
  display:flex; align-items:center; justify-content:center; gap:20px;
  padding:20px 28px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius-lg);
}
.pc-item { font-size:14px; color:var(--text-muted); flex:1; text-align:center; }
.pc-item strong { color:var(--text); }
.pc-item--accent strong { color:var(--accent); }
.pc-arrow { color:var(--primary-soft); font-size:18px; flex-shrink:0; }

/* ============================================================
   SLIDE 5 - CHAT + FEATURES
   ============================================================ */
.conv-layout {
  display:grid; grid-template-columns:1.1fr 1fr; gap:32px; align-items:start;
}
.conv-features { display:flex; flex-direction:column; gap:20px; }
.conv-feat {
  display:flex; align-items:flex-start; gap:16px;
  padding:18px 20px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius);
  transition:border-color .2s;
}
.conv-feat:hover { border-color:rgba(139,0,245,.35); }
.cf-icon {
  width:40px; height:40px; border-radius:10px; flex-shrink:0;
  background:rgba(139,0,245,.15); color:var(--primary-soft);
  display:flex; align-items:center; justify-content:center; font-size:16px;
}
.conv-feat h4 { font-size:14px; font-weight:700; margin-bottom:4px; }
.conv-feat p { font-size:13px; color:var(--text-muted); line-height:1.5; }
/* Chat mock */
.chat-mock {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-xl); overflow:hidden;
}
.chat-mock-head {
  display:flex; align-items:center; gap:12px;
  padding:14px 18px; border-bottom:1px solid var(--border);
  background:var(--bg-card-2);
}
.cm-avatar {
  width:38px; height:38px; border-radius:50%;
  background:var(--grad-primary);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:#fff; flex-shrink:0;
}
.cm-name { font-size:14px; font-weight:700; }
.cm-status { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--text-muted); }
.dot-online { width:8px; height:8px; border-radius:50%; background:var(--accent); flex-shrink:0; animation:dotBlink 2s ease-in-out infinite; }
@keyframes dotBlink { 0%,100% { opacity:1; } 50% { opacity:.4; } }
.chat-mock-body { padding:18px; display:flex; flex-direction:column; gap:10px; min-height:240px; }
.bubble {
  max-width:80%; padding:10px 14px; border-radius:18px;
  font-size:13px; line-height:1.5;
  opacity:0; transform:translateY(8px);
  animation:bubbleIn .4s var(--ease) forwards;
}
.bubble--in {
  background:rgba(255,255,255,.06); border:1px solid var(--border);
  border-bottom-left-radius:4px; align-self:flex-start;
}
.bubble--out {
  background:var(--grad-primary); color:#fff;
  border-bottom-right-radius:4px; align-self:flex-end;
}
.bubble--typing {
  display:flex; gap:4px; align-items:center; padding:14px 18px;
}
.bubble--typing span {
  width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.6);
  animation:typingDot .8s ease-in-out infinite;
}
.bubble--typing span:nth-child(2) { animation-delay:.15s; }
.bubble--typing span:nth-child(3) { animation-delay:.3s; }
@keyframes typingDot { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-4px); } }
@keyframes bubbleIn { to { opacity:1; transform:translateY(0); } }

/* ============================================================
   SLIDE 6 - DASHBOARD
   ============================================================ */
.dashboard-mock {
  display:grid; grid-template-columns:180px 1fr; gap:0;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-xl); overflow:hidden;
  min-height:360px;
}
.dm-sidebar {
  background:var(--bg-card-2); border-right:1px solid var(--border);
  padding:18px 0; display:flex; flex-direction:column; gap:4px;
}
.dm-logo {
  display:flex; align-items:center; gap:8px;
  padding:0 16px 16px; font-family:'Space Grotesk',sans-serif;
  font-size:15px; font-weight:700; border-bottom:1px solid var(--border);
  margin-bottom:8px;
}
.dm-nav-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 16px; font-size:13px; color:var(--text-muted);
  cursor:pointer; border-radius:0;
  transition:background .15s, color .15s;
}
.dm-nav-item:hover { background:rgba(255,255,255,.04); color:var(--text); }
.dm-nav-item.active { background:rgba(139,0,245,.15); color:var(--primary-soft); }
.dm-hint {
  margin-top:auto; padding:12px 16px;
  font-size:11px; color:var(--text-dim);
  display:flex; align-items:center; gap:6px;
}
.dm-main { padding:18px; overflow:hidden; }
.dm-view { display:none; flex-direction:column; gap:14px; }
.dm-view.is-active { display:flex; }
.dm-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:4px; }
.dm-title { font-size:15px; font-weight:700; }
.dm-actions { display:flex; align-items:center; gap:8px; }
.dm-chip {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; font-size:12px;
  background:rgba(255,255,255,.05); border:1px solid var(--border);
  border-radius:100px; color:var(--text-muted); cursor:pointer;
  transition:background .15s;
}
.dm-chip.is-on { background:rgba(139,0,245,.2); border-color:rgba(139,0,245,.4); color:var(--primary-soft); }
.dm-chip--toggle { cursor:pointer; }
.dm-cards { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.dm-card {
  background:var(--bg-card-2); border:1px solid var(--border);
  border-radius:var(--radius); padding:12px 14px;
}
.dm-card-label { font-size:11px; color:var(--text-dim); text-transform:uppercase; letter-spacing:.05em; margin-bottom:6px; }
.dm-card-value { font-family:'Space Grotesk',sans-serif; font-size:clamp(20px,2vw,28px); font-weight:800; line-height:1; margin-bottom:6px; }
.dm-card-trend { display:flex; align-items:center; gap:5px; font-size:11px; }
.dm-card-trend.up { color:var(--accent); }
.dm-card-trend.warn { color:#FF7A1A; }
.dm-chart { background:var(--bg-card-2); border:1px solid var(--border); border-radius:var(--radius); padding:14px; }
.dm-chart-head { font-size:12px; color:var(--text-dim); margin-bottom:12px; }
.dm-bars { display:flex; align-items:flex-end; gap:6px; height:70px; }
.dm-bar {
  flex:1; height:var(--h); background:rgba(139,0,245,.4);
  border-radius:4px 4px 0 0;
  position:relative; display:flex; align-items:flex-end; justify-content:center;
  transition:background .2s;
}
.dm-bar--accent { background:rgba(139,0,245,.8); }
.dm-bar:hover { background:rgba(139,0,245,.7); }
.dm-bar span { font-size:10px; color:var(--text-dim); padding-bottom:2px; position:absolute; bottom:-16px; }
/* Calendar */
.dm-cal-day { font-size:12px; color:var(--text-dim); margin-bottom:10px; }
.dm-cal-list { display:flex; flex-direction:column; gap:8px; }
.dm-cal-event {
  display:flex; align-items:center; gap:10px;
  background:var(--bg-card-2); border:1px solid var(--border);
  border-radius:var(--radius); padding:10px 14px;
}
.dm-cal-time { font-size:13px; font-weight:700; color:var(--text-muted); min-width:42px; }
.dm-cal-bar { width:3px; height:36px; background:var(--c,var(--primary)); border-radius:2px; flex-shrink:0; }
.dm-cal-info { flex:1; }
.dm-cal-info strong { font-size:13px; display:block; }
.dm-cal-info span { font-size:11px; color:var(--text-dim); display:flex; align-items:center; gap:4px; margin-top:2px; }
.dm-cal-tag {
  font-size:11px; padding:4px 10px; border-radius:100px;
  background:rgba(255,255,255,.06); border:1px solid var(--border); color:var(--text-muted);
}
.dm-cal-tag.ok { background:rgba(0,229,143,.12); border-color:rgba(0,229,143,.3); color:var(--accent); }
.dm-cal-tag.warn { background:rgba(255,122,26,.12); border-color:rgba(255,122,26,.3); color:#FF7A1A; }
/* Kanban */
.dm-kanban { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.dm-col-head {
  display:flex; align-items:center; justify-content:space-between;
  font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.06em;
  color:var(--text-muted); margin-bottom:8px;
}
.dm-col-count {
  font-size:12px; padding:2px 8px; border-radius:100px;
  background:rgba(255,255,255,.06); color:var(--text-dim);
}
.dm-kcard {
  background:var(--bg-card-2); border:1px solid var(--border);
  border-radius:10px; padding:10px 12px; margin-bottom:6px;
}
.dm-kcard-ok { border-color:rgba(0,229,143,.3); }
.dm-kcard-name { font-size:13px; font-weight:600; }
.dm-kcard-meta { font-size:11px; color:var(--text-dim); margin-top:3px; display:flex; align-items:center; gap:4px; }
.dm-kcard-warn { color:#FF7A1A; }
/* Reviews */
.dm-reviews { display:flex; flex-direction:column; gap:10px; }
.dm-review {
  background:var(--bg-card-2); border:1px solid var(--border);
  border-radius:var(--radius); padding:14px;
}
.dm-review-stars { color:#FFD600; font-size:13px; margin-bottom:6px; }
.dm-review-text { font-size:13px; color:var(--text-muted); line-height:1.5; margin-bottom:6px; font-style:italic; }
.dm-review-author { font-size:11px; color:var(--text-dim); }

/* ============================================================
   SLIDE 7 - PLANOS
   ============================================================ */
.plans-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px;
}
.plan-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-xl); padding:24px 22px;
  display:flex; flex-direction:column; gap:0;
  position:relative; transition:border-color .2s, box-shadow .2s;
}
.plan-card:hover { border-color:rgba(139,0,245,.4); box-shadow:var(--shadow-card); }
.plan-card--highlight {
  border-color:rgba(139,0,245,.6);
  background:linear-gradient(160deg,rgba(139,0,245,.12),rgba(78,100,186,.08));
  box-shadow:var(--shadow-card);
}
.plan-card--full { border-color:rgba(78,100,186,.4); }
.plan-badge-rec {
  position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-soft) 100%);
  color:#1a0d00;
  font-size:11px; font-weight:800; padding:4px 14px;
  border-radius:100px; white-space:nowrap; letter-spacing:.05em;
  box-shadow:0 4px 14px -4px rgba(232,185,35,.5);
}
.plan-name {
  font-family:'Space Grotesk',sans-serif;
  font-size:16px; font-weight:700; margin-bottom:10px; margin-top:10px;
}
.plan-card--highlight .plan-name { color:var(--primary-soft); }
.plan-price { display:flex; align-items:flex-end; gap:3px; margin-bottom:6px; }
.plan-currency { font-size:16px; font-weight:700; color:var(--text-muted); margin-bottom:6px; }
.plan-value { font-family:'Space Grotesk',sans-serif; font-size:clamp(28px,2.8vw,38px); font-weight:900; line-height:1; }
.plan-card--highlight .plan-value { background:var(--grad-primary); -webkit-background-clip:text; background-clip:text; color:transparent; }
.plan-period { font-size:13px; color:var(--text-muted); margin-bottom:4px; }
.plan-tagline { font-size:12px; color:var(--text-muted); line-height:1.5; margin-bottom:12px; }
.plan-limit { font-size:12px; color:var(--text-dim); margin-bottom:18px; padding-bottom:18px; border-bottom:1px solid var(--border); }
.plan-features { display:flex; flex-direction:column; gap:9px; flex:1; margin-bottom:20px; }
.plan-features li { display:flex; align-items:flex-start; gap:8px; font-size:13px; color:var(--text-muted); line-height:1.4; }
.plan-features li i { margin-top:2px; font-size:12px; flex-shrink:0; }
.plan-features li:not(.feat--off) i { color:var(--accent); }
.feat--off { opacity:.45; }
.feat--off i { color:var(--text-dim) !important; }
.plan-cta {
  display:flex; align-items:center; justify-content:center;
  padding:11px 18px; border-radius:var(--radius);
  font-size:13px; font-weight:700; transition:all .2s;
  text-align:center; cursor:pointer;
}
.plan-cta--primary {
  background:var(--grad-primary); color:#fff;
  box-shadow:0 8px 24px -8px rgba(139,0,245,.5);
}
.plan-cta--primary:hover { box-shadow:0 12px 32px -8px rgba(139,0,245,.7); transform:translateY(-1px); }
.plan-cta--ghost {
  border:1px solid var(--border); color:var(--text-muted);
}
.plan-cta--ghost:hover { border-color:rgba(139,0,245,.4); color:var(--text); }
.plans-foot {
  display:flex; align-items:center; gap:10px;
  padding:14px 20px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius);
  font-size:13px; color:var(--text-muted);
}
.plans-foot i { color:var(--primary-soft); flex-shrink:0; }

/* ============================================================
   SLIDE 8 - CTA
   ============================================================ */
.cta-demo {
  display:flex; align-items:center; gap:20px;
  padding:24px 28px; margin:0 auto 32px;
  background:linear-gradient(135deg,rgba(139,0,245,.15),rgba(78,100,186,.08));
  border:1px solid rgba(139,0,245,.4);
  border-radius:var(--radius-xl);
  max-width:740px;
  transition:box-shadow .2s, border-color .2s, transform .2s;
  cursor:pointer;
}
.cta-demo:hover {
  box-shadow:var(--shadow-card); border-color:rgba(139,0,245,.7); transform:translateY(-2px);
}
.cta-demo-icon {
  width:64px; height:64px; border-radius:18px;
  background:var(--grad-primary); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:28px; flex-shrink:0;
}
.cta-demo-text { flex:1; }
.cta-demo-eyebrow { font-size:11px; letter-spacing:.18em; color:var(--primary-soft); text-transform:uppercase; margin-bottom:4px; }
.cta-demo-text h3 { font-size:18px; font-weight:800; margin-bottom:4px; }
.cta-demo-text p { font-size:13px; color:var(--text-muted); }
.cta-demo-arrow { color:var(--primary-soft); font-size:22px; flex-shrink:0; }
.cta-roadmap {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:32px;
}
.cta-step { display:flex; align-items:flex-start; gap:14px; }
.cs-num {
  width:36px; height:36px; border-radius:10px; flex-shrink:0;
  background:var(--grad-primary); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-family:'Space Grotesk',sans-serif; font-size:16px; font-weight:800;
}
.cs-content h4 { font-size:14px; font-weight:700; margin-bottom:4px; }
.cs-content p { font-size:13px; color:var(--text-muted); line-height:1.5; }
.cta-final { display:flex; flex-direction:column; align-items:center; gap:16px; }
.cta-final-logo img { height:52px; width:auto; opacity:.9; }
.cta-actions { display:flex; align-items:center; gap:12px; }
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 24px; border-radius:var(--radius);
  font-size:14px; font-weight:700; transition:all .2s;
}
.btn--primary { background:var(--grad-primary); color:#fff; box-shadow:0 8px 24px -8px rgba(139,0,245,.5); }
.btn--primary:hover { box-shadow:0 12px 32px -8px rgba(139,0,245,.7); transform:translateY(-1px); }
.btn--ghost { border:1px solid var(--border); color:var(--text-muted); }
.btn--ghost:hover { border-color:var(--border-strong); color:var(--text); }
.cta-signature { font-size:12px; color:var(--text-dim); text-align:center; }

/* ============================================================
   NAV
   ============================================================ */
.deck-nav {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%);
  display:flex; align-items:center; gap:14px;
  background:rgba(14,19,22,.92); backdrop-filter:blur(20px);
  border:1px solid var(--border); border-radius:100px;
  padding:8px 16px; z-index:100;
}
.nav-btn {
  width:36px; height:36px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.06); color:var(--text-muted);
  transition:background .15s, color .15s;
}
.nav-btn:hover:not(:disabled) { background:rgba(139,0,245,.2); color:var(--primary-soft); }
.nav-btn:disabled { opacity:.3; cursor:default; }
.nav-progress { display:flex; align-items:center; gap:10px; }
.np-track { width:80px; height:3px; background:var(--border-strong); border-radius:2px; }
.np-fill { height:100%; background:var(--grad-primary); border-radius:2px; transition:width .4s var(--ease); }
.np-counter { font-size:13px; color:var(--text-muted); min-width:32px; text-align:center; }

/* ============================================================
   MODAL
   ============================================================ */
.modal {
  position:fixed; inset:0; z-index:200;
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden;
  transition:opacity .3s, visibility .3s;
}
.modal.is-open { opacity:1; visibility:visible; }
.modal-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.7); backdrop-filter:blur(6px); }
.modal-panel {
  position:relative; z-index:1;
  width:min(540px,92vw); max-height:80vh; overflow-y:auto;
  background:var(--bg-card); border:1px solid var(--border-strong);
  border-radius:var(--radius-xl); padding:32px;
  transform:translateY(20px) scale(.97);
  transition:transform .3s var(--ease);
}
.modal.is-open .modal-panel { transform:translateY(0) scale(1); }
.modal-close {
  position:absolute; top:14px; right:14px;
  width:32px; height:32px; border-radius:8px;
  background:rgba(255,255,255,.06); color:var(--text-muted);
  display:flex; align-items:center; justify-content:center;
  transition:background .15s;
}
.modal-close:hover { background:rgba(255,255,255,.12); }
.mc-head { display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.mc-icon {
  width:48px; height:48px; border-radius:14px; flex-shrink:0;
  background:var(--grad-primary); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:20px;
}
.mc-title { font-size:18px; font-weight:800; }
.mc-role { font-size:13px; color:var(--text-muted); }
.mc-section { margin-bottom:18px; }
.mc-section h4 { font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--primary-soft); margin-bottom:10px; }
.mc-section p { font-size:14px; color:var(--text-muted); line-height:1.6; }
.mc-list { display:flex; flex-direction:column; gap:10px; }
.mc-list li { display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--text-muted); }
.mc-list li i { color:var(--accent); margin-top:2px; flex-shrink:0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* iOS safe area */
@supports (padding: env(safe-area-inset-bottom)) {
  .deck-nav { bottom: calc(24px + env(safe-area-inset-bottom)); }
  .slide { padding-bottom: calc(110px + env(safe-area-inset-bottom)); }
}

@media (max-width: 900px) {
  /* align-items:flex-start evita conteudo cortado no topo em telas menores */
  .slide { padding:32px 24px 90px; align-items:flex-start; }
  .slide--cover { align-items:center; }
  .silence-stage,
  .intro-stage,
  .conv-layout { grid-template-columns:1fr; }
  .intro-orb-wrap { display:none; }
  .plans-grid { grid-template-columns:repeat(2,1fr); }
  .dm-cards { grid-template-columns:repeat(2,1fr); }
  .sophia-pipeline { gap:0; justify-content:flex-start; }
  .sp-step { min-width:90px; padding:12px 10px; }
  .sp-line { width:28px; }
  .cover-stats { padding:14px 18px; }
  .cs-item { padding:0 14px; }
  .cta-roadmap { grid-template-columns:repeat(2,1fr); }
}

@media (max-width: 600px) {
  .slide { padding:20px 16px 90px; align-items:flex-start; }
  .slide--cover { align-items:flex-start; justify-content:flex-start; padding-top:28px; }

  /* Typography */
  .cover-title { font-size:clamp(26px,8vw,52px); line-height:1; }
  .sbn-value { font-size:clamp(56px,14vw,100px); }

  /* Cover stats - empilha verticalmente em telas pequenas */
  .cover-stats { flex-direction:column; gap:0; padding:14px 20px; }
  .cs-sep { width:60%; height:1px; margin:10px auto; align-self:center; }
  .cs-item { padding:4px 0; }

  /* Grids */
  .plans-grid { grid-template-columns:1fr; }
  .cta-roadmap { grid-template-columns:1fr; }
  .dashboard-mock { grid-template-columns:1fr; }
  .dm-kanban { grid-template-columns:repeat(2,1fr); }
  .dm-sidebar { display:none; }

  /* Pipeline - scroll horizontal */
  .sophia-pipeline { overflow-x:auto; padding-bottom:6px; }

  /* CTA final */
  .cta-demo { flex-direction:column; text-align:center; padding:18px; gap:12px; }
  .cta-demo-arrow { display:none; }
  .cta-actions { flex-direction:column; align-items:stretch; }
  .btn { justify-content:center; }

  /* Plan cards */
  .plan-card { padding:18px 16px; }
}

@media (max-width: 390px) {
  .slide { padding:16px 14px 80px; }
  .cover-title { font-size:clamp(22px,7.5vw,42px); }
  .dm-cards { grid-template-columns:1fr; }
  .dm-kanban { grid-template-columns:1fr; }
}
