/* ═══════════════════════════════════════════════
   TUTORIAL
   ═══════════════════════════════════════════════ */
.tut-ov{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);align-items:center;justify-content:center}
.tut-ov.active{display:flex}
.tut-card{background:#fff;border-radius:22px;padding:2.2rem;width:90%;max-width:480px;box-shadow:var(--shadow-lg);text-align:center;animation:tutIn .35s ease-out}
@keyframes tutIn{from{opacity:0;transform:translateY(25px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.tut-prog{display:flex;gap:5px;justify-content:center;margin-bottom:1.3rem}
.tut-dot{width:7px;height:7px;border-radius:50%;background:var(--border);transition:all .3s}
.tut-dot.active{background:var(--primary);width:22px;border-radius:4px}
.tut-ill{width:180px;height:140px;margin:0 auto 1.2rem;position:relative}
.tut-card h2{font-family:'Outfit',sans-serif;font-size:1.25rem;font-weight:800;margin-bottom:.5rem}
.tut-card p{font-size:.88rem;color:var(--text-sec);line-height:1.5;margin-bottom:1.3rem}
.tut-acts{display:flex;gap:.7rem;justify-content:center}

.tut-phone{width:80px;height:125px;background:#1a2e22;border-radius:12px;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);box-shadow:var(--shadow-md);overflow:hidden;display:flex;flex-direction:column;align-items:center;padding-top:8px}
.tut-phone-scr{width:66px;height:98px;background:#fff;border-radius:7px;display:flex;flex-direction:column;padding:5px;gap:3px}
.tb{height:5px;border-radius:3px}
.tb-g{background:var(--primary-light);width:100%}
.tb-a{background:var(--accent-light);width:60%}
.tb-x{background:var(--border-light);width:75%}

@keyframes coinB{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes bellR{0%,100%{transform:rotate(0)}15%{transform:rotate(14deg)}30%{transform:rotate(-11deg)}45%{transform:rotate(7deg)}60%{transform:rotate(0)}}
@keyframes shieldP{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.1)}}

/* ═══════════════════════════════════════════════
   ONBOARDING CARD
   ═══════════════════════════════════════════════ */
.onboard-card{background:#1a2e22;border-radius:var(--radius);padding:1.1rem 1.3rem 1.2rem;margin-bottom:1.1rem;animation:tutIn .35s ease-out}
.onboard-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem;gap:.8rem}
.onboard-head-left{flex:1;min-width:0}
.onboard-title{font-size:.82rem;font-weight:600;color:rgba(255,255,255,.75);letter-spacing:.2px}
.onboard-head-right{display:flex;align-items:center;gap:.65rem;flex-shrink:0}
.onboard-progress-label{font-size:.75rem;font-weight:700;background:rgba(27,140,90,.35);color:#5dca8a;padding:.22rem .65rem;border-radius:50px;white-space:nowrap}
.onboard-dismiss{background:none;border:none;color:rgba(255,255,255,.35);font-size:.95rem;cursor:pointer;padding:.2rem .35rem;border-radius:4px;line-height:1;transition:color var(--tr)}
.onboard-dismiss:hover{color:rgba(255,255,255,.75)}

.onboard-prog-track{height:4px;background:rgba(255,255,255,.1);border-radius:4px;overflow:hidden;margin-bottom:1rem}
.onboard-prog-fill{height:100%;background:var(--primary);border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}

.onboard-steps{display:flex;flex-direction:column;gap:.35rem}
.onboard-step{display:flex;align-items:flex-start;gap:.85rem;padding:.75rem .9rem;border-radius:10px;background:rgba(255,255,255,.05);transition:background var(--tr)}
.onboard-step--done{background:rgba(255,255,255,.04);opacity:.7}
.onboard-step--next{background:rgba(27,140,90,.18);border:1px solid rgba(27,140,90,.35)}

.onboard-step-icon{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:rgba(255,255,255,.5);flex-shrink:0;margin-top:.05rem}
.onboard-step--done .onboard-step-icon{background:var(--primary);color:#fff;font-size:.9rem}
.onboard-step--next .onboard-step-icon{background:var(--primary);color:#fff;font-weight:800}

.onboard-step-body{flex:1;min-width:0}
.onboard-step-title{font-size:.88rem;font-weight:600;color:#fff;line-height:1.3}
.onboard-step--done .onboard-step-title{color:rgba(255,255,255,.55);font-weight:500}
.onboard-step-desc{font-size:.75rem;color:rgba(255,255,255,.5);margin-top:.18rem;line-height:1.4}
.onboard-step-cta{display:inline-flex;align-items:center;margin-top:.5rem;padding:.3rem .75rem;background:var(--primary);color:#fff;border:none;border-radius:7px;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:background var(--tr)}
.onboard-step-cta:hover{background:var(--primary-dark)}

.onboard-step-done-label{font-size:.7rem;font-weight:600;color:var(--primary);background:rgba(27,140,90,.2);padding:.18rem .55rem;border-radius:50px;white-space:nowrap;align-self:center;flex-shrink:0}

@media(max-width:600px){
  .onboard-card{padding:.9rem 1rem 1rem}
  .onboard-step{gap:.65rem;padding:.65rem .75rem}
}

/* ═══════════════════════════════════════════════
   TUTORIAL GUIADO IN-APP
   ═══════════════════════════════════════════════ */
.gtut-ov{
  display:none;
  position:fixed;inset:0;z-index:8000;
  align-items:flex-end;justify-content:center;
  padding-bottom:1.4rem;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(1px);
}

/* Card flutuante */
.gtut-card{
  position:relative;
  width:min(480px,calc(100vw - 2rem));
  background:#fff;border-radius:20px;
  box-shadow:0 16px 48px rgba(0,0,0,.22),0 2px 8px rgba(0,0,0,.1);
  overflow:hidden;
  animation:gtutSlideUp .35s cubic-bezier(.4,0,.2,1) both;
}
@keyframes gtutSlideUp{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}

/* Header */
.gtut-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 1rem .5rem;
}
.gtut-step-pills{display:flex;gap:4px;align-items:center}
.gtut-pill{
  height:5px;border-radius:3px;transition:all .35s;
  background:var(--border);
}
.gtut-pill.done{background:var(--primary)}
.gtut-pill.active{background:var(--primary);width:20px!important}
.gtut-close{
  background:none;border:none;cursor:pointer;
  font-size:.85rem;color:var(--text-muted);
  width:26px;height:26px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.gtut-close:hover{background:var(--border-light);color:var(--text)}

/* Ilustração */
.gtut-ill{
  height:130px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;position:relative;
  margin:0 1rem;border-radius:12px;
  background:linear-gradient(135deg,#f0fdf6,#e8f5f0);
}
.gtut-ill-inner{
  display:flex;align-items:center;justify-content:center;
  width:100%;height:100%;position:relative;
}

/* Body */
.gtut-body{padding:.8rem 1.1rem .4rem}
.gtut-tag{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;
  padding:.18rem .55rem;border-radius:50px;margin-bottom:.4rem;
}
.gtut-tag.green{background:var(--primary-light);color:var(--primary)}
.gtut-tag.blue{background:#EFF6FF;color:#2563EB}
.gtut-tag.yellow{background:var(--accent-light);color:#B07520}
.gtut-tag.purple{background:#F5F3FF;color:#7C3AED}
.gtut-tag.red{background:var(--danger-light);color:var(--danger)}

.gtut-title{font-size:1.05rem;font-weight:800;color:var(--text);line-height:1.3;margin-bottom:.35rem}
.gtut-desc{font-size:.83rem;color:var(--text-muted);line-height:1.55}

/* CTA inline */
.gtut-cta{
  display:inline-flex;align-items:center;gap:.35rem;
  margin-top:.6rem;padding:.38rem .85rem;
  background:var(--primary);color:#fff;
  border:none;border-radius:8px;cursor:pointer;
  font-family:inherit;font-size:.8rem;font-weight:600;
  transition:background .15s,transform .1s;
}
.gtut-cta:hover{background:var(--primary-dark);transform:translateY(-1px)}
.gtut-cta:active{transform:translateY(0)}

/* Footer */
.gtut-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem 1rem .9rem;border-top:1px solid var(--border-light);
  margin-top:.5rem;
}
.gtut-btn-skip{
  background:none;border:none;cursor:pointer;
  font-size:.75rem;color:var(--text-muted);font-family:inherit;
  padding:.3rem .4rem;border-radius:6px;transition:color .15s;
}
.gtut-btn-skip:hover{color:var(--text)}
.gtut-nav{display:flex;gap:.5rem;align-items:center}
.gtut-btn-back{
  background:none;border:1px solid var(--border);cursor:pointer;
  font-size:.8rem;font-weight:600;color:var(--text-muted);font-family:inherit;
  padding:.38rem .8rem;border-radius:9px;transition:all .15s;
}
.gtut-btn-back:hover{border-color:var(--text-muted);color:var(--text)}
.gtut-btn-next{
  background:var(--primary);border:none;cursor:pointer;
  font-size:.82rem;font-weight:700;color:#fff;font-family:inherit;
  padding:.42rem 1.1rem;border-radius:9px;transition:background .15s,transform .1s;
  display:flex;align-items:center;gap:.3rem;
}
.gtut-btn-next:hover{background:var(--primary-dark);transform:translateY(-1px)}
.gtut-btn-next.finish{background:#7C3AED}
.gtut-btn-next.finish:hover{background:#6D28D9}

/* Animação de troca de step */
/* Animação de troca de step */
@keyframes gtutStepIn{
  from{opacity:0;transform:translateY(12px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.gtut-step-in{animation:gtutStepIn .28s cubic-bezier(.4,0,.2,1) both}

/* Elemento destacado pelo spotlight */
.gtut-hl{
  position:relative;
  z-index:8100!important;
  border-radius:10px!important;
  outline:3px solid var(--primary)!important;
  outline-offset:4px!important;
  background:#fff!important;
  box-shadow:
    0 0 0 8px #fff,
    0 0 0 11px var(--primary),
    0 8px 32px rgba(0,0,0,.18) !important;
  animation:gtutHlPulse 1.5s ease-in-out infinite!important;
}
/* FAB mantém seu background original */
#fab.gtut-hl{
  background:var(--primary)!important;
  box-shadow:
    0 0 0 8px rgba(27,140,90,.15),
    0 0 0 11px var(--primary),
    0 8px 32px rgba(39,174,96,.4) !important;
}
@keyframes gtutHlPulse{
  0%,100%{box-shadow:0 0 0 8px #fff, 0 0 0 11px var(--primary), 0 0 0 18px rgba(39,174,96,.15), 0 8px 32px rgba(0,0,0,.18)}
  50%{box-shadow:0 0 0 8px #fff, 0 0 0 11px var(--primary), 0 0 0 24px rgba(39,174,96,.22), 0 8px 32px rgba(0,0,0,.18)}
}

/* Seta animada "veja na tela" */
.gtut-arrow-anim{
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  font-size:2.2rem;
  animation:gtutBounce 1s ease-in-out infinite;
}
.gtut-arrow-anim span{
  font-size:.72rem;font-weight:600;color:var(--primary);
  background:var(--primary-light);padding:.2rem .65rem;border-radius:50px;
  animation:none;
}

/* Ponteiro animado do FAB */
.gtut-fab-pointer{
  font-size:2.4rem;
  animation:gtutFabPoint 1s ease-in-out infinite;
}
@keyframes gtutFabPoint{
  0%,100%{transform:translateX(0)}
  50%{transform:translateX(10px)}
}

/* Spotlight no item de nav (ex: Obrigações, Lançamentos) */
.app-nav a.gtut-hl{
  outline:3px solid var(--primary)!important;
  outline-offset:3px!important;
  border-radius:8px!important;
  z-index:8100!important;
  position:relative!important;
}

@keyframes gtutBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes gtutPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
@keyframes gtutFabPulse{0%,100%{box-shadow:0 6px 20px rgba(39,174,96,.4)}50%{box-shadow:0 6px 32px rgba(39,174,96,.7)}}
@keyframes gtutGrow{from{width:0}to{width:72%}}

@media(max-width:480px){
  .gtut-card{border-radius:16px}
  .gtut-ill{height:90px}
  .gtut-title{font-size:.95rem}
}
