/* ============================================================
   HELIXIUS — Auth pages
   Navy #202946 · Grey #EFECE8 · Beige #D7C5B2
   Inherits tokens from styles.css
   ============================================================ */

.auth-body{min-height:100vh;display:flex;background:var(--bg-soft);font-family:var(--ff-body);color:var(--ink)}
.auth-shell{display:grid;grid-template-columns:1.05fr 1fr;width:100%;min-height:100vh}

/* ---------- Brand panel ---------- */
.auth-brand{position:relative;overflow:hidden;background:var(--navy);color:#fff;display:flex;flex-direction:column;
  justify-content:space-between;padding:46px 54px}
.auth-brand__bg{position:absolute;inset:0;z-index:0}
.auth-brand__bg img{width:100%;height:100%;object-fit:cover;opacity:.26}
.auth-brand__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(32,41,70,.86),rgba(19,26,46,.96))}
.auth-brand__top,.auth-brand__mid,.auth-brand__foot{position:relative;z-index:2}
.auth-brand__logo{height:42px;width:auto}
.auth-brand__mid{margin:auto 0}
.auth-brand__eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--tan);margin-bottom:1.2rem}
.auth-brand__eyebrow::before{content:"";width:30px;height:2px;background:var(--tan);border-radius:2px}
.auth-brand h2{color:#fff;font-size:clamp(1.9rem,2.8vw,2.6rem);line-height:1.15;margin-bottom:1rem}
.auth-brand h2 .text-script{color:var(--tan);font-size:1.15em}
.auth-brand p{color:#cdd3e0;font-size:1.02rem;max-width:380px;line-height:1.6}
.auth-points{list-style:none;padding:0;margin:1.8rem 0 0;display:grid;gap:.9rem}
.auth-points li{display:flex;align-items:center;gap:.7rem;font-size:.96rem;color:#e7ebf2}
.auth-points svg{width:20px;height:20px;color:var(--tan);flex:none}
.auth-brand__foot{font-size:.84rem;color:#9aa3b6;display:flex;gap:1.4rem}
.auth-brand__foot a{color:#cdd3e0}
.auth-brand__foot a:hover{color:var(--tan)}

/* ---------- Form panel ---------- */
.auth-main{display:flex;align-items:center;justify-content:center;padding:40px 28px;position:relative}
.auth-card{width:100%;max-width:410px}
.auth-mobilelogo{display:none;margin-bottom:1.6rem}
.auth-mobilelogo img{height:38px}
.auth-back{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--ff-body);font-weight:500;font-size:.88rem;
  color:var(--slate);background:none;border:0;cursor:pointer;padding:0;margin-bottom:1.4rem;transition:.2s}
.auth-back:hover{color:var(--navy)}
.auth-back svg{width:16px;height:16px}
.auth-view{display:none;animation:authIn .45s cubic-bezier(.16,1,.3,1)}
.auth-view.active{display:block}
@keyframes authIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.auth-head{margin-bottom:1.8rem}
.auth-head h1{font-size:1.9rem;margin-bottom:.4rem}
.auth-head p{color:var(--slate);font-size:.98rem;margin:0}
.auth-head p a{color:var(--tan-deep);font-weight:600;cursor:pointer}

/* fields */
.afield{margin-bottom:1.1rem}
.afield label{display:block;font-family:var(--ff-body);font-weight:500;font-size:.86rem;color:var(--navy);margin-bottom:.45rem}
.afield .ipwrap{position:relative;display:flex;align-items:center}
.afield .ipwrap .lead-ic{position:absolute;left:13px;width:19px;height:19px;color:#9aa3b6;pointer-events:none}
.afield input[type=text],.afield input[type=email],.afield input[type=tel],.afield input[type=password]{
  width:100%;font-family:var(--ff-body);font-size:.97rem;color:var(--ink);padding:.82rem 1rem .82rem 2.5rem;
  border:1.5px solid var(--line);border-radius:12px;background:#fff;transition:.2s;outline:none}
.afield input:focus{border-color:var(--navy);box-shadow:0 0 0 4px rgba(32,41,70,.09)}
.afield input.no-ic{padding-left:1rem}
.afield .toggle-pw{position:absolute;right:11px;background:none;border:0;cursor:pointer;color:#9aa3b6;padding:4px;display:grid;place-items:center}
.afield .toggle-pw:hover{color:var(--navy)}
.afield .toggle-pw svg{width:19px;height:19px}
.afield .hint{font-size:.78rem;color:var(--slate);margin-top:.35rem}
.afield .err{font-size:.78rem;color:#E63946;margin-top:.35rem;display:none}
.afield.invalid input{border-color:#E63946}
.afield.invalid .err{display:block}

/* password strength */
.pw-strength{display:flex;gap:.35rem;margin-top:.55rem}
.pw-strength span{height:5px;flex:1;border-radius:5px;background:var(--bg-soft2);transition:.3s}
.pw-strength.s1 span:nth-child(1){background:#E63946}
.pw-strength.s2 span:nth-child(-n+2){background:#FFC83D}
.pw-strength.s3 span:nth-child(-n+3){background:#f0a500}
.pw-strength.s4 span{background:#2EB872}
.pw-label{font-size:.76rem;color:var(--slate);margin-top:.3rem;height:1em}

/* row helpers */
.arow{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.4rem}
.acheck{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--slate);cursor:pointer;user-select:none}
.acheck input{width:17px;height:17px;accent-color:var(--navy);cursor:pointer}
.alink{font-size:.88rem;color:var(--tan-deep);font-weight:600;cursor:pointer;background:none;border:0;font-family:var(--ff-body)}
.alink:hover{text-decoration:underline}

/* buttons */
.abtn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--ff-body);
  font-weight:600;font-size:1rem;padding:.92rem 1.4rem;border-radius:12px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .18s,box-shadow .25s,background .2s,color .2s;line-height:1}
.abtn svg{width:19px;height:19px}
.abtn-primary{background:var(--navy);color:#fff;box-shadow:0 12px 26px -14px rgba(32,41,70,.7)}
.abtn-primary:hover{background:var(--navy-700);transform:translateY(-2px)}
.abtn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}
.abtn-google{background:#fff;color:#3c4043;border-color:var(--line);font-weight:500}
.abtn-google:hover{background:#fafafa;border-color:#cfd5dd;box-shadow:var(--shadow-sm)}
.abtn-google .g-ic{width:20px;height:20px;flex:none}
.abtn-ghost{background:transparent;color:var(--navy);border-color:var(--line)}
.abtn-ghost:hover{border-color:var(--navy)}

/* divider */
.adiv{display:flex;align-items:center;gap:1rem;margin:1.3rem 0;color:#9aa3b6;font-size:.82rem;font-weight:500}
.adiv::before,.adiv::after{content:"";flex:1;height:1px;background:var(--line)}

/* social row */
.asocial{display:grid;gap:.7rem;margin-bottom:.4rem}

/* alt method tiles */
.alt-methods{display:grid;gap:.7rem;margin-top:1.2rem}
.alt-tile{display:flex;align-items:center;gap:.9rem;border:1.5px solid var(--line);border-radius:12px;padding:.9rem 1rem;cursor:pointer;
  transition:.2s;background:#fff;text-align:left;width:100%;font-family:var(--ff-body)}
.alt-tile:hover{border-color:var(--navy);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.alt-tile .at-ic{width:42px;height:42px;border-radius:11px;background:var(--orange-soft);color:var(--tan-deep);display:grid;place-items:center;flex:none}
.alt-tile .at-ic svg{width:21px;height:21px}
.alt-tile .at-txt b{display:block;font-family:var(--ff-body);font-weight:600;color:var(--navy);font-size:.95rem}
.alt-tile .at-txt span{font-size:.82rem;color:var(--slate)}
.alt-tile .at-arrow{margin-left:auto;color:#bcc3d0}
.alt-tile .at-arrow svg{width:18px;height:18px}

/* OTP / code inputs */
.otp-inputs{display:flex;gap:.6rem;justify-content:center;margin:.4rem 0 1.2rem}
.otp-inputs input{width:52px;height:60px;text-align:center;font-family:var(--ff-head);font-weight:700;font-size:1.5rem;
  color:var(--navy);border:1.5px solid var(--line);border-radius:12px;background:#fff;outline:none;transition:.2s}
.otp-inputs input:focus{border-color:var(--navy);box-shadow:0 0 0 4px rgba(32,41,70,.09)}
.otp-inputs input.filled{border-color:var(--tan);background:var(--orange-soft)}
.otp-target{font-family:var(--ff-body);font-weight:600;color:var(--navy)}
.otp-resend{text-align:center;font-size:.88rem;color:var(--slate);margin-top:.2rem}
.otp-resend button{background:none;border:0;color:var(--tan-deep);font-weight:600;cursor:pointer;font-family:var(--ff-body);font-size:.88rem}
.otp-resend button:disabled{color:#b5bccb;cursor:not-allowed}
.demo-pill{display:inline-flex;align-items:center;gap:.4rem;background:var(--orange-soft);color:var(--tan-deep);
  border-radius:100px;padding:.3rem .75rem;font-size:.78rem;font-weight:600;font-family:var(--ff-body);margin:0 auto 1rem;
  width:fit-content}
.demo-pill svg{width:14px;height:14px}
.text-center{text-align:center}
.center-row{display:flex;justify-content:center}

/* QR for authenticator */
.qr-box{display:flex;gap:1.1rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:1.2rem}
.qr-box .qr{width:104px;height:104px;border-radius:10px;flex:none;background:
  conic-gradient(#202946 25%,#fff 0 50%,#202946 0 75%,#fff 0);background-size:14px 14px;border:6px solid #fff;outline:1px solid var(--line);position:relative;overflow:hidden}
.qr-box .qr::after{content:"";position:absolute;inset:32px;background:var(--tan);border-radius:6px}
.qr-box .qr-txt b{display:block;font-family:var(--ff-body);font-weight:600;color:var(--navy);font-size:.92rem;margin-bottom:.3rem}
.qr-box .qr-txt p{font-size:.82rem;color:var(--slate);margin:0 0 .5rem;line-height:1.45}
.qr-box .qr-key{font-family:monospace;font-size:.82rem;background:var(--bg-soft);border:1px dashed var(--line);border-radius:7px;padding:.3rem .5rem;color:var(--navy);letter-spacing:.05em}

/* success */
.auth-success{text-align:center}
.auth-success .as-check{width:88px;height:88px;border-radius:50%;background:#e6f7ee;color:#2EB872;display:grid;place-items:center;margin:0 auto 1.4rem;
  animation:asPop .5s cubic-bezier(.34,1.56,.64,1)}
@keyframes asPop{from{transform:scale(0)}to{transform:scale(1)}}
.auth-success .as-check svg{width:46px;height:46px}
.auth-success h1{font-size:1.8rem;margin-bottom:.5rem}
.auth-success p{color:var(--slate);margin-bottom:1.6rem}

/* toast (reuse) */
.auth-toast{position:fixed;top:22px;left:50%;transform:transl(-50%,-20px);transform:translateX(-50%) translateY(-20px);z-index:1300;
  display:flex;align-items:center;gap:.6rem;background:var(--navy);color:#fff;padding:.8rem 1.2rem;border-radius:12px;
  box-shadow:var(--shadow-lg);font-weight:500;font-size:.92rem;opacity:0;transition:.35s cubic-bezier(.16,1,.3,1);pointer-events:none}
.auth-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.auth-toast svg{width:18px;height:18px;color:var(--tan)}

/* responsive */
@media (max-width:880px){
  .auth-shell{grid-template-columns:1fr}
  .auth-brand{display:none}
  .auth-mobilelogo{display:block;text-align:center}
  .auth-main{padding:36px 22px;min-height:100vh}
}
@media (max-width:420px){
  .otp-inputs{gap:.4rem}
  .otp-inputs input{width:44px;height:54px;font-size:1.3rem}
  .auth-head h1{font-size:1.6rem}
}