/* ═══════════════════════════════════════════════
   ObraTarget — Auth Pages (login, recuperação de senha)
   ═══════════════════════════════════════════════ */

/* LAYOUT SPLIT */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:420px 1fr;}

/* ── PAINEL ESQUERDO — marca ──────────────────── */
.auth-brand{
  background:linear-gradient(160deg,var(--ac) 0%,#3730a3 100%);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:40px;color:#fff;position:relative;overflow:hidden;
}
.auth-brand::before{
  content:'';position:absolute;width:340px;height:340px;
  border-radius:50%;border:64px solid rgba(255,255,255,.06);
  top:-90px;right:-90px;
}
.auth-brand::after{
  content:'';position:absolute;width:220px;height:220px;
  border-radius:50%;border:44px solid rgba(255,255,255,.05);
  bottom:70px;left:-60px;
}
.ab-logo{font-family:var(--fm);font-size:20px;font-weight:700;z-index:1;}
.ab-logo span{color:rgba(255,255,255,.55);}
.ab-main{flex:1;display:flex;flex-direction:column;justify-content:center;z-index:1;}
.ab-title{font-size:26px;font-weight:700;line-height:1.25;margin-bottom:10px;}
.ab-sub{font-size:13px;opacity:.75;line-height:1.65;max-width:300px;}
.ab-features{display:flex;flex-direction:column;gap:11px;margin-top:26px;}
.ab-feat{display:flex;align-items:center;gap:10px;font-size:13px;opacity:.85;}
.ab-feat i{font-size:15px;background:rgba(255,255,255,.15);border-radius:6px;padding:5px;flex-shrink:0;}
.ab-footer{font-size:11px;opacity:.4;z-index:1;}

/* ── PAINEL DIREITO — formulário ──────────────── */
.auth-form-side{
  background:var(--bg);display:flex;align-items:center;
  justify-content:center;padding:40px 24px;position:relative;
}
.auth-theme-btn{
  position:absolute;top:20px;right:20px;
  background:var(--sur);border:1px solid var(--bor);color:var(--muted);
  border-radius:8px;padding:6px 10px;font-size:14px;cursor:pointer;
  transition:all .2s;
}
.auth-theme-btn:hover{color:var(--ac);border-color:var(--ac);}

/* CARD */
.auth-card{
  width:100%;max-width:420px;
  background:var(--sur);border-radius:var(--r);
  padding:36px 32px;box-shadow:0 4px 28px rgba(0,0,0,.08);
  border:1px solid var(--bor);
}
.auth-icon{font-size:42px;color:var(--ac);margin-bottom:14px;display:block;}
.auth-icon.good{color:var(--good);}
.auth-icon.warn{color:var(--warn);}
.auth-title{font-family:var(--fm);font-size:19px;font-weight:700;margin-bottom:4px;}
.auth-sub{font-size:13px;color:var(--muted);margin-bottom:24px;line-height:1.55;}

/* FORM FIELDS */
.af-group{display:flex;flex-direction:column;gap:5px;margin-bottom:15px;}
.af-group label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:600;}
.af-input{
  background:var(--sur2);border:1px solid var(--bor);border-radius:8px;
  color:var(--tx);padding:10px 12px;font-size:13px;font-family:var(--fb);
  width:100%;transition:border-color .2s;
}
.af-input:focus{outline:none;border-color:var(--ac);}
.af-input::placeholder{color:var(--muted);}
.af-pw-wrap{position:relative;}
.af-pw-wrap .af-input{padding-right:42px;}
.pw-toggle{
  position:absolute;right:0;top:0;bottom:0;width:40px;
  display:flex;align-items:center;justify-content:center;
  background:none;border:none;color:var(--muted);cursor:pointer;
  transition:color .2s;
}
.pw-toggle:hover{color:var(--ac);}

/* CHECKBOX ROW */
.auth-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:8px;}
.auth-check{display:flex;align-items:center;gap:7px;cursor:pointer;font-size:13px;color:var(--muted);user-select:none;}
.auth-check input[type=checkbox]{width:15px;height:15px;accent-color:var(--ac);cursor:pointer;}

/* LINKS */
.auth-link{color:var(--ac);text-decoration:none;font-size:13px;font-weight:500;white-space:nowrap;}
.auth-link:hover{text-decoration:underline;}

/* BUTTONS */
.btn-auth{
  width:100%;background:var(--ac);color:#fff;border:none;border-radius:8px;
  padding:12px;font-size:14px;font-weight:700;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--fb);transition:opacity .2s;
}
.btn-auth:hover{opacity:.88;}
.btn-auth-out{
  width:100%;background:var(--sur2);color:var(--tx);
  border:1px solid var(--bor);border-radius:8px;padding:11px;
  font-size:14px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--fb);transition:all .2s;text-decoration:none;
  margin-top:10px;
}
.btn-auth-out:hover{border-color:var(--ac);color:var(--ac);}

/* FOOTER DO CARD */
.auth-footer{
  text-align:center;margin-top:20px;padding-top:16px;
  border-top:1px solid var(--bor);font-size:13px;color:var(--muted);
}

/* INFO CARD (done / complete) */
.auth-info{text-align:center;padding:8px 0;}
.auth-info p{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:10px;}
.auth-note{
  font-size:12px;color:var(--muted);background:var(--sur2);
  border:1px solid var(--bor);border-radius:8px;padding:10px 14px;
  margin:16px 0;line-height:1.55;text-align:left;
}
.auth-divider{border:none;border-top:1px solid var(--bor);margin:20px 0;opacity:.6;}

/* ERRO de link inválido */
.auth-warn-box{
  background:rgba(217,119,6,.07);border:1px solid rgba(217,119,6,.25);
  border-radius:8px;padding:12px 14px;font-size:13px;
  color:var(--warn);text-align:center;margin-bottom:20px;line-height:1.5;
}

/* ── RESPONSIVO ──────────────────────────────── */
@media(max-width:900px){
  .auth-wrap{grid-template-columns:1fr;}
  .auth-brand{display:none;}
}
@media(max-width:480px){
  .auth-card{padding:24px 18px;}
  .auth-form-side{padding:20px 12px;align-items:flex-start;padding-top:40px;}
}
@media(max-width:360px){
  .auth-card{padding:20px 14px;}
  .auth-title{font-size:17px;}
  .auth-sub{font-size:12px;}
  .btn-auth,.btn-auth-out{font-size:13px;padding:11px;}
}
