/* =========================================================
   inzopay — Auth Pages (login, register)
   ========================================================= */

/* ———— Login layout ———— */
.auth { display: grid; grid-template-columns: 1fr 1fr; min-height: 100vh; }
.auth-form { padding: 40px 48px; display: flex; flex-direction: column; }
.auth-form .logo { margin-bottom: 40px; }
.auth-body { margin: auto 0; max-width: 420px; width: 100%; }
.auth-body h1 { font-size: 28px; letter-spacing: -0.02em; margin: 0 0 6px; }
.auth-body .sub { color: var(--ink-500); font-size: 14.5px; margin-bottom: 28px; }
.auth-foot { display: flex; justify-content: space-between; align-items: center;
  margin-top: 14px; color: var(--ink-500); font-size: 13px; }
.auth-foot a { color: var(--primary); font-weight: 500; }
.auth-footer { color: var(--ink-400); font-size: 12px; margin-top: 30px;
  display: flex; justify-content: space-between; }
.auth-footer a { color: var(--ink-400); }
.auth-footer a:hover { color: var(--ink-700); }

/* ———— Divider + SSO ———— */
.divider { display:flex; align-items:center; gap:10px; margin: 20px 0;
  color: var(--ink-400); font-size: 12px; }
.divider::before, .divider::after { content:""; flex:1; height:1px; background: var(--line); }
.sso { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.sso .btn { border: 1px solid var(--line-strong); background: var(--surface); }
.sso .btn:hover { background: var(--line); }

/* ———— Auth aside ———— */
.auth-aside { background: var(--ink-900); color: var(--bg); padding: 40px;
  display: flex; flex-direction: column; position: relative; overflow: hidden; }
.auth-aside::before { content:""; position:absolute; inset:0; background:
  radial-gradient(55% 70% at 100% 0%, color-mix(in oklab, var(--primary) 30%, transparent), transparent 60%),
  radial-gradient(50% 60% at 0% 100%, color-mix(in oklab, var(--primary) 15%, transparent), transparent 60%); }
.aside-head, .aside-body { position: relative; }
.aside-body { margin: auto 0; }
.aside-body h2 { font-size: 28px; letter-spacing:-0.02em; line-height:1.15;
  font-weight:700; margin: 0 0 14px; text-wrap: balance; }
.aside-body p { color: color-mix(in oklab, var(--bg) 75%, transparent);
  font-size: 15px; line-height:1.6; margin:0 0 28px; max-width: 460px; }
.quote-card { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1);
  border-radius: 14px; padding: 20px; backdrop-filter: blur(10px); }
.quote-card .q { font-size: 14.5px; line-height:1.6;
  color: color-mix(in oklab, var(--bg) 90%, transparent); margin-bottom: 14px; }
.quote-card .a { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.quote-card .a .av { width: 34px; height: 34px; border-radius: 50%; background: var(--primary);
  color:var(--primary-ink); display:grid; place-items:center; font-weight:700; }
.quote-card .a .who { color: color-mix(in oklab, var(--bg) 85%, transparent); font-weight: 500; }
.quote-card .a .role { color: color-mix(in oklab, var(--bg) 55%, transparent); font-size: 12px; }
.aside-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 30px; }
.aside-stats .s .v { font-family: var(--font-en); font-weight: 700; font-size: 22px; letter-spacing: -.02em; }
.aside-stats .s .l { color: color-mix(in oklab, var(--bg) 60%, transparent); font-size: 11.5px; margin-top: 2px; }

/* ———— Register layout ———— */
.reg-wrap { min-height: 100vh; display: grid; grid-template-columns: 1fr 380px; }
.reg-main { padding: 32px 48px; }
.reg-head { display:flex; justify-content:space-between; align-items:center; margin-bottom: 36px; }
.reg-body { max-width: 680px; }
.reg-body h1 { font-size: 26px; letter-spacing: -.02em; margin: 0 0 6px; }
.reg-body .sub { color: var(--ink-500); font-size: 14.5px; margin-bottom: 22px; }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.reg-aside { background: var(--surface); border-inline-start: 1px solid var(--line); padding: 32px 28px; }
.reg-aside h4 { font-size: 14px; font-weight: 600; margin: 0 0 14px; }
.reg-aside ul { list-style: none; padding: 0; margin: 0 0 24px; display: grid; gap: 12px; }
.reg-aside li { display:flex; gap: 10px; font-size: 13px; color: var(--ink-700); }
.reg-aside li .c { width: 18px; height: 18px; border-radius: 50%; background: var(--primary-tint);
  color: var(--primary); display:grid; place-items:center; font-size: 11px; flex:0 0 auto; }
.trust { background: var(--bg); border: 1px solid var(--line); border-radius: 12px;
  padding: 14px; font-size: 12.5px; color: var(--ink-700); }
.trust b { display: block; margin-bottom: 4px; color: var(--ink-900); font-size: 13px; }

/* ———— Error messages ———— */
.field-error { color: var(--red); font-size: 12px; margin-top: 4px; display: none; }
.alert-error { background: color-mix(in oklab, var(--red) 10%, var(--bg));
  border: 1px solid color-mix(in oklab, var(--red) 30%, transparent);
  color: var(--red); padding: 10px 14px; border-radius: 9px;
  font-size: 13.5px; margin-bottom: 14px; display: none; }

/* ———— 2FA step ———— */
.twofa-step { display: none; }
.twofa-step.active { display: block; }
.login-step { display: block; }
.login-step.hidden { display: none; }
.otp-input { font-family: var(--font-mono);letter-spacing: .2em;
  text-align: center; }

/* ———— Mobile ———— */
@media (max-width: 900px) {
  .auth { grid-template-columns: 1fr; }
  .auth-aside { display: none; }
  .auth-form { padding: 32px 24px; }
  .reg-wrap { grid-template-columns: 1fr; }
  .reg-aside { display: none; }
  .reg-main { padding: 24px; }
  .two-col { grid-template-columns: 1fr; }
}

/* ———— Password toggle ———— */
.input-wrap { position: relative; }
.input-wrap .input { padding-inline-end: 42px; width: 100%; }
.input-eye { position: absolute; inset-inline-end: 12px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; color: var(--ink-400); padding: 0;
  display: flex; align-items: center; }
.input-eye:hover { color: var(--ink-700); }

/* ———— Register Steps ———— */
.steps { display: flex; gap: 8px; margin-bottom: 28px;max-width: 680px;}
.step { flex: 1; padding: 10px 12px; border: 1px solid var(--line); border-radius: 9px;
  background: var(--surface); display:flex; align-items:center; gap:10px;
  font-size: 12.5px; color: var(--ink-500); }
.step.active { border-color: var(--primary); background: var(--primary-tint); color: var(--ink-900); }
.step.done { border-color: var(--accent-green); background: color-mix(in oklab, var(--accent-green) 10%, var(--bg)); }
.step .n { width: 20px; height: 20px; border-radius: 50%; background: var(--line);
  color: var(--ink-500); display:grid; place-items:center;
  font-size: 11px; font-weight: 600; flex: 0 0 auto; }
.step.active .n { background: var(--primary); color: #fff; }
.step.done .n { background: var(--accent-green); color: #fff; }
.step-title { font-weight: 500; }

/* ———— Business Type Selector ———— */
.seg-radio { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.seg-radio label { padding: 12px; border: 1px solid var(--line-strong); border-radius: 10px;
  cursor: pointer; background: var(--surface); font-size: 13px;
  display: flex; flex-direction: column; gap: 2px; transition: border-color .15s, background .15s; }
.seg-radio label:hover { border-color: var(--primary); }
.seg-radio input[type="radio"] { display: none; }
.seg-radio label:has(input:checked) { border-color: var(--primary); background: var(--primary-tint);
  box-shadow: inset 0 0 0 1px var(--primary); }
.seg-radio .t { font-weight: 600; color: var(--ink-900); }
.seg-radio .d { color: var(--ink-500); font-size: 12px; }
@media (max-width: 900px) { .seg-radio { grid-template-columns: 1fr; } }
