/* ============================================================
   TakeTips IA — AUTH DESIGN SYSTEM (Taste Skill / dark premium)
   Stylesheet compartilhado: login, cadastro, forgot/reset/criar senha,
   success. Re-estiliza as classes existentes — HTML/JS intactos.
   Mantém os nomes de variáveis legados (--green, --border, ...) mapeados
   pra nova paleta, porque há style="var(--green)" inline no HTML/JS.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

:root{
  /* nova paleta */
  --bg:#0B0F10;
  --bg-deep:#070A0B;
  --surface:#111827;
  --surface-2:#151A22;
  --green:#00FF88;
  --green-2:#00D26A;
  --green-dark:#00D26A;
  --green-glow:rgba(0,255,136,0.14);
  --blue:#4EA8FF;
  --purple:#A78BFA;
  --red:#FF5C6C;
  --gold:#FFC34D;
  --text:#EAF1F2;
  --muted:#8B97A0;
  --muted-2:#5C6B72;
  --line:rgba(255,255,255,0.08);
  --line-2:rgba(255,255,255,0.13);
  /* aliases legados (inline styles/JS dependem deles) */
  --bg2:#0E1620;
  --bg3:#151F1B;
  --card:#111827;
  --border:rgba(255,255,255,0.08);
  --display:'Space Grotesk',sans-serif;
  --body:'Inter',sans-serif;
  --mono:'JetBrains Mono',monospace;
  --ease:cubic-bezier(0.22,1,0.36,1);
}

*{margin:0;padding:0;box-sizing:border-box;}

body{
  font-family:var(--body);background:var(--bg);color:var(--text);
  min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:28px 20px;position:relative;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
::selection{background:var(--green);color:#04110a;}

/* ambient background — orbs + grid (CSS-only) */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(600px 600px at 50% -8%, rgba(0,255,136,0.10), transparent 70%),
    radial-gradient(520px 520px at 85% 110%, rgba(78,168,255,0.07), transparent 70%),
    radial-gradient(480px 480px at 10% 90%, rgba(167,139,250,0.06), transparent 70%);
}
body::after{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,0.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.015) 1px,transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(circle at 50% 30%,black,transparent 75%);
  mask-image:radial-gradient(circle at 50% 30%,black,transparent 75%);
}
body>*{position:relative;z-index:1;}

/* ---------- LOGO ---------- */
/* flow logo (login, cadastro): <div class="logo"><div class="logo-text">…</div></div> */
.login-wrap,.signup-wrap{width:100%;max-width:440px;display:flex;flex-direction:column;align-items:center;gap:22px;}
div.logo{text-align:center;}
.logo-text{font-family:var(--display);font-size:1.7rem;font-weight:700;color:var(--text);letter-spacing:-0.03em;}
.logo-text span{color:var(--green);}
.logo-sub{font-size:0.8rem;color:var(--muted);margin-top:5px;}
/* fixed top logo (success: <a class="logo">, criar-senha: .logo-top) */
a.logo,.logo-top{position:fixed;top:22px;left:50%;transform:translateX(-50%);z-index:5;text-decoration:none;}
a.logo img,.logo-top img{max-height:62px;width:auto;object-fit:contain;display:block;}
.logo em{color:var(--text);font-style:normal;}

/* ---------- CARD ---------- */
.card{
  background:linear-gradient(180deg,var(--surface),var(--bg-deep));
  border:1px solid var(--line-2);border-radius:20px;
  padding:38px 34px;width:100%;max-width:440px;
  box-shadow:0 30px 80px -28px rgba(0,0,0,0.75), inset 0 1px 0 rgba(255,255,255,0.04);
  animation:card-in .5s var(--ease) both;
}
@keyframes card-in{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}

/* logo/img inside card (forgot, reset) */
.card>a>img,.card img[alt="TakeTips IA"]{height:54px !important;}

/* ---------- TÍTULOS ---------- */
.card-title{font-family:var(--display);font-size:1.4rem;font-weight:700;letter-spacing:-0.02em;margin-bottom:6px;}
.card-sub{font-size:0.86rem;color:var(--muted);margin-bottom:22px;line-height:1.55;}
.card-sub strong{color:var(--green);}
h1{font-family:var(--display);font-size:1.45rem;font-weight:700;text-align:center;letter-spacing:-0.02em;margin-bottom:8px;}
h1 span{color:var(--green);}
.subtitle{text-align:center;color:var(--muted);font-size:0.86rem;margin-bottom:26px;}
.desc{color:var(--muted);font-size:0.88rem;text-align:center;line-height:1.6;margin-bottom:24px;}

/* ---------- FORM ---------- */
.form-group,.field{margin-bottom:16px;}
label{display:block;font-family:var(--body);font-size:0.74rem;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px;}
.input-wrap{position:relative;}
input{
  width:100%;background:rgba(255,255,255,0.025);border:1px solid var(--line);
  border-radius:11px;padding:12px 14px;color:var(--text);font-family:var(--body);
  font-size:0.94rem;outline:none;transition:border-color .2s,box-shadow .2s,background .2s;
}
input[type="password"],input[type="text"]{padding-right:44px;}
input:focus{border-color:rgba(0,255,136,0.5);box-shadow:0 0 0 3px rgba(0,255,136,0.1);background:rgba(255,255,255,0.04);}
input::placeholder{color:var(--muted-2);}
.toggle-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;
  cursor:pointer;color:var(--muted);font-size:1rem;padding:2px;transition:color .2s;}
.toggle-eye:hover{color:var(--green);}

/* ---------- BOTÕES ---------- */
.btn,.btn-login,.btn-signup,.btn-ok,.btn-primary{
  width:100%;background:var(--green);color:#04110a;border:none;border-radius:12px;padding:14px;
  font-family:var(--body);font-size:0.97rem;font-weight:700;cursor:pointer;letter-spacing:-0.01em;
  transition:transform .2s var(--ease),box-shadow .2s,background .2s;margin-top:8px;display:block;text-align:center;text-decoration:none;
}
.btn{margin-top:20px;}
.btn:hover,.btn-login:hover,.btn-signup:hover,.btn-ok:hover,.btn-primary:hover{
  background:var(--green);transform:translateY(-2px);box-shadow:0 14px 34px -10px rgba(0,255,136,0.5);
}
.btn:active,.btn-login:active,.btn-signup:active,.btn-primary:active{transform:translateY(0);}
.btn:disabled,.btn-login:disabled,.btn-signup:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;}
.btn-ok{width:auto;display:inline-block;padding:11px 36px;margin-top:20px;}
.btn-secondary{
  width:100%;display:block;background:rgba(255,255,255,0.04);color:var(--text);border:1px solid var(--line-2);
  border-radius:12px;padding:13px;font-family:var(--body);font-size:0.9rem;font-weight:600;cursor:pointer;
  text-decoration:none;text-align:center;transition:all .2s;margin-top:10px;
}
.btn-secondary:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.22);color:var(--text);}
.link-btn{display:inline-block;margin-top:20px;padding:12px 26px;background:var(--green);color:#04110a;
  border-radius:11px;text-decoration:none;font-weight:700;font-size:0.9rem;transition:transform .2s;}
.link-btn:hover{transform:translateY(-2px);}

/* ---------- MENSAGENS ---------- */
.msg{margin-top:14px;padding:11px 15px;border-radius:10px;font-size:0.84rem;text-align:center;display:none;}
.msg.success{background:rgba(0,255,136,.08);border:1px solid rgba(0,255,136,.25);color:var(--green);}
.msg.error{background:rgba(255,92,108,.09);border:1px solid rgba(255,92,108,.3);color:var(--red);}

/* ---------- LINKS / DIVISOR ---------- */
.divider{border:none;border-top:1px solid var(--line);margin:20px 0;}
.bottom-link{font-size:0.85rem;color:var(--muted);text-align:center;}
.bottom-link a{color:var(--green);text-decoration:none;font-weight:600;}
.bottom-link a:hover{text-decoration:underline;}
.forgot-link{display:block;text-align:right;font-size:0.76rem;color:var(--muted);text-decoration:none;margin-top:6px;cursor:pointer;}
.forgot-link:hover{color:var(--green);}
.back-link{display:block;text-align:center;margin-top:20px;color:var(--muted);font-size:0.85rem;text-decoration:none;}
.back-link:hover{color:var(--green);}

/* ---------- BADGES ---------- */
.trial-badge,.welcome-badge,.badge{
  display:inline-flex;align-items:center;gap:7px;background:rgba(0,255,136,0.1);
  border:1px solid rgba(0,255,136,0.25);color:var(--green);border-radius:999px;
  padding:6px 15px;font-size:0.76rem;font-weight:600;letter-spacing:0.02em;margin-bottom:18px;
}
.welcome-badge::before{content:'✦';font-size:0.7rem;}
.badge::before{content:'●';font-size:0.5rem;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.35}}
.trial-badge .gift{font-size:1.1rem;}

/* ---------- ÍCONES CIRCULARES ---------- */
.icon-wrap{
  width:66px;height:66px;border-radius:50%;background:var(--green-glow);
  border:1px solid rgba(0,255,136,0.3);display:flex;align-items:center;justify-content:center;
  font-size:1.9rem;margin:0 auto 20px;box-shadow:0 0 28px rgba(0,255,136,0.12);
}
.success-icon{
  width:86px;height:86px;border-radius:50%;
  background:linear-gradient(135deg,rgba(0,255,136,0.2),rgba(0,255,136,0.04));
  border:2px solid var(--green);display:flex;align-items:center;justify-content:center;
  font-size:2.6rem;margin:0 auto 26px;box-shadow:0 0 34px rgba(0,255,136,0.22);
}

/* checkmark SVG (success) */
.checkmark{width:54px;height:54px;margin:0 auto 26px;}
.checkmark-circle{stroke-dasharray:166;stroke-dashoffset:166;animation:stroke .6s cubic-bezier(0.65,0,0.45,1) .3s forwards;}
.checkmark-check{stroke-dasharray:48;stroke-dashoffset:48;animation:stroke .3s cubic-bezier(0.65,0,0.45,1) .8s forwards;}
@keyframes stroke{100%{stroke-dashoffset:0;}}

/* ---------- FORÇA DE SENHA ---------- */
.strength-wrap{margin-top:9px;}
.strength-bar{height:4px;border-radius:3px;background:rgba(255,255,255,0.07);overflow:hidden;}
.strength-fill{height:100%;width:0%;border-radius:3px;transition:width .3s,background .3s;}
.strength-label{font-size:0.74rem;color:var(--muted);margin-top:5px;font-family:var(--mono);}

/* requisitos */
.reqs{margin-top:9px;display:flex;flex-direction:column;gap:5px;}
.req{font-size:0.78rem;color:var(--muted);display:flex;align-items:center;gap:8px;transition:color .2s;}
.req.ok{color:var(--green);}
.req-dot{width:6px;height:6px;border-radius:50%;background:var(--muted-2);flex-shrink:0;transition:background .2s;}
.req.ok .req-dot{background:var(--green);}

/* ---------- BENEFÍCIOS (cadastro) ---------- */
.benefits{list-style:none;margin:0 0 16px;padding:0;}
.benefits li{font-size:0.8rem;color:var(--muted);padding:4px 0;display:flex;align-items:center;gap:9px;}
.benefits li::before{content:'';display:inline-block;width:5px;height:5px;background:var(--green);border-radius:50%;flex-shrink:0;}

/* ---------- VIEWS DE ESTADO ---------- */
/* escondidas por padrão (o JS alterna via style.display) */
.success-view,.invalid-view,.done-view,.alt-view{display:none;}
.success-view,.invalid-view,.done-view,.alt-view,.modal-success-view{text-align:center;}
.success-view .check,.success-view .icon,.invalid-view .icon,.done-view .icon,.alt-view .big-icon,.modal-success-view .s-icon{
  font-size:3rem;margin-bottom:16px;
}
.success-view h2,.success-view h3,.invalid-view h2,.done-view h2,.alt-view h2,.modal-success-view h3{
  font-family:var(--display);font-weight:700;font-size:1.2rem;margin-bottom:10px;
}
.success-view p,.invalid-view p,.done-view p,.alt-view p,.modal-success-view p{color:var(--muted);font-size:0.86rem;line-height:1.65;}
.success-view .resend,.success-view .spam-note,.success-view .spam{margin-top:14px;color:var(--muted);font-size:0.8rem;}
.success-view .resend a{color:var(--green);text-decoration:none;cursor:pointer;}
.success-view .resend a:hover{text-decoration:underline;}
.countdown-redirect{margin-top:16px;font-size:0.8rem;color:var(--muted);}
.countdown-redirect span{color:var(--green);font-weight:700;}

/* ---------- LOADER ---------- */
.loader{text-align:center;padding:30px 0;}
.loader p{color:var(--muted);font-size:0.86rem;}
.spinner{width:38px;height:38px;border:3px solid var(--line-2);border-top-color:var(--green);
  border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 14px;}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- MODAL (login: esqueci a senha) ---------- */
.modal-backdrop{position:fixed;inset:0;background:rgba(5,8,9,0.82);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;z-index:999;animation:fadeInBd .18s ease;}
.modal-box{background:linear-gradient(180deg,var(--surface),var(--bg-deep));border:1px solid var(--line-2);
  border-radius:20px;padding:36px 32px 32px;width:90%;max-width:420px;position:relative;
  box-shadow:0 40px 100px -30px rgba(0,0,0,0.85);animation:slideUpBox .22s var(--ease);}
.modal-close{position:absolute;top:14px;right:16px;background:none;border:none;color:var(--muted);
  font-size:1.4rem;line-height:1;cursor:pointer;padding:2px 8px;border-radius:8px;}
.modal-close:hover{color:var(--text);background:rgba(255,255,255,0.06);}
.modal-icon{font-size:2.4rem;text-align:center;margin-bottom:12px;}
.modal-title{font-family:var(--display);font-size:1.2rem;font-weight:700;text-align:center;margin-bottom:8px;}
.modal-desc{font-size:0.85rem;color:var(--muted);text-align:center;line-height:1.6;margin-bottom:22px;}
@keyframes fadeInBd{from{opacity:0}to{opacity:1}}
@keyframes slideUpBox{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ---------- SUCCESS: plano + steps + countdown + partículas ---------- */
.plan-box{background:rgba(0,255,136,0.05);border:1px solid rgba(0,255,136,0.22);border-radius:14px;
  padding:18px 22px;margin-bottom:28px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.plan-label{font-size:0.8rem;color:var(--muted);margin-bottom:4px;}
.plan-name-big{font-family:var(--display);font-size:1.2rem;font-weight:700;color:var(--green);}
.plan-credits{text-align:right;}
.plan-credits-num{font-family:var(--mono);font-size:1.6rem;font-weight:700;color:var(--text);line-height:1;}
.plan-credits-label{font-size:0.74rem;color:var(--muted);}
.steps{text-align:left;margin-bottom:30px;display:flex;flex-direction:column;gap:14px;}
.step-item{display:flex;align-items:flex-start;gap:14px;}
.step-dot{width:28px;height:28px;border-radius:50%;background:rgba(0,255,136,0.1);border:1px solid var(--green);
  display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:0.75rem;font-weight:600;
  color:var(--green);flex-shrink:0;margin-top:1px;}
.step-text strong{display:block;font-size:0.92rem;font-weight:600;margin-bottom:2px;}
.step-text span{font-size:0.82rem;color:var(--muted);}
.countdown{font-size:0.8rem;color:var(--muted);margin-top:20px;}
.countdown span{color:var(--green);font-weight:700;}
.particle{position:fixed;width:4px;height:4px;background:var(--green);border-radius:50%;
  animation:float-up linear infinite;opacity:0;z-index:0;}
@keyframes float-up{0%{transform:translateY(100vh) scale(0);opacity:0;}10%{opacity:0.6;}90%{opacity:0.3;}100%{transform:translateY(-100px) scale(1.5);opacity:0;}}

/* ---------- RESPONSIVO ---------- */
@media(max-width:480px){
  .card{padding:30px 22px;}
  a.logo img,.logo-top img{max-height:52px;}
}
