
:root{
  --qs-auth-bg: radial-gradient(circle at top left, #eef7ff 0%, #f7fbff 38%, #f4f7fb 100%);
  --qs-auth-card: rgba(255,255,255,.96);
  --qs-auth-card-strong: #ffffff;
  --qs-auth-text: #0f2740;
  --qs-auth-muted: #5e7388;
  --qs-auth-border: rgba(15, 39, 64, .10);
  --qs-auth-border-strong: rgba(15, 39, 64, .16);
  --qs-auth-primary: #0f63ce;
  --qs-auth-primary-strong: #094a9c;
  --qs-auth-primary-soft: rgba(15, 99, 206, .12);
  --qs-auth-success: #1f9d63;
  --qs-auth-success-soft: rgba(31, 157, 99, .12);
  --qs-auth-warning: #b86c00;
  --qs-auth-warning-soft: rgba(184, 108, 0, .12);
  --qs-auth-danger: #c03636;
  --qs-auth-danger-soft: rgba(192, 54, 54, .10);
  --qs-auth-shadow: 0 24px 70px rgba(11, 43, 76, .10);
  --qs-auth-radius-xl: 30px;
  --qs-auth-radius-lg: 22px;
  --qs-auth-radius-md: 16px;
  --qs-auth-radius-sm: 12px;
  --qs-auth-max: 1160px;
}

html{scroll-behavior:smooth}
body.qs-auth-body{
  margin:0;
  min-height:100vh;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--qs-auth-text);
  background:var(--qs-auth-bg);
}
.qs-auth-body *{box-sizing:border-box}
.qs-auth-body a{color:var(--qs-auth-primary);text-decoration:none}
.qs-auth-body a:hover{text-decoration:underline}
.qs-auth-shell{
  width:min(var(--qs-auth-max), calc(100% - 32px));
  margin:0 auto;
  min-height:100vh;
  display:grid;
  grid-template-columns:minmax(280px, 420px) minmax(0, 1fr);
  gap:28px;
  align-items:stretch;
  padding:24px 0 32px;
}
.qs-auth-side,
.qs-auth-main{min-width:0}
.qs-auth-side{
  position:relative;
  overflow:hidden;
  padding:30px;
  border-radius:var(--qs-auth-radius-xl);
  background:
    linear-gradient(180deg, rgba(15,99,206,.92) 0%, rgba(9,74,156,.96) 100%);
  color:#fff;
  box-shadow:var(--qs-auth-shadow);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.qs-auth-side::before,
.qs-auth-side::after{
  content:"";
  position:absolute;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  pointer-events:none;
}
.qs-auth-side::before{width:220px;height:220px;top:-90px;right:-60px}
.qs-auth-side::after{width:180px;height:180px;left:-50px;bottom:-70px}
.qs-auth-side-top,
.qs-auth-side-bottom,
.qs-auth-side-content{position:relative;z-index:1}
.qs-auth-brand{
  display:flex;
  gap:14px;
  align-items:center;
  margin-bottom:18px;
}
.qs-auth-brand-mark{
  width:52px;height:52px;border-radius:18px;
  background:rgba(255,255,255,.18);
  display:grid;place-items:center;
  font-size:24px;font-weight:800;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);
}
.qs-auth-brand-copy{min-width:0}
.qs-auth-brand-copy strong{
  display:block;
  font-size:24px;
  font-weight:800;
  letter-spacing:.01em;
  line-height:1.08;
}
.qs-auth-brand-copy span{
  display:block;margin-top:4px;color:rgba(255,255,255,.82);font-size:14px;line-height:1.5
}
.qs-auth-eyebrow,
.qs-auth-side-top .qs-auth-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  min-height:34px;padding:0 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:rgba(255,255,255,.94);
  font-size:13px;font-weight:700;letter-spacing:.01em;
}
.qs-auth-side h2{
  margin:18px 0 12px;
  font-size:clamp(28px, 4vw, 42px);
  line-height:1.02;
}
.qs-auth-side p{
  margin:0;
  color:rgba(255,255,255,.88);
  font-size:16px;
  line-height:1.65;
}
.qs-auth-side-list{
  list-style:none;
  padding:0;margin:24px 0 0;
  display:grid;gap:12px;
}
.qs-auth-side-list li{
  display:flex;gap:12px;align-items:flex-start;
  padding:14px 16px;border-radius:18px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
}
.qs-auth-side-list b{display:block;margin-bottom:2px;font-size:14px}
.qs-auth-side-list span{display:block;color:rgba(255,255,255,.80);font-size:13px;line-height:1.5}
.qs-auth-facts{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:24px
}
.qs-auth-fact{
  padding:14px 16px;border-radius:18px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.12);
}
.qs-auth-fact strong{display:block;font-size:24px;line-height:1.05}
.qs-auth-fact span{display:block;margin-top:6px;color:rgba(255,255,255,.78);font-size:13px;line-height:1.45}
.qs-auth-side-bottom{
  margin-top:24px;
  font-size:13px;
  color:rgba(255,255,255,.70);
  line-height:1.6;
}

.qs-auth-side-balanced{
  align-self:center;
  min-height:clamp(640px, 76vh, 760px);
  padding:30px 28px;
  justify-content:flex-start;
  gap:22px;
}
.qs-auth-side-balanced .qs-auth-side-top{
  display:grid;
  align-content:start;
}
.qs-auth-side-balanced .qs-auth-brand{
  margin-bottom:18px;
}
.qs-auth-side-balanced .qs-auth-brand-copy span{
  max-width:32ch;
  font-size:15px;
}
.qs-auth-side-balanced h2{
  margin:18px 0 12px;
  font-size:clamp(34px, 4vw, 48px);
  line-height:1.02;
}
.qs-auth-side-balanced > .qs-auth-side-top > p{
  max-width:31ch;
  font-size:16px;
  line-height:1.62;
}
.qs-auth-side-balanced .qs-auth-side-list{
  margin-top:24px;
}
.qs-auth-side-balanced .qs-auth-side-bottom{
  margin-top:auto;
  padding-top:22px;
  max-width:32ch;
}


.qs-auth-main{
  display:flex;
  align-items:center;
  justify-content:center;
}
.qs-auth-card{
  width:min(100%, 640px);
  background:var(--qs-auth-card);
  border:1px solid var(--qs-auth-border);
  border-radius:var(--qs-auth-radius-xl);
  box-shadow:var(--qs-auth-shadow);
  backdrop-filter:blur(12px);
  padding:32px;
}
.qs-auth-card.is-wide{width:min(100%, 720px)}
.qs-auth-card.is-compact{width:min(100%, 560px)}
.qs-auth-card-head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:18px;
  margin-bottom:20px;
}
.qs-auth-card h1{
  margin:10px 0 10px;
  font-size:clamp(28px, 4vw, 38px);
  line-height:1.06;
  color:var(--qs-auth-text);
}
.qs-auth-card p{
  margin:0;
  color:var(--qs-auth-muted);
  font-size:16px;
  line-height:1.65;
}
.qs-auth-card code{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  word-break:break-word;
  background:#f5f8fc;
  padding:2px 4px;
  border-radius:8px;
}
.qs-auth-kicker{
  display:inline-flex;align-items:center;gap:8px;
  min-height:32px;padding:0 12px;border-radius:999px;
  background:var(--qs-auth-primary-soft);
  color:var(--qs-auth-primary-strong);
  font-size:13px;font-weight:700;
}
.qs-auth-steps{
  display:flex;gap:10px;flex-wrap:wrap;margin:22px 0 0;
}
.qs-auth-step{
  display:inline-flex;align-items:center;gap:8px;
  min-height:36px;padding:0 14px;border-radius:999px;
  border:1px solid var(--qs-auth-border);
  color:var(--qs-auth-muted);
  background:#fff;
  font-size:13px;font-weight:700;
}
.qs-auth-step.is-active{
  color:#fff;background:linear-gradient(135deg,var(--qs-auth-primary) 0%, var(--qs-auth-primary-strong) 100%);
  border-color:transparent;
  box-shadow:0 14px 34px rgba(15,99,206,.24);
}
.qs-auth-step.is-done{
  color:var(--qs-auth-success);background:var(--qs-auth-success-soft);border-color:rgba(31,157,99,.18)
}
.qs-auth-grid{
  display:grid;
  gap:16px;
  margin-top:24px;
}
.qs-auth-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.qs-auth-field,
.qs-auth-fieldset{
  display:grid;gap:8px;
}
.qs-auth-field label,
.qs-auth-fieldset legend,
.qs-auth-label{
  font-size:14px;font-weight:700;color:var(--qs-auth-text)
}
.qs-auth-fieldset{
  margin:0;border:1px solid var(--qs-auth-border);border-radius:20px;padding:18px;background:#fbfdff
}
.qs-auth-fieldset legend{padding:0 10px}
.qs-auth-field input,
.qs-auth-field select,
.qs-auth-field textarea,
.qs-auth-input,
.qs-auth-body input[type="text"],
.qs-auth-body input[type="email"],
.qs-auth-body input[type="password"],
.qs-auth-body input[type="search"],
.qs-auth-body input[type="tel"]{
  width:100%;
  min-height:54px;
  padding:0 16px;
  border-radius:16px;
  border:1px solid var(--qs-auth-border);
  background:#fff;
  color:var(--qs-auth-text);
  font-size:16px;
  line-height:1.2;
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.qs-auth-body textarea{padding:14px 16px;min-height:120px;resize:vertical}
.qs-auth-body input:focus,
.qs-auth-body select:focus,
.qs-auth-body textarea:focus{
  outline:none;
  border-color:rgba(15,99,206,.50);
  box-shadow:0 0 0 4px rgba(15,99,206,.12);
}
.qs-auth-body input[readonly]{
  background:#f8fbff;color:#33516a
}
.qs-auth-body ::placeholder{color:#90a0b2}
.qs-auth-help{font-size:13px;color:var(--qs-auth-muted);line-height:1.55}
.qs-auth-help strong{color:var(--qs-auth-text)}
.qs-auth-summary{
  display:grid;gap:14px;
  padding:18px;
  border-radius:20px;
  background:#f7fbff;
  border:1px solid rgba(15,99,206,.10);
}
.qs-auth-summary-grid{
  display:grid;gap:12px;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
}
.qs-auth-summary-item{
  padding:14px 16px;border-radius:16px;background:#fff;border:1px solid var(--qs-auth-border)
}
.qs-auth-summary-item strong{
  display:block;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--qs-auth-muted);margin-bottom:8px
}
.qs-auth-summary-item span{display:block;font-size:16px;font-weight:700;color:var(--qs-auth-text);word-break:break-word}
.qs-auth-role-grid{
  display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:24px;
}
.qs-auth-role-option{position:relative}
.qs-auth-role-option input{
  position:absolute;opacity:0;pointer-events:none
}
.qs-auth-role-card{
  height:100%;
  padding:22px;
  border-radius:24px;
  border:1px solid var(--qs-auth-border);
  background:#fff;
  box-shadow:0 8px 26px rgba(15,39,64,.04);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.qs-auth-role-card h3{margin:0 0 8px;font-size:20px;color:var(--qs-auth-text)}
.qs-auth-role-card p{margin:0;color:var(--qs-auth-muted);font-size:15px}
.qs-auth-role-card .qs-auth-help{margin-top:14px}
.qs-auth-role-option:hover .qs-auth-role-card{transform:translateY(-2px);box-shadow:0 14px 36px rgba(15,39,64,.10)}
.qs-auth-role-option input:checked + .qs-auth-role-card{
  border-color:rgba(15,99,206,.42);
  background:linear-gradient(180deg, rgba(15,99,206,.08) 0%, rgba(15,99,206,.03) 100%);
  box-shadow:0 16px 40px rgba(15,99,206,.18);
}
.qs-auth-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
  align-items:center;
}
.qs-auth-btn,
.qs-auth-body button,
.qs-auth-body .btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:52px;padding:0 18px;border-radius:16px;border:1px solid transparent;
  background:linear-gradient(135deg,var(--qs-auth-primary) 0%, var(--qs-auth-primary-strong) 100%);
  color:#fff;font-size:15px;font-weight:700;letter-spacing:.01em;text-decoration:none;
  box-shadow:0 16px 34px rgba(15,99,206,.22);
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  cursor:pointer;
}
.qs-auth-btn:hover,
.qs-auth-body button:hover,
.qs-auth-body .btn:hover{
  transform:translateY(-1px);
  box-shadow:0 20px 38px rgba(15,99,206,.26);
  text-decoration:none;
}
.qs-auth-btn:focus-visible,
.qs-auth-body button:focus-visible{outline:3px solid rgba(15,99,206,.22);outline-offset:2px}
.qs-auth-btn.is-secondary,
.qs-auth-btn.is-ghost,
.qs-auth-body .qs-auth-btn.is-ghost,
.qs-auth-body button.is-ghost{
  background:#fff;
  color:var(--qs-auth-text);
  border-color:var(--qs-auth-border-strong);
  box-shadow:none;
}
.qs-auth-btn.is-secondary:hover,
.qs-auth-btn.is-ghost:hover,
.qs-auth-body button.is-ghost:hover{box-shadow:0 14px 28px rgba(15,39,64,.08)}
.qs-auth-btn.is-danger{background:linear-gradient(135deg,#cf4a4a 0%, #a92727 100%)}
.qs-auth-body a.qs-auth-btn,
.qs-auth-body a.qs-auth-btn:link,
.qs-auth-body a.qs-auth-btn:visited,
.qs-auth-body a.qs-auth-btn:hover,
.qs-auth-body a.qs-auth-btn:active,
.qs-auth-body a.qs-auth-btn:focus{
  color:#fff;
  text-decoration:none;
}
.qs-auth-body a.qs-auth-btn.is-secondary,
.qs-auth-body a.qs-auth-btn.is-secondary:link,
.qs-auth-body a.qs-auth-btn.is-secondary:visited,
.qs-auth-body a.qs-auth-btn.is-secondary:hover,
.qs-auth-body a.qs-auth-btn.is-secondary:active,
.qs-auth-body a.qs-auth-btn.is-secondary:focus,
.qs-auth-body a.qs-auth-btn.is-ghost,
.qs-auth-body a.qs-auth-btn.is-ghost:link,
.qs-auth-body a.qs-auth-btn.is-ghost:visited,
.qs-auth-body a.qs-auth-btn.is-ghost:hover,
.qs-auth-body a.qs-auth-btn.is-ghost:active,
.qs-auth-body a.qs-auth-btn.is-ghost:focus{
  color:var(--qs-auth-text);
  text-decoration:none;
}
.qs-auth-links{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  margin-top:18px;font-size:14px;color:var(--qs-auth-muted)
}
.qs-auth-links .sep{color:#b3bfcb}
.qs-auth-divider{
  height:1px;background:linear-gradient(90deg, rgba(15,39,64,0), rgba(15,39,64,.10), rgba(15,39,64,0));margin:24px 0
}
.qs-auth-alert{
  display:flex;gap:12px;align-items:flex-start;
  margin-top:18px;
  padding:16px 18px;
  border-radius:18px;
  border:1px solid transparent;
  line-height:1.6;
  font-size:14px;
}
.qs-auth-alert strong{display:block;margin-bottom:2px}
.qs-auth-alert::before{font-size:18px;line-height:1}
.qs-auth-alert.is-info{background:rgba(15,99,206,.08);border-color:rgba(15,99,206,.14);color:var(--qs-auth-primary-strong)}
.qs-auth-alert.is-info::before{content:"ℹ️"}
.qs-auth-alert.is-success{background:var(--qs-auth-success-soft);border-color:rgba(31,157,99,.16);color:#145c3c}
.qs-auth-alert.is-success::before{content:"✅"}
.qs-auth-alert.is-warning{background:var(--qs-auth-warning-soft);border-color:rgba(184,108,0,.18);color:#8a5300}
.qs-auth-alert.is-warning::before{content:"⚠️"}
.qs-auth-alert.is-error{background:var(--qs-auth-danger-soft);border-color:rgba(192,54,54,.18);color:#8f2020}
.qs-auth-alert.is-error::before{content:"⛔"}
.qs-auth-alert.is-neutral{background:#f7f9fc;border-color:var(--qs-auth-border);color:var(--qs-auth-text)}
.qs-auth-alert.is-neutral::before{content:"•"}
.qs-auth-checklist,
.qs-auth-list{
  list-style:none;
  padding:0;margin:18px 0 0;
  display:grid;gap:12px
}
.qs-auth-checklist li,
.qs-auth-list li{
  padding:14px 16px;border-radius:16px;border:1px solid var(--qs-auth-border);background:#fbfdff;
  color:var(--qs-auth-text);font-size:14px;line-height:1.6;
}
.qs-auth-checklist li::before{
  content:"✓";
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:999px;margin-right:10px;
  background:var(--qs-auth-success-soft);color:var(--qs-auth-success);font-weight:800
}
.qs-auth-note{
  margin-top:18px;padding:16px 18px;border-radius:18px;
  background:#f7f9fc;border:1px solid var(--qs-auth-border);color:var(--qs-auth-muted);font-size:14px;line-height:1.65
}
.qs-auth-note strong{color:var(--qs-auth-text)}
.qs-auth-toggle{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:18px
}
.qs-auth-toggle button{
  min-height:42px;padding:0 14px;border-radius:999px;box-shadow:none;
  background:#fff;color:var(--qs-auth-text);border:1px solid var(--qs-auth-border-strong)
}
.qs-auth-toggle button.is-active{
  background:var(--qs-auth-primary-soft);
  border-color:rgba(15,99,206,.22);
  color:var(--qs-auth-primary-strong);
}
.qs-auth-inline{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap
}
.qs-auth-inline input[type="checkbox"]{
  width:18px;height:18px;min-height:18px;padding:0;border-radius:6px
}
.qs-auth-strength{
  display:grid;gap:10px;margin-top:10px
}
.qs-auth-strength-bar{
  height:10px;border-radius:999px;background:#e9eff6;overflow:hidden
}
.qs-auth-strength-bar span{display:block;height:100%;width:0;background:linear-gradient(135deg,var(--qs-auth-warning) 0%, var(--qs-auth-success) 100%);transition:width .18s ease}
.qs-auth-meta{
  display:grid;gap:8px;
  margin-top:16px;
  color:var(--qs-auth-muted);
  font-size:14px;
}
.qs-auth-meta .row{display:flex;flex-wrap:wrap;gap:8px 12px}
.qs-auth-chip{
  display:inline-flex;align-items:center;gap:8px;
  min-height:32px;padding:0 12px;border-radius:999px;background:#fff;border:1px solid var(--qs-auth-border);font-size:13px;font-weight:700;color:var(--qs-auth-text)
}
.qs-auth-chip.is-warning{background:var(--qs-auth-warning-soft);border-color:rgba(184,108,0,.16);color:#8a5300}
.qs-auth-chip.is-success{background:var(--qs-auth-success-soft);border-color:rgba(31,157,99,.16);color:#145c3c}
.qs-auth-chip.is-danger{background:var(--qs-auth-danger-soft);border-color:rgba(192,54,54,.18);color:#8f2020}
.qs-auth-code-list{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:18px
}
.qs-auth-code{
  padding:16px;border-radius:18px;background:#fff;border:1px solid var(--qs-auth-border);font-size:15px;font-weight:800;letter-spacing:.06em;text-align:center
}
.qs-auth-table{
  width:100%;border-collapse:collapse;margin-top:18px;font-size:14px
}
.qs-auth-table th,.qs-auth-table td{
  padding:12px 14px;border-bottom:1px solid var(--qs-auth-border);text-align:left;vertical-align:top
}
.qs-auth-table th{
  font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--qs-auth-muted)
}
.qs-auth-security{
  display:grid;
  gap:20px;
}
.qs-auth-security .qs-card{
  border-radius:22px;
  border:1px solid rgba(15,39,64,.08);
  box-shadow:0 18px 42px rgba(11,43,76,.06);
  background:linear-gradient(180deg, #fff 0%, #fcfdff 100%);
}
.qs-auth-security > h1{
  margin:0;
  font-size:clamp(30px, 4vw, 40px);
  line-height:1.05;
  color:var(--qs-auth-text);
}
.qs-auth-security .qs-auth-security-hero{
  display:grid;grid-template-columns:minmax(0,1.15fr) minmax(260px,.85fr);gap:18px;
}
.qs-auth-security .qs-auth-security-hero .qs-card{
  margin:0;
}
.qs-auth-security .qs-auth-security-intro{
  display:grid;gap:16px;
}
.qs-auth-security .qs-auth-security-grid{
  display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))
}
.qs-auth-security .qs-auth-security-stat{
  padding:18px;border-radius:18px;background:#f7fbff;border:1px solid rgba(15,99,206,.10)
}
.qs-auth-security .qs-auth-security-stat strong{
  display:block;font-size:28px;line-height:1.1;color:var(--qs-auth-text)
}
.qs-auth-security .qs-auth-security-stat span{
  display:block;margin-top:8px;color:var(--qs-auth-muted);font-size:13px;line-height:1.5
}
.qs-auth-security .qs-auth-security-stack{display:grid;gap:16px}
.qs-auth-security .qs-card-head{align-items:flex-start}
.qs-auth-security .qs-card-head h2{margin:0;font-size:24px;line-height:1.15;color:var(--qs-auth-text)}
.qs-auth-security .qs-card-head p{margin:8px 0 0;color:var(--qs-auth-muted);line-height:1.6}
.qs-auth-security .qs-kv{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.qs-auth-security .qs-kv > div{
  padding:16px 18px;border-radius:18px;background:#f7fafd;border:1px solid rgba(15,39,64,.08)
}
.qs-auth-security .qs-kv span{
  display:block;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--qs-auth-muted);margin-bottom:8px
}
.qs-auth-security .qs-kv strong{display:block;font-size:18px;line-height:1.35;color:var(--qs-auth-text);word-break:break-word}
.qs-auth-security .qs-inline-note{
  padding:16px 18px;border-radius:18px;border:1px solid rgba(15,39,64,.08);background:#f7f9fc;color:var(--qs-auth-muted);line-height:1.65
}
.qs-auth-security .qs-inline-note.is-ok{
  background:var(--qs-auth-success-soft);border-color:rgba(31,157,99,.16);color:#145c3c
}
.qs-auth-security .qs-inline-note.is-warn{
  background:var(--qs-auth-warning-soft);border-color:rgba(184,108,0,.18);color:#8a5300
}
.qs-auth-security .qs-list{display:grid;gap:12px}
.qs-auth-security .qs-list a{
  display:flex;justify-content:space-between;gap:12px;
  padding:14px 16px;border-radius:16px;background:#fff;border:1px solid rgba(15,39,64,.08);text-decoration:none;color:var(--qs-auth-text);font-weight:600
}
.qs-auth-security .qs-list a::after{content:"→";color:var(--qs-auth-primary);font-weight:700}
.qs-auth-security .qs-history-list{display:grid;gap:12px}
.qs-auth-security .qs-history-item,
.qs-auth-security .qs-session{
  display:flex;justify-content:space-between;align-items:flex-start;gap:16px;
  padding:16px 18px;border-radius:18px;border:1px solid rgba(15,39,64,.08);background:#fff
}
.qs-auth-security .qs-history-main{display:grid;gap:8px;min-width:0}
.qs-auth-security .qs-session-title{display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-size:16px;font-weight:700;color:var(--qs-auth-text)}
.qs-auth-security .qs-device-meta{display:flex;flex-wrap:wrap;gap:8px 12px;color:var(--qs-auth-muted);font-size:13px}
.qs-auth-security .qs-device-meta span{
  display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;background:#f6f9fc;border:1px solid rgba(15,39,64,.06)
}
.qs-auth-security .qs-status-pill{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:30px;padding:0 10px;border-radius:999px;background:#edf2f7;border:1px solid rgba(15,39,64,.08);font-size:12px;font-weight:700
}
.qs-auth-security .qs-status-pill.is-ok{background:var(--qs-auth-success-soft);color:#145c3c}
.qs-auth-security .qs-status-pill.is-warn{background:var(--qs-auth-warning-soft);color:#8a5300}
.qs-auth-security .qs-status-pill.is-danger,
.qs-auth-security .qs-status-pill.is-error{background:var(--qs-auth-danger-soft);color:#8f2020}

.qs-auth-security .qs-status-pill.is-bad{background:var(--qs-auth-danger-soft);color:#8f2020}
.qs-auth-security .qs-security-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.qs-auth-security .qs-status-pill.is-neutral{background:#f1f5f9;color:var(--qs-auth-muted)}
.qs-auth-security .qs-inline-actions,
.qs-auth-security .qs-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.qs-auth-security .qs-sep{border:none;height:1px;background:rgba(15,39,64,.08);margin:18px 0}
.qs-auth-security label{display:grid;gap:8px;font-size:14px;font-weight:700;color:var(--qs-auth-text)}
.qs-auth-security input,
.qs-auth-security select,
.qs-auth-security textarea{
  width:100%;min-height:50px;padding:0 14px;border-radius:14px;border:1px solid rgba(15,39,64,.12);background:#fff;font-size:15px
}
.qs-auth-security input:focus,
.qs-auth-security select:focus,
.qs-auth-security textarea:focus{
  outline:none;border-color:rgba(15,99,206,.42);box-shadow:0 0 0 4px rgba(15,99,206,.12)
}
.qs-auth-security .qs-stack-sm{display:grid;gap:12px}
.qs-auth-security .qs-form-label{font-size:14px;font-weight:700;color:var(--qs-auth-text)}
.qs-auth-security .qs-btn,
.qs-auth-security .qs-linkbtn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 14px;border-radius:14px;border:1px solid transparent;
  background:linear-gradient(135deg,var(--qs-auth-primary) 0%, var(--qs-auth-primary-strong) 100%);color:#fff;text-decoration:none;font-weight:700;box-shadow:0 14px 28px rgba(15,99,206,.20)
}
.qs-auth-security .qs-btn.is-ghost,
.qs-auth-security .qs-linkbtn{
  background:#fff;color:var(--qs-auth-text);border-color:rgba(15,39,64,.12);box-shadow:none
}
.qs-auth-security .qs-btn[disabled]{opacity:.65;cursor:not-allowed;box-shadow:none}
.qs-auth-security pre, .qs-auth-security code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}

.auth-dashboard-shell{
  max-width:960px;
  margin:0 auto;
  padding:28px 16px 88px;
}
.auth-dashboard-card{
  background:rgba(255,255,255,.96);
  border:1px solid rgba(15,39,64,.08);
  border-radius:28px;
  box-shadow:var(--qs-auth-shadow);
  padding:28px;
}
.auth-dashboard-shell h1{
  margin:10px 0 12px;
  font-size:clamp(30px, 4vw, 42px);
  line-height:1.04;
  color:var(--qs-auth-text);
}
.auth-dashboard-shell p{
  color:var(--qs-auth-muted);
  line-height:1.65;
}
.auth-dashboard-shell .card{border-radius:24px;border:1px solid rgba(15,39,64,.08);box-shadow:none}
.auth-dashboard-shell .strength{margin-top:14px;padding:16px;border-radius:18px;background:#f7fbff;border:1px solid rgba(15,99,206,.10)}
.auth-dashboard-shell .strength .bar{height:10px;border-radius:999px;background:#e7edf5;overflow:hidden}
.auth-dashboard-shell .strength .bar span{display:block;height:100%;width:0;background:linear-gradient(135deg,var(--qs-auth-warning) 0%, var(--qs-auth-success) 100%)}
.auth-dashboard-shell .strength .row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:12px}
.auth-dashboard-shell .label{font-weight:700;color:var(--qs-auth-text)}
.auth-dashboard-shell .hint{color:var(--qs-auth-muted);font-size:14px}
.auth-dashboard-shell .tips{margin-top:16px;padding:16px 18px;border-radius:18px;background:#f7f9fc;border:1px solid rgba(15,39,64,.08)}
.auth-dashboard-shell .tips-title{font-weight:800;margin-bottom:8px;color:var(--qs-auth-text)}
.auth-dashboard-shell .tips ul{margin:0;padding-left:18px;color:var(--qs-auth-muted);display:grid;gap:8px}
.auth-dashboard-shell .actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.auth-dashboard-shell .btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:50px;padding:0 16px;border-radius:16px;border:1px solid transparent;text-decoration:none;font-weight:700;
}
.auth-dashboard-shell .btn.primary{background:linear-gradient(135deg,var(--qs-auth-primary) 0%, var(--qs-auth-primary-strong) 100%);color:#fff;box-shadow:0 16px 30px rgba(15,99,206,.20)}
.auth-dashboard-shell .btn.ghost{background:#fff;color:var(--qs-auth-text);border-color:rgba(15,39,64,.12)}
.auth-dashboard-shell .alert{padding:16px 18px;border-radius:18px;margin:18px 0;border:1px solid rgba(15,39,64,.08)}
.auth-dashboard-shell .alert.error{background:var(--qs-auth-danger-soft);border-color:rgba(192,54,54,.18);color:#8f2020}
.auth-dashboard-shell .alert.ok{background:var(--qs-auth-success-soft);border-color:rgba(31,157,99,.16);color:#145c3c}
.auth-dashboard-shell .form{display:grid;gap:16px;margin-top:24px}
.auth-dashboard-shell .form label{display:grid;gap:8px;font-weight:700;color:var(--qs-auth-text)}
.auth-dashboard-shell .form input{
  width:100%;min-height:54px;padding:0 16px;border-radius:16px;border:1px solid rgba(15,39,64,.12);font-size:16px
}
.auth-dashboard-shell .form input:focus{outline:none;border-color:rgba(15,99,206,.42);box-shadow:0 0 0 4px rgba(15,99,206,.12)}

@media (max-width: 980px){
  .qs-auth-shell{grid-template-columns:1fr;padding:18px 0 28px}
  .qs-auth-side{padding:26px}
  .qs-auth-card{width:100%}
  .qs-auth-security .qs-auth-security-hero{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .qs-auth-shell{width:min(100%, calc(100% - 20px))}
  .qs-auth-side, .qs-auth-card{border-radius:24px}
  .qs-auth-card, .qs-auth-side{padding:22px}
  .qs-auth-grid.cols-2,
  .qs-auth-role-grid{grid-template-columns:1fr}
  .qs-auth-facts{grid-template-columns:1fr 1fr}
  .qs-auth-security .qs-history-item,
  .qs-auth-security .qs-session{flex-direction:column}
  .auth-dashboard-shell{padding:18px 12px 88px}
  .auth-dashboard-card{padding:22px}
}
@media (max-width: 520px){
  .qs-auth-facts{grid-template-columns:1fr}
  .qs-auth-actions > *{width:100%}
  .qs-auth-links{gap:10px}
  .qs-auth-security .qs-kv{grid-template-columns:1fr}
}


/* Signup / Verify final polish */
.qs-auth-link-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:0 18px;
  border-radius:16px;
  border:1px solid var(--qs-auth-border-strong);
  background:#fff;
  color:var(--qs-auth-text);
  font-size:15px;
  font-weight:700;
  text-decoration:none;
  box-shadow:none;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.qs-auth-link-button:hover{
  text-decoration:none;
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(15,39,64,.08);
}
.qs-auth-footer{
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid rgba(15,39,64,.08);
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:12px 18px;
  color:var(--qs-auth-muted);
  font-size:14px;
}
.qs-auth-footer p{margin:0}
.qs-auth-card-signup,
.qs-auth-card-verify{
  position:relative;
  overflow:hidden;
}
.qs-auth-card-signup::before,
.qs-auth-card-verify::before{
  content:"";
  position:absolute;
  inset:auto -120px -120px auto;
  width:240px;
  height:240px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(15,99,206,.10) 0%, rgba(15,99,206,0) 72%);
  pointer-events:none;
}
.qs-auth-card-head-signup,
.qs-auth-card-head-verify{
  align-items:center;
}


.qs-auth-brand-simple{
  margin-bottom:16px;
}
.qs-auth-brand-simple .qs-auth-brand-copy strong{
  font-size:26px;
}
.qs-auth-brand-simple .qs-auth-brand-copy span{
  margin-top:2px;
  font-size:13px;
  color:rgba(255,255,255,.78);
  text-transform:uppercase;
  letter-spacing:.05em;
}
.qs-signup-side-top-simple{
  display:grid;
  gap:0;
}
.qs-signup-side-top-simple h2{
  margin:8px 0 10px;
  font-size:clamp(30px, 4vw, 40px);
}
.qs-signup-side-top-simple p{
  max-width:34ch;
}
.qs-signup-side-bottom-simple a{
  color:#fff;
  font-weight:700;
}
.qs-auth-card-head-simple{
  margin-bottom:18px;
}
.qs-auth-card-head-simple h1{
  margin-top:0;
}
.qs-auth-card-head-simple p{
  max-width:48ch;
}
.qs-signup-role-copy{
  margin:0;
  color:var(--qs-auth-muted);
  font-size:15px;
  line-height:1.6;
}
.qs-signup-actions-single{
  justify-content:flex-end;
}
.qs-signup-step-note{
  padding:14px 16px;
  border-radius:18px;
  background:#f7fbff;
  border:1px solid rgba(15,99,206,.10);
}
.qs-signup-step-note p{
  margin:0;
  color:var(--qs-auth-muted);
  font-size:14px;
  line-height:1.6;
}
.qs-signup-step-note-password{
  margin-top:16px;
  margin-bottom:18px;
}

.qs-signup-data-form{
  align-items:start;
  row-gap:18px;
}
.qs-signup-data-form .qs-signup-data-field{
  min-width:0;
}
.qs-signup-data-form .qs-signup-data-field-primary{
  height:100%;
  padding:18px 18px 16px;
  border-radius:22px;
  border:1px solid rgba(15,39,64,.08);
  background:linear-gradient(180deg,#ffffff 0%, #fcfdff 100%);
  box-shadow:0 12px 30px rgba(11,43,76,.04);
  grid-template-rows:auto minmax(54px,auto) minmax(42px,1fr);
  gap:10px;
}
.qs-signup-data-form .qs-signup-data-field-primary label{
  min-height:20px;
}
.qs-signup-data-form .qs-signup-data-field-primary .qs-auth-help{
  margin:0;
  display:flex;
  align-items:flex-start;
}
.qs-signup-data-form .qs-signup-data-field-full{
  gap:10px;
}
.qs-signup-data-form .qs-auth-actions{
  grid-column:1 / -1;
  justify-content:space-between;
}
@media (max-width: 720px){
  .qs-signup-data-form .qs-signup-data-field-primary{
    padding:16px;
    min-height:auto;
  }
}
.qs-signup-summary{
  margin-bottom:16px;
}
.qs-signup-summary .qs-auth-summary-grid{
  gap:12px;
}
.qs-signup-summary .qs-auth-summary-item{
  padding:16px 18px;
}

.qs-signup-card-badge{
  display:grid;
  gap:6px;
  min-width:148px;
  padding:14px 16px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(15,99,206,.10) 0%, rgba(15,99,206,.04) 100%);
  border:1px solid rgba(15,99,206,.12);
  text-align:left;
}
.qs-signup-card-badge span{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--qs-auth-muted);
  font-weight:700;
}
.qs-signup-card-badge strong{
  font-size:20px;
  line-height:1.1;
  color:var(--qs-auth-text);
}
.qs-signup-progress{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:22px 0 0;
}
.qs-signup-progress span{
  height:9px;
  border-radius:999px;
  background:#e5edf6;
}
.qs-signup-progress span.is-active{
  background:linear-gradient(135deg,var(--qs-auth-primary) 0%, var(--qs-auth-primary-strong) 100%);
  box-shadow:0 10px 24px rgba(15,99,206,.20);
}
.qs-signup-progress span.is-done{
  background:linear-gradient(135deg,#58b988 0%, #1f9d63 100%);
}
.qs-signup-inline-pills{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.qs-signup-stage-rail,
.qs-verify-stage-rail{
  display:grid;
  gap:12px;
  margin:24px 0 0;
}
.qs-signup-stage-card{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 16px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08);
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}
.qs-signup-stage-card strong{
  display:block;
  font-size:15px;
  line-height:1.3;
  color:#fff;
}
.qs-signup-stage-card span:last-child{
  display:block;
  margin-top:4px;
  color:rgba(255,255,255,.78);
  font-size:13px;
  line-height:1.5;
}
.qs-signup-stage-card.is-active{
  transform:translateY(-1px);
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.24);
}
.qs-signup-stage-card.is-done{
  background:rgba(31,157,99,.22);
  border-color:rgba(155,255,208,.22);
}
.qs-signup-stage-index{
  flex:0 0 auto;
  width:34px;
  height:34px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.14);
  color:#fff;
  font-size:14px;
  font-weight:800;
}
.qs-signup-facts,
.qs-verify-facts{
  margin-top:28px;
}
.qs-signup-facts .qs-auth-fact strong,
.qs-verify-facts .qs-auth-fact strong{
  font-size:20px;
  text-transform:none;
}
.qs-signup-role-grid{
  margin-top:0;
}
.qs-signup-role-card{
  display:grid;
  gap:16px;
}
.qs-signup-role-top{
  display:flex;
  align-items:flex-start;
  gap:14px;
}
.qs-signup-role-icon{
  flex:0 0 auto;
  width:44px;
  height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:rgba(15,99,206,.10);
  font-size:22px;
}
.qs-signup-role-points,
.qs-signup-setup-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}
.qs-signup-role-points li,
.qs-signup-setup-list li{
  position:relative;
  padding-left:28px;
  color:var(--qs-auth-muted);
  font-size:14px;
  line-height:1.6;
}
.qs-signup-role-points li::before,
.qs-signup-setup-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.45em;
  width:16px;
  height:16px;
  border-radius:999px;
  background:rgba(15,99,206,.10);
  box-shadow:inset 0 0 0 4px rgba(15,99,206,.22);
}
.qs-signup-bottom-row{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  align-items:center;
  justify-content:space-between;
}
.qs-signup-note{
  display:grid;
  gap:6px;
  flex:1 1 280px;
  padding:16px 18px;
  border-radius:18px;
  background:#f7fbff;
  border:1px solid rgba(15,99,206,.10);
}
.qs-signup-note strong{
  color:var(--qs-auth-text);
  font-size:15px;
}
.qs-signup-note span{
  color:var(--qs-auth-muted);
  font-size:14px;
  line-height:1.6;
}
.qs-auth-field-full{
  grid-column:1 / -1;
}
.qs-signup-setup-grid,
.qs-signup-security-grid,
.qs-verify-status-grid,
.qs-verify-policy-grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.qs-signup-setup-card,
.qs-signup-security-card,
.qs-verify-status-card,
.qs-verify-policy-card{
  padding:20px 22px;
  border-radius:22px;
  border:1px solid rgba(15,39,64,.08);
  background:linear-gradient(180deg,#ffffff 0%, #fcfdff 100%);
  box-shadow:0 14px 34px rgba(11,43,76,.05);
}
.qs-signup-setup-card.is-soft,
.qs-signup-security-card.is-soft,
.qs-verify-status-card.is-soft,
.qs-verify-policy-card.is-soft{
  background:#f8fbff;
}
.qs-signup-setup-kicker{
  display:inline-flex;
  min-height:28px;
  align-items:center;
  padding:0 10px;
  border-radius:999px;
  background:rgba(15,99,206,.09);
  color:var(--qs-auth-primary-strong);
  font-size:12px;
  font-weight:800;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.qs-signup-setup-card h3,
.qs-signup-security-card h3,
.qs-verify-status-card h3,
.qs-verify-policy-card h3{
  margin:14px 0 10px;
  font-size:22px;
  line-height:1.15;
}
.qs-signup-setup-card p,
.qs-signup-security-card p,
.qs-verify-status-card p,
.qs-verify-policy-card p{
  margin:0;
  color:var(--qs-auth-muted);
  line-height:1.65;
}
.qs-signup-summary{
  gap:18px;
}
.qs-signup-security-grid{
  margin-top:2px;
}
.qs-verify-form{
  margin-top:16px;
}
.qs-verify-policy-card .qs-auth-list{
  margin-top:14px;
}
.qs-verify-links{
  margin-top:24px;
}
.qs-verify-links .qs-auth-btn{
  text-decoration:none;
}
.qs-verify-links .qs-auth-btn.is-ghost{
  background:#fff;
}
.qs-signup-page .qs-auth-side,
.qs-verify-page .qs-auth-side{
  padding:34px;
}
.qs-signup-page .qs-auth-main,
.qs-verify-page .qs-auth-main{
  align-items:stretch;
}
.qs-signup-page .qs-auth-card,
.qs-verify-page .qs-auth-card{
  align-self:center;
}
@media (min-width: 981px){
  .qs-signup-page .qs-auth-side,
  .qs-verify-page .qs-auth-side{
    position:sticky;
    top:24px;
    max-height:calc(100vh - 48px);
  }
}
@media (max-width: 980px){
  .qs-signup-page .qs-auth-card,
  .qs-verify-page .qs-auth-card{
    width:100%;
  }
}
@media (max-width: 720px){
  .qs-auth-card-head-signup,
  .qs-auth-card-head-verify{
    flex-direction:column;
    align-items:flex-start;
  }
  .qs-signup-setup-grid,
  .qs-signup-security-grid,
  .qs-verify-status-grid,
  .qs-verify-policy-grid{
    grid-template-columns:1fr;
  }
  .qs-signup-bottom-row{
    align-items:stretch;
  }
  .qs-signup-card-badge{
    width:100%;
  }
  .qs-signup-page .qs-auth-side,
  .qs-verify-page .qs-auth-side{
    padding:24px;
  }
}
@media (max-width: 520px){
  .qs-signup-stage-card{
    padding:12px 14px;
  }
  .qs-signup-stage-index{
    width:30px;
    height:30px;
    font-size:13px;
  }
  .qs-signup-inline-pills{
    gap:8px;
  }
}


.qs-auth-password-row{
  position:relative;
  display:block;
}
.qs-auth-password-row input{
  padding-right:68px;
}
.qs-auth-body .qs-auth-password-toggle{
  position:absolute;
  top:50%;
  right:12px;
  transform:translateY(-50%);
  width:42px;
  height:42px;
  min-width:42px;
  min-height:42px;
  padding:0;
  border-radius:999px;
  border:1px solid var(--qs-auth-border-strong);
  background:#fff;
  color:var(--qs-auth-text);
  box-shadow:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
  transition:border-color .18s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease;
}
.qs-auth-body .qs-auth-password-toggle:hover,
.qs-auth-body .qs-auth-password-toggle:active{
  transform:translateY(-50%);
  box-shadow:0 10px 22px rgba(15,39,64,.08);
}
.qs-auth-body .qs-auth-password-toggle:focus-visible{
  transform:translateY(-50%);
  outline:none;
  border-color:var(--qs-auth-primary);
  box-shadow:0 0 0 4px rgba(30,102,214,.14);
}
.qs-auth-body .qs-auth-password-toggle svg{
  width:20px;
  height:20px;
  display:block;
}
.qs-auth-toggle-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.qs-auth-toggle-icon-hide{
  display:none;
}
.qs-auth-password-toggle.is-active .qs-auth-toggle-icon-show{
  display:none;
}
.qs-auth-password-toggle.is-active .qs-auth-toggle-icon-hide{
  display:inline-flex;
}
.qs-auth-visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0, 0, 0, 0);
  white-space:nowrap;
  border:0;
}
.qs-auth-password-strength{
  padding:18px;
  border:1px solid var(--qs-auth-border);
  border-radius:20px;
  background:#fbfdff;
}
.qs-auth-strength-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.qs-auth-strength-top strong{
  font-size:15px;
  color:var(--qs-auth-text);
}
.qs-auth-strength-state{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid var(--qs-auth-border);
  background:#fff;
  color:var(--qs-auth-muted);
  font-size:13px;
  font-weight:700;
}
.qs-auth-strength-state.is-idle{
  background:#fff;
  color:var(--qs-auth-muted);
}
.qs-auth-strength-state.is-warning{
  background:var(--qs-auth-warning-soft);
  border-color:rgba(184,108,0,.18);
  color:#8a5300;
}
.qs-auth-strength-state.is-good{
  background:var(--qs-auth-primary-soft);
  border-color:rgba(15,99,206,.20);
  color:var(--qs-auth-primary-strong);
}
.qs-auth-strength-state.is-strong{
  background:var(--qs-auth-success-soft);
  border-color:rgba(31,157,99,.18);
  color:#145c3c;
}
.qs-auth-password-rules{
  list-style:none;
  padding:0;
  margin:18px 0 0;
  display:grid;
  gap:10px;
}
.qs-auth-password-rules li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid var(--qs-auth-border);
  background:#fbfdff;
  color:var(--qs-auth-text);
  font-size:14px;
  line-height:1.55;
  transition:border-color .18s ease, background-color .18s ease, color .18s ease;
}
.qs-auth-rule-dot{
  width:22px;
  height:22px;
  flex:0 0 22px;
  border-radius:999px;
  border:1px solid var(--qs-auth-border-strong);
  background:#fff;
  position:relative;
  margin-top:1px;
}
.qs-auth-password-rules li.is-pass{
  background:rgba(31,157,99,.08);
  border-color:rgba(31,157,99,.18);
}
.qs-auth-password-rules li.is-pass .qs-auth-rule-dot{
  border-color:rgba(31,157,99,.18);
  background:var(--qs-auth-success-soft);
}
.qs-auth-password-rules li.is-pass .qs-auth-rule-dot::after{
  content:"";
  position:absolute;
  inset:5px;
  border-radius:999px;
  background:var(--qs-auth-success);
}
.qs-auth-password-rules li.is-fail{
  background:#fbfdff;
  border-color:var(--qs-auth-border);
}
@media (max-width: 640px){
  .qs-auth-password-row{
    grid-template-columns:1fr;
  }
  .qs-auth-body .qs-auth-password-toggle{
    width:100%;
  }
  .qs-auth-strength-top{
    align-items:flex-start;
    flex-direction:column;
  }
}


.qs-auth-segmented{
  display:inline-flex;
  gap:8px;
  flex-wrap:wrap;
  padding:6px;
  border-radius:18px;
  background:#f3f7fb;
  border:1px solid var(--qs-auth-border);
}
.qs-auth-segmented button{
  min-height:42px;
  padding:0 14px;
  border-radius:14px;
  border:1px solid transparent;
  background:transparent;
  color:var(--qs-auth-muted);
  font-weight:700;
  box-shadow:none;
}
.qs-auth-segmented button.is-active{
  background:#fff;
  color:var(--qs-auth-primary-strong);
  border-color:rgba(15,99,206,.18);
}

.qs-twofa-qr-card{
  display:grid;
  grid-template-columns:minmax(180px, 220px) minmax(0,1fr);
  gap:18px;
  align-items:center;
  padding:18px;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(15,39,64,.08);
}
.qs-twofa-qr{
  width:min(220px, 100%);
  aspect-ratio:1 / 1;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(15,39,64,.08);
  background:#fff;
  display:grid;
  place-items:center;
}
.qs-twofa-qr svg{width:100%;height:100%;display:block}
.qs-twofa-qr-meta{display:grid;gap:12px;min-width:0}
.qs-twofa-code-row{
  display:grid;
  gap:10px;
}
.qs-twofa-code-box{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(15,39,64,.08);
  background:#fff;
}
.qs-twofa-code-box code{
  display:block;
  max-width:100%;
  overflow:auto hidden;
  white-space:nowrap;
  font-size:14px;
}
.qs-twofa-code-hint{font-size:13px;color:var(--qs-auth-muted);line-height:1.55}
.qs-twofa-otp{
  display:grid;
  grid-template-columns:repeat(6, minmax(44px, 1fr));
  gap:10px;
  max-width:420px;
}
.qs-twofa-otp-box{
  min-height:58px;
  padding:0;
  text-align:center;
  font-size:24px;
  font-weight:800;
  letter-spacing:0.02em;
}
.qs-twofa-stack{
  display:grid;
  gap:12px;
}
.qs-twofa-field-note{
  font-size:13px;
  color:var(--qs-auth-muted);
  line-height:1.55;
}
.qs-twofa-backup-input{
  max-width:220px;
  letter-spacing:0.08em;
  font-weight:700;
}
.qs-twofa-hidden-token{display:none}
.qs-twofa-inline-grid{
  display:grid;
  gap:14px;
}

@media (max-width: 900px){
  .qs-twofa-qr-card{
    grid-template-columns:1fr;
  }
}
@media (max-width: 560px){
  .qs-twofa-otp{
    grid-template-columns:repeat(6, minmax(36px, 1fr));
    gap:8px;
  }
  .qs-twofa-otp-box{
    min-height:52px;
    font-size:22px;
  }
}

.qs-auth-badge{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:13px;
  font-weight:700;
  letter-spacing:.02em;
}
.qs-auth-subtitle{
  margin:0 0 6px;
  color:var(--qs-auth-muted);
  font-size:15px;
  line-height:1.7;
}
.qs-auth-points{
  display:grid;
  gap:12px;
  margin:24px 0 0;
  padding:0;
  list-style:none;
}
.qs-auth-points li{
  display:grid;
  gap:6px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14);
}
.qs-auth-points b{
  display:block;
  font-size:15px;
  margin-bottom:4px;
}
.qs-auth-points span{
  display:block;
  color:rgba(255,255,255,.82);
  font-size:14px;
  line-height:1.6;
}


/* Login polish */
.qs-login-page .qs-auth-shell{
  width:min(1080px, calc(100% - 32px));
  gap:24px;
  padding:20px 0 26px;
  align-items:center;
}
.qs-login-side{
  min-height:clamp(640px, 76vh, 760px);
  padding:30px 28px;
  justify-content:flex-start;
  gap:22px;
  align-self:center;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.14) 0%, rgba(255,255,255,0) 36%),
    linear-gradient(180deg, rgba(15,99,206,.94) 0%, rgba(9,74,156,.98) 100%);
}
.qs-login-page .qs-auth-brand{
  margin-bottom:18px;
}
.qs-login-page .qs-auth-brand-copy strong{
  font-size:24px;
}
.qs-login-page .qs-auth-brand-copy span{
  margin-top:4px;
  font-size:15px;
}
.qs-login-page .qs-auth-eyebrow{
  min-height:34px;
  padding:0 12px;
  font-size:13px;
}
.qs-login-page .qs-auth-side h2{
  margin:18px 0 12px;
  font-size:clamp(34px, 4vw, 48px);
  line-height:1.02;
}
.qs-login-page .qs-auth-side p{
  font-size:16px;
  line-height:1.62;
  max-width:31ch;
}
.qs-login-page .qs-auth-side-bottom{
  margin-top:auto;
  padding-top:22px;
  font-size:13px;
  line-height:1.58;
  color:rgba(255,255,255,.76);
  max-width:31ch;
}
.qs-login-card{
  width:min(100%, 540px);
  padding:26px;
  overflow:hidden;
}
.qs-login-head{
  display:block;
  margin-bottom:16px;
}
.qs-login-head-copy{
  display:grid;
  gap:0;
}
.qs-login-head-copy h1{
  margin-bottom:8px;
}
.qs-login-head-copy p{
  max-width:42ch;
}
.qs-login-return-alert{
  margin-top:0;
}
.qs-login-form{
  margin-top:18px;
}
.qs-login-label-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:10px 14px;
}
.qs-login-inline-link{
  font-size:14px;
  font-weight:700;
}
.qs-login-actions{
  margin-top:4px;
}
.qs-login-submit{
  flex:1 1 220px;
}
.qs-login-links{
  width:100%;
  margin-top:0;
  justify-content:center;
  text-align:center;
}
.qs-login-page .qs-auth-alert{
  line-height:1.55;
}
.qs-login-page .qs-auth-card p{
  max-width:50ch;
}
.qs-login-page .qs-auth-help{
  max-width:48ch;
}
@media (max-width: 980px){
  .qs-login-page .qs-auth-shell{
    gap:18px;
    padding:16px 0 24px;
  }
  .qs-auth-side-balanced,
  .qs-login-side{
    min-height:auto;
    align-self:stretch;
  }
  .qs-login-page .qs-auth-side p,
  .qs-login-page .qs-auth-side-bottom,
  .qs-auth-side-balanced .qs-auth-brand-copy span,
  .qs-auth-side-balanced > .qs-auth-side-top > p,
  .qs-auth-side-balanced .qs-auth-side-bottom{
    max-width:none;
  }
}
@media (max-width: 720px){
  .qs-login-page .qs-auth-shell{
    width:min(100%, calc(100% - 22px));
    padding:12px 0 18px;
  }
  .qs-auth-side-balanced,
  .qs-login-side{
    padding:22px;
    gap:16px;
  }
  .qs-login-card{
    padding:22px;
  }
  .qs-auth-side-balanced h2,
  .qs-login-page .qs-auth-side h2{
    font-size:30px;
  }
  .qs-auth-brand-copy strong,
  .qs-login-page .qs-auth-brand-copy strong{
    font-size:22px;
  }
}


/* --- Milestone 12: final calm auth UI --- */
body.qs-auth-body.qs-auth-verify-page{
  background:
    radial-gradient(circle at top left, #f7fbff 0%, #f3f7fc 42%, #eef3f8 100%);
}
.qs-auth-shell--verify{
  grid-template-columns:minmax(260px, 330px) minmax(0, 1fr);
  gap:22px;
  padding:28px 0 34px;
}
.qs-auth-verify-page .qs-auth-side{
  background:linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(245,249,255,.98) 100%);
  color:var(--qs-auth-text);
  border:1px solid rgba(15,39,64,.10);
  box-shadow:0 18px 46px rgba(15,39,64,.08);
}
.qs-auth-verify-page .qs-auth-side::before,
.qs-auth-verify-page .qs-auth-side::after{
  background:rgba(15,99,206,.06);
}
.qs-auth-verify-page .qs-auth-badge{
  background:rgba(15,99,206,.08);
  color:var(--qs-auth-primary-strong);
  border:1px solid rgba(15,99,206,.14);
}
.qs-auth-verify-page .qs-auth-side p,
.qs-auth-verify-page .qs-auth-points span{
  color:#5c6f83;
}
.qs-auth-verify-page .qs-auth-points{
  gap:10px;
}
.qs-auth-verify-page .qs-auth-points li{
  padding:14px 0;
  border-top:1px solid rgba(15,39,64,.08);
  display:grid;
  grid-template-columns:1fr;
}
.qs-auth-verify-page .qs-auth-points li:first-child{
  border-top:0;
  padding-top:0;
}
.qs-auth-verify-page .qs-auth-card{
  padding:30px;
}
.qs-auth-verify-page .qs-auth-note,
.qs-auth-verify-page .qs-auth-alert{
  border-radius:18px;
}
.qs-auth-verify-page .qs-auth-segmented{
  background:rgba(15,39,64,.04);
  padding:6px;
}
.qs-auth-verify-page .qs-auth-segmented button{
  min-height:46px;
  font-weight:700;
}
.qs-auth-verify-page .qs-auth-otp{
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:10px;
  margin-top:6px;
}
.qs-auth-verify-page .qs-auth-otp-digit{
  width:100%;
  min-width:0;
  min-height:58px;
  border-radius:16px;
  border:1px solid rgba(15,39,64,.12);
  background:#fff;
  text-align:center;
  font-size:1.3rem;
  font-weight:800;
  color:var(--qs-auth-text);
  box-shadow:inset 0 1px 2px rgba(15,39,64,.03);
}
.qs-auth-verify-page .qs-auth-otp-digit:focus{
  outline:none;
  border-color:rgba(15,99,206,.55);
  box-shadow:0 0 0 4px rgba(15,99,206,.12);
}
.qs-auth-verify-page .qs-auth-backup-input{
  min-height:56px;
  border-radius:16px;
  border:1px solid rgba(15,39,64,.12);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:700;
}
.qs-auth-verify-page .qs-auth-actions{
  margin-top:8px;
}
.qs-auth-verify-page .qs-auth-actions button,
.qs-auth-verify-page .qs-auth-actions .qs-auth-btn{
  min-height:50px;
}
@media (max-width: 900px){
  .qs-auth-shell--verify{
    grid-template-columns:1fr;
  }
}
@media (max-width: 560px){
  .qs-auth-verify-page .qs-auth-card{
    padding:22px;
  }
  .qs-auth-verify-page .qs-auth-otp{
    gap:8px;
  }
  .qs-auth-verify-page .qs-auth-otp-digit{
    min-height:52px;
    font-size:1.15rem;
  }
}


/* Generic verify / OTP components */
.qs-auth-mode-panel{
  display:grid;
  gap:10px;
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(15,39,64,.08);
  background:linear-gradient(180deg, #fbfdff 0%, #f6f9fd 100%);
}
.qs-auth-mode-panel[hidden]{display:none !important;}
.qs-auth-mode-panel label{
  font-size:14px;
  font-weight:700;
  color:var(--qs-auth-text);
}
.qs-auth-mode-copy{
  font-size:13px;
  line-height:1.55;
  color:var(--qs-auth-muted);
}
.qs-auth-otp{
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 56px));
  gap:10px;
}
.qs-auth-otp-digit{
  width:56px !important;
  min-width:56px;
  height:56px !important;
  min-height:56px;
  padding:0 !important;
  border-radius:18px !important;
  text-align:center;
  font-size:24px !important;
  font-weight:800;
  letter-spacing:0;
  border:1px solid rgba(15,39,64,.14) !important;
  background:#fff;
  box-shadow:none !important;
}
.qs-auth-otp-digit:focus{
  border-color:rgba(15,99,206,.36) !important;
  box-shadow:0 0 0 4px rgba(15,99,206,.12) !important;
}
.qs-auth-backup-input{
  max-width:260px;
  font-size:20px !important;
  letter-spacing:.14em;
  font-weight:800;
  text-transform:uppercase;
}
.qs-auth-inline--choice{
  align-items:flex-start;
  gap:12px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(15,39,64,.08);
  background:#f8fbff;
  position:relative;
  cursor:pointer;
}
.qs-auth-inline--choice input[type="checkbox"]{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.qs-auth-choice-control{
  width:22px;
  height:22px;
  flex:0 0 22px;
  border-radius:7px;
  border:1.5px solid rgba(15,39,64,.24);
  background:linear-gradient(180deg, #ffffff 0%, #f4f8fc 100%);
  margin-top:1px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.92),
    0 1px 2px rgba(15,39,64,.06);
  transition:border-color .18s ease, background .18s ease, box-shadow .18s ease, transform .18s ease;
  position:relative;
}
.qs-auth-choice-control::after{
  content:"";
  position:absolute;
  width:6px;
  height:11px;
  left:7px;
  top:3px;
  border-right:2.5px solid transparent;
  border-bottom:2.5px solid transparent;
  transform:rotate(42deg) scale(.82);
  transform-origin:center;
  opacity:0;
  transition:opacity .16s ease, border-color .16s ease, transform .16s ease;
}
.qs-auth-inline--choice input[type="checkbox"]:focus + .qs-auth-choice-control{
  box-shadow:
    0 0 0 4px rgba(15,99,206,.12),
    0 1px 2px rgba(15,39,64,.08);
  border-color:rgba(15,99,206,.34);
}
.qs-auth-inline--choice input[type="checkbox"]:checked + .qs-auth-choice-control{
  background:linear-gradient(135deg, var(--qs-auth-primary) 0%, var(--qs-auth-primary-strong) 100%);
  border-color:transparent;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.16),
    0 6px 14px rgba(15,99,206,.18);
}
.qs-auth-inline--choice input[type="checkbox"]:checked + .qs-auth-choice-control::after{
  opacity:1;
  border-color:#fff;
  transform:rotate(45deg) scale(1);
}
.qs-auth-inline--choice input[type="checkbox"]:disabled + .qs-auth-choice-control{
  opacity:.5;
}
.qs-auth-choice-copy{
  display:grid;
  gap:4px;
  color:var(--qs-auth-muted);
  font-size:13px;
  line-height:1.55;
}
.qs-auth-choice-copy strong{
  color:var(--qs-auth-text);
  font-size:14px;
  line-height:1.35;
}
.qs-auth-body.qs-auth-is-submitting #twofa-submit.is-loading{
  opacity:.9;
  pointer-events:none;
  cursor:progress;
}
.qs-auth-body.qs-auth-is-submitting #twofa-submit.is-loading::after{
  content:"";
  width:15px;
  height:15px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.35);
  border-top-color:#fff;
  animation:qsVerifySpin .75s linear infinite;
}
@keyframes qsVerifySpin{
  to{transform:rotate(360deg);}
}


/* Verify page shell + sidebar/layout overrides */
.qs-verify-page .qs-auth-shell{
  width:min(1080px, calc(100% - 32px));
  gap:22px;
  padding:18px 0 28px;
  align-items:center;
}

.qs-verify-page .qs-auth-side{
  min-height:0;
  padding:26px 24px;
  background:linear-gradient(180deg, rgba(10,46,86,.96) 0%, rgba(14,69,128,.98) 100%);
}

.qs-verify-page .qs-auth-side::before{width:180px;height:180px;top:-88px;right:-70px;background:rgba(255,255,255,.08)}
.qs-verify-page .qs-auth-side::after{width:140px;height:140px;left:-46px;bottom:-58px;background:rgba(255,255,255,.07)}

.qs-verify-page .qs-auth-badge{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.14);
  color:rgba(255,255,255,.94);
}

.qs-verify-page .qs-auth-side h1{
  margin:16px 0 10px;
  font-size:clamp(30px, 4vw, 38px);
  line-height:1.04;
  letter-spacing:-.02em;
}

.qs-verify-page .qs-auth-side p{
  color:rgba(255,255,255,.84);
  font-size:15px;
  line-height:1.65;
}

.qs-verify-page .qs-auth-points{
  margin-top:18px;
  gap:10px;
}

.qs-verify-page .qs-auth-points li{
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.10);
  padding:13px 15px;
}

.qs-verify-page .qs-auth-points b{
  font-size:14px;
  letter-spacing:.01em;
}

.qs-verify-page .qs-auth-points span{
  font-size:13px;
  line-height:1.55;
  color:rgba(255,255,255,.78);
}

.qs-verify-page .qs-auth-card{
  width:min(100%, 620px);
  padding:30px 30px 28px;
}

.qs-verify-page .qs-auth-subtitle{
  max-width:52ch;
  margin-bottom:2px;
}

.qs-verify-page .qs-auth-note,
.qs-verify-page .qs-auth-alert{
  margin-top:14px;
}

.qs-verify-page .qs-auth-note{
  background:#f7faff;
  border-color:rgba(15,39,64,.08);
}

.qs-verify-page .qs-auth-grid{
  gap:14px;
  margin-top:20px;
}

.qs-verify-page .qs-auth-segmented{
  width:fit-content;
}

.qs-verify-page .qs-auth-segmented button{
  min-width:150px;
}

.qs-verify-page #trust-device-help{
  margin-top:-4px;
  padding-left:4px;
}

.qs-verify-page .qs-auth-actions{
  margin-top:18px;
}

@media (max-width: 900px){
  .qs-verify-page .qs-auth-shell{
    width:min(720px, calc(100% - 24px));
    grid-template-columns:1fr;
    gap:18px;
    padding:14px 0 24px;
  }

  .qs-verify-page .qs-auth-side{
    padding:22px 20px;
  }

  .qs-verify-page .qs-auth-card{
    width:100%;
    padding:24px 20px;
  }

  .qs-auth-otp{
    grid-template-columns:repeat(6, minmax(0, 1fr));
  }

  .qs-auth-otp-digit{
    width:100% !important;
    min-width:0;
  }
}

@media (max-width: 520px){
  .qs-verify-page .qs-auth-card{
    padding:22px 16px;
    border-radius:24px;
  }

  .qs-verify-page .qs-auth-side{
    border-radius:24px;
  }

  .qs-auth-otp{
    gap:8px;
  }

  .qs-auth-otp-digit{
    height:52px !important;
    min-height:52px;
    border-radius:16px !important;
    font-size:22px !important;
  }

  .qs-verify-page .qs-auth-segmented{
    width:100%;
  }

  .qs-verify-page .qs-auth-segmented button{
    flex:1 1 0;
    min-width:0;
    padding:0 12px;
  }

  .qs-auth-backup-input{
    max-width:none;
    width:100%;
    letter-spacing:.12em;
  }
}


/* Twofa recovery page polish */
.qs-auth-body--recovery{
  overflow:hidden;
}
.qs-auth-body--recovery .qs-auth-shell{
  width:min(1240px, calc(100% - 40px));
  min-height:calc(100vh - var(--qs-header-h, 80px));
  padding:16px 0 18px;
  gap:20px;
  grid-template-columns:minmax(280px, 360px) minmax(0, 1fr);
  align-items:center;
}
.qs-auth-body--recovery .qs-auth-main{
  display:flex;
  align-items:center;
  justify-content:center;
}
.qs-auth-body--recovery .qs-auth-side{
  padding:24px 24px 22px;
}
.qs-auth-body--recovery .qs-auth-brand{
  gap:0;
  margin-bottom:12px;
}
.qs-auth-body--recovery .qs-auth-brand-copy strong{
  font-size:22px;
}
.qs-auth-body--recovery .qs-auth-brand-copy span{
  margin-top:3px;
  font-size:13px;
  line-height:1.45;
}
.qs-auth-body--recovery .qs-auth-side h2{
  margin:14px 0 10px;
  font-size:clamp(24px, 3vw, 34px);
  line-height:1.02;
}
.qs-auth-body--recovery .qs-auth-side p{
  font-size:15px;
  line-height:1.55;
}
.qs-auth-body--recovery .qs-auth-side-list{
  gap:10px;
  margin-top:18px;
}
.qs-auth-body--recovery .qs-auth-side-list li{
  padding:14px 16px;
}
.qs-auth-body--recovery .qs-auth-card{
  width:min(100%, 640px);
  max-height:calc(100vh - var(--qs-header-h, 80px) - 36px);
  padding:26px 28px;
  overflow:auto;
}
.qs-auth-body--recovery .qs-auth-card-head{
  margin-bottom:14px;
}
.qs-auth-body--recovery .qs-auth-card h1{
  margin:8px 0 8px;
  font-size:clamp(24px, 3.2vw, 34px);
}
.qs-auth-body--recovery .qs-auth-card p{
  font-size:15px;
  line-height:1.55;
}
.qs-auth-body--recovery .qs-auth-alert{
  margin-top:14px;
  padding:14px 16px;
  line-height:1.5;
}
.qs-auth-body--recovery .qs-auth-grid{
  margin-top:18px;
  gap:12px;
}
.qs-auth-body--recovery .qs-auth-field label{
  font-size:13px;
}
.qs-auth-body--recovery .qs-auth-help{
  font-size:12px;
  line-height:1.45;
}
.qs-auth-body--recovery .qs-auth-actions{
  margin-top:16px;
}
.qs-auth-body--recovery .qs-auth-card::-webkit-scrollbar{
  width:10px;
}
.qs-auth-body--recovery .qs-auth-card::-webkit-scrollbar-thumb{
  background:rgba(15,99,206,.18);
  border-radius:999px;
}

@media (max-width: 980px){
  .qs-auth-body--recovery{
    overflow:auto;
  }
  .qs-auth-body--recovery .qs-auth-shell{
    width:min(100%, calc(100% - 24px));
    min-height:unset;
    padding:18px 0 28px;
    grid-template-columns:1fr;
    align-items:start;
  }
  .qs-auth-body--recovery .qs-auth-main{
    display:block;
  }
  .qs-auth-body--recovery .qs-auth-card{
    width:100%;
    max-height:none;
    overflow:visible;
  }
}


/* --- Milestone 7: auth help / support finishing --- */
.qs-auth-side-bottom-links{
  display:grid;
  gap:12px;
}
.qs-auth-side-link-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.qs-auth-side-link,
.qs-auth-side-link:link,
.qs-auth-side-link:visited,
.qs-auth-side-link:active{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  font-weight:700;
  line-height:1;
  text-decoration:none;
  box-shadow:0 8px 18px rgba(3, 24, 53, .14);
}
.qs-auth-side-link:hover{
  background:rgba(255,255,255,.22);
  color:#fff;
  text-decoration:none;
}
.qs-auth-side-link.is-strong{
  background:#fff;
  color:var(--qs-auth-primary-strong);
  border-color:rgba(255,255,255,.82);
}
.qs-auth-side-link.is-strong:hover{
  background:#f4f8ff;
  color:var(--qs-auth-primary-strong);
}
.qs-auth-links-support{
  justify-content:center;
  text-align:center;
}
.qs-auth-links-support a,
.qs-login-links a{
  font-weight:700;
}
.qs-auth-side-bottom a{
  text-decoration:none;
}
.qs-auth-side-bottom a:focus-visible,
.qs-auth-links a:focus-visible{
  outline:2px solid rgba(15,99,206,.28);
  outline-offset:3px;
}


/* --- CSS-only redo: 2FA recovery desktop compact layout --- */
@media (min-width: 981px){
  .qs-auth-body--recovery{
    overflow:hidden;
  }

  .qs-auth-body--recovery .qs-auth-shell{
    width:min(1320px, calc(100% - 40px));
    min-height:calc(100vh - var(--qs-header-h, 80px));
    padding:14px 0 16px;
    gap:28px;
    grid-template-columns:minmax(360px, 440px) minmax(0, 660px);
    align-items:center;
    justify-content:center;
  }

  .qs-auth-body--recovery .qs-auth-side{
    min-height:clamp(660px, 78vh, 780px);
    padding:28px 24px 26px;
    align-self:center;
  }

  .qs-auth-body--recovery .qs-auth-brand{
    margin-bottom:10px;
  }

  .qs-auth-body--recovery .qs-auth-brand-copy strong{
    font-size:20px;
    line-height:1.05;
  }

  .qs-auth-body--recovery .qs-auth-brand-copy span{
    font-size:12px;
    line-height:1.35;
  }

  .qs-auth-body--recovery .qs-auth-side h2{
    margin:12px 0 10px;
    font-size:clamp(25px, 2.8vw, 42px);
    line-height:1.02;
  }

  .qs-auth-body--recovery .qs-auth-side > p,
  .qs-auth-body--recovery .qs-auth-side p{
    font-size:14px;
    line-height:1.5;
  }

  .qs-auth-body--recovery .qs-auth-side-list{
    gap:10px;
    margin-top:18px;
  }

  .qs-auth-body--recovery .qs-auth-side-list li{
    padding:12px 14px;
    border-radius:16px;
  }

  .qs-auth-body--recovery .qs-auth-side-list b{
    font-size:14px;
    margin-bottom:2px;
  }

  .qs-auth-body--recovery .qs-auth-side-list span{
    font-size:13px;
    line-height:1.45;
  }

  .qs-auth-body--recovery .qs-auth-card{
    width:min(100%, 660px);
    max-height:none;
    overflow:hidden;
    padding:24px 24px 22px;
    align-self:center;
  }

  .qs-auth-body--recovery .qs-auth-card-head{
    margin-bottom:10px;
  }

  .qs-auth-body--recovery .qs-auth-card h1{
    margin:6px 0 8px;
    font-size:clamp(24px, 2.7vw, 40px);
    line-height:1.04;
  }

  .qs-auth-body--recovery .qs-auth-card h3{
    margin:10px 0 4px;
    font-size:19px;
    line-height:1.2;
  }

  .qs-auth-body--recovery .qs-auth-card p,
  .qs-auth-body--recovery .qs-auth-help{
    font-size:14px;
    line-height:1.48;
  }

  .qs-auth-body--recovery .qs-auth-alert{
    margin-top:12px;
    padding:12px 14px;
    border-radius:16px;
    font-size:13px;
    line-height:1.42;
  }

  .qs-auth-body--recovery .qs-auth-grid{
    margin-top:14px;
    gap:10px;
  }

  .qs-auth-body--recovery .qs-auth-actions{
    margin-top:14px;
  }

  .qs-auth-body--recovery .qs-auth-btn,
  .qs-auth-body--recovery .qs-auth-actions .qs-auth-btn{
    min-height:46px;
  }
}


/* =================================================================
   LOGIN + SIGNUP — MOBILE AUTH-PANEL KOMPAKT
   Milestone 5
   Scope: nur Mobile Login/Signup; Desktop/iPad bleiben unverändert
================================================================= */
@media (max-width: 700px){
  body.qs-auth-body.qs-login-page,
  body.qs-auth-body.qs-signup-page{
    overflow-x:hidden;
    background:
      radial-gradient(circle at top left, #f7fbff 0%, #eef5fc 44%, #edf3f8 100%);
  }

  .qs-login-page .qs-auth-shell,
  .qs-signup-page .qs-auth-shell,
  .qs-signup-page .qs-auth-shell-signup{
    width:100%;
    min-height:auto;
    padding:10px 12px 24px;
    gap:12px;
    align-items:start;
  }

  .qs-login-page .qs-auth-main,
  .qs-signup-page .qs-auth-main{
    width:100%;
    min-width:0;
  }

  /* Blaues Desktop-Panel wird am Handy zum kompakten Flow-Header */
  .qs-login-page .qs-auth-side,
  .qs-signup-page .qs-auth-side,
  .qs-login-page .qs-login-side,
  .qs-signup-page .qs-auth-side-signup{
    min-height:0;
    align-self:stretch;
    justify-content:flex-start;
    gap:10px;
    padding:18px;
    border-radius:22px;
    box-shadow:0 14px 34px rgba(11,43,76,.12);
  }

  .qs-login-page .qs-auth-side::before,
  .qs-signup-page .qs-auth-side::before{
    width:150px;
    height:150px;
    top:-70px;
    right:-42px;
    opacity:.65;
  }

  .qs-login-page .qs-auth-side::after,
  .qs-signup-page .qs-auth-side::after{
    width:120px;
    height:120px;
    left:-42px;
    bottom:-62px;
    opacity:.45;
  }

  .qs-login-page .qs-auth-brand,
  .qs-signup-page .qs-auth-brand,
  .qs-signup-page .qs-auth-brand-simple{
    margin:0 0 8px;
    gap:10px;
  }

  .qs-login-page .qs-auth-brand-copy strong,
  .qs-signup-page .qs-auth-brand-copy strong,
  .qs-signup-page .qs-auth-brand-simple .qs-auth-brand-copy strong{
    font-size:21px;
    line-height:1.05;
  }

  .qs-login-page .qs-auth-brand-copy span,
  .qs-signup-page .qs-auth-brand-copy span,
  .qs-signup-page .qs-auth-brand-simple .qs-auth-brand-copy span{
    margin-top:2px;
    font-size:11px;
    line-height:1.35;
    letter-spacing:.06em;
    opacity:.82;
  }

  .qs-login-page .qs-auth-eyebrow{
    min-height:26px;
    width:max-content;
    padding:0 10px;
    font-size:11px;
  }

  .qs-login-page .qs-auth-side h2,
  .qs-signup-page .qs-auth-side h2,
  .qs-signup-page .qs-signup-side-top-simple h2{
    margin:4px 0 4px;
    font-size:clamp(22px, 7.4vw, 29px);
    line-height:1.08;
    letter-spacing:-.02em;
  }

  .qs-login-page .qs-auth-side p,
  .qs-signup-page .qs-auth-side p,
  .qs-signup-page .qs-signup-side-top-simple p{
    max-width:none;
    font-size:14px;
    line-height:1.45;
  }

  /* Lange Desktop-Zusatzinfos auf Mobile ausblenden, damit das Formular schneller sichtbar ist */
  .qs-login-page .qs-auth-side-bottom,
  .qs-login-page .qs-auth-side-bottom-links,
  .qs-signup-page .qs-auth-side-bottom,
  .qs-signup-page .qs-signup-facts,
  .qs-signup-page .qs-verify-facts,
  .qs-login-page .qs-auth-points,
  .qs-signup-page .qs-auth-points{
    display:none;
  }

  /* Signup-Fortschritt bleibt sichtbar, aber als kompakte Statusleiste */
  .qs-signup-page .qs-signup-stage-rail{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:8px;
    margin:12px 0 0;
  }

  .qs-signup-page .qs-signup-stage-card{
    min-width:0;
    min-height:46px;
    padding:8px;
    gap:7px;
    align-items:center;
    border-radius:15px;
  }

  .qs-signup-page .qs-signup-stage-index{
    width:25px;
    height:25px;
    font-size:12px;
  }

  .qs-signup-page .qs-signup-stage-card strong{
    font-size:12px;
    line-height:1.15;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .qs-signup-page .qs-signup-stage-card span:last-child{
    display:none;
  }

  /* Formular-Card als Hauptinhalt priorisieren */
  .qs-login-page .qs-auth-card,
  .qs-signup-page .qs-auth-card,
  .qs-login-page .qs-login-card,
  .qs-signup-page .qs-auth-card-signup{
    width:100%;
    padding:18px;
    border-radius:22px;
    box-shadow:0 14px 36px rgba(11,43,76,.08);
  }

  .qs-login-page .qs-auth-card-head,
  .qs-signup-page .qs-auth-card-head,
  .qs-signup-page .qs-auth-card-head-simple{
    display:block;
    margin-bottom:12px;
  }

  .qs-login-page .qs-auth-card h1,
  .qs-signup-page .qs-auth-card h1{
    margin:4px 0 8px;
    font-size:clamp(25px, 8vw, 34px);
    line-height:1.08;
    letter-spacing:-.025em;
  }

  .qs-login-page .qs-auth-card p,
  .qs-signup-page .qs-auth-card p,
  .qs-login-page .qs-auth-help,
  .qs-signup-page .qs-auth-help{
    font-size:14px;
    line-height:1.5;
  }

  .qs-login-page .qs-auth-grid,
  .qs-signup-page .qs-auth-grid{
    gap:12px;
    margin-top:14px;
  }

  .qs-login-page .qs-auth-grid.cols-2,
  .qs-signup-page .qs-auth-grid.cols-2,
  .qs-signup-page .qs-signup-data-form{
    grid-template-columns:1fr;
  }

  .qs-login-page .qs-auth-field,
  .qs-signup-page .qs-auth-field,
  .qs-login-page .qs-auth-fieldset,
  .qs-signup-page .qs-auth-fieldset{
    gap:7px;
  }

  .qs-login-page .qs-auth-field label,
  .qs-signup-page .qs-auth-field label,
  .qs-login-page .qs-auth-label,
  .qs-signup-page .qs-auth-label{
    font-size:13px;
  }

  .qs-login-page .qs-auth-field input,
  .qs-login-page .qs-auth-input,
  .qs-login-page input[type="text"],
  .qs-login-page input[type="email"],
  .qs-login-page input[type="password"],
  .qs-signup-page .qs-auth-field input,
  .qs-signup-page .qs-auth-input,
  .qs-signup-page input[type="text"],
  .qs-signup-page input[type="email"],
  .qs-signup-page input[type="password"],
  .qs-signup-page input[type="tel"],
  .qs-signup-page select{
    min-height:48px;
    padding:0 14px;
    border-radius:14px;
    font-size:16px;
  }

  .qs-login-page textarea,
  .qs-signup-page textarea{
    min-height:96px;
    padding:12px 14px;
    border-radius:14px;
    font-size:16px;
  }

  .qs-login-page .qs-auth-actions,
  .qs-signup-page .qs-auth-actions{
    margin-top:14px;
    gap:10px;
  }

  .qs-login-page .qs-auth-btn,
  .qs-login-page .qs-auth-body button,
  .qs-login-page button,
  .qs-signup-page .qs-auth-btn,
  .qs-signup-page .qs-auth-body button,
  .qs-signup-page button,
  .qs-signup-page .qs-auth-link-button{
    min-height:48px;
    border-radius:15px;
    font-size:15px;
  }

  .qs-signup-page .qs-auth-link-button{
    flex:1 1 130px;
  }

  .qs-signup-page .qs-signup-actions-single{
    justify-content:stretch;
  }

  .qs-signup-page .qs-signup-actions-single button,
  .qs-login-page .qs-login-submit{
    width:100%;
    flex:1 1 100%;
  }

  /* Signup-Rollenauswahl kompakter */
  .qs-signup-page .qs-auth-role-grid,
  .qs-signup-page .qs-signup-role-grid{
    grid-template-columns:1fr;
    gap:10px;
  }

  .qs-signup-page .qs-auth-role-card,
  .qs-signup-page .qs-signup-role-card{
    padding:14px;
    border-radius:18px;
    gap:10px;
  }

  .qs-signup-page .qs-signup-role-top{
    gap:12px;
    align-items:center;
  }

  .qs-signup-page .qs-signup-role-icon{
    width:36px;
    height:36px;
    border-radius:12px;
    font-size:18px;
  }

  .qs-signup-page .qs-auth-role-card h3{
    margin-bottom:4px;
    font-size:18px;
  }

  .qs-signup-page .qs-auth-role-card p,
  .qs-signup-page .qs-signup-role-copy{
    font-size:13px;
    line-height:1.45;
  }

  .qs-signup-page .qs-signup-role-copy{
    margin-top:-2px;
  }

  .qs-signup-page .qs-signup-progress{
    gap:8px;
    margin:14px 0 0;
  }

  .qs-signup-page .qs-signup-progress span{
    height:7px;
  }

  /* Signup Step 2/3: Eingabekarten und Hinweise kürzer */
  .qs-signup-page .qs-signup-data-form .qs-signup-data-field-primary,
  .qs-signup-page .qs-signup-step-note,
  .qs-signup-page .qs-auth-alert,
  .qs-login-page .qs-auth-alert{
    padding:12px 14px;
    border-radius:17px;
  }

  .qs-signup-page .qs-signup-data-form .qs-auth-actions{
    grid-column:auto;
  }

  .qs-signup-page .qs-signup-card-badge{
    min-width:0;
    padding:10px 12px;
    border-radius:14px;
  }

  .qs-signup-page .qs-signup-card-badge strong{
    font-size:17px;
  }

  .qs-signup-page .qs-signup-inline-pills{
    gap:8px;
    margin-top:12px;
  }

  .qs-signup-page .qs-signup-setup-list{
    gap:8px;
  }

  .qs-signup-page .qs-signup-setup-list li,
  .qs-signup-page .qs-signup-role-points li{
    padding-left:24px;
    font-size:13px;
    line-height:1.45;
  }

  .qs-login-page .qs-auth-footer,
  .qs-signup-page .qs-auth-footer{
    margin-top:16px;
    padding-top:14px;
    gap:10px;
    font-size:13px;
  }

  .qs-login-page .qs-auth-links,
  .qs-signup-page .qs-auth-links,
  .qs-login-page .qs-login-links{
    gap:10px;
    justify-content:center;
  }
}

@media (max-width: 380px){
  .qs-login-page .qs-auth-shell,
  .qs-signup-page .qs-auth-shell{
    padding:8px 10px 22px;
    gap:10px;
  }

  .qs-login-page .qs-auth-side,
  .qs-signup-page .qs-auth-side{
    padding:16px;
    border-radius:20px;
  }

  .qs-login-page .qs-auth-side h2,
  .qs-signup-page .qs-auth-side h2{
    font-size:24px;
  }

  .qs-login-page .qs-auth-side p,
  .qs-signup-page .qs-auth-side p{
    font-size:13px;
  }

  .qs-login-page .qs-auth-card,
  .qs-signup-page .qs-auth-card{
    padding:16px;
    border-radius:20px;
  }

  .qs-login-page .qs-auth-card h1,
  .qs-signup-page .qs-auth-card h1{
    font-size:26px;
  }

  .qs-signup-page .qs-signup-stage-card{
    padding:7px 6px;
  }

  .qs-signup-page .qs-signup-stage-card strong{
    font-size:11px;
  }
}


/* =================================================================
   AUTH-FLOW — MOBILE PANEL NACHBESSERUNG
   Milestone 5.1
   Scope: Login, Signup und weitere Auth-Seiten auf Mobile
   Ziel: blaues Panel kompakt halten, Formular/Inhalt priorisieren
================================================================= */
@media (max-width: 700px){
  body.qs-auth-body{
    overflow-x:hidden;
    background:
      radial-gradient(circle at top left, #f8fbff 0%, #eef5fb 44%, #edf3f8 100%);
  }

  body.qs-auth-body .qs-auth-shell,
  body.qs-auth-body .qs-auth-shell-signup,
  body.qs-auth-body .qs-auth-shell--recovery{
    width:100%;
    max-width:100%;
    min-height:auto;
    padding:10px 12px 26px;
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    align-items:start;
    justify-content:stretch;
  }

  body.qs-auth-body .qs-auth-main,
  body.qs-auth-body .qs-auth-side{
    width:100%;
    min-width:0;
  }

  /* Das blaue Desktop-Panel wird auf Mobile zum kurzen Kontext-Header. */
  body.qs-auth-body .qs-auth-side,
  body.qs-auth-body .qs-auth-side-balanced,
  body.qs-auth-body .qs-auth-side-signup,
  body.qs-auth-body .qs-login-side{
    order:0;
    min-height:0 !important;
    height:auto;
    align-self:stretch;
    justify-content:flex-start;
    gap:8px;
    padding:16px 16px 15px;
    border-radius:22px;
    box-shadow:0 14px 34px rgba(11,43,76,.12);
  }

  body.qs-auth-body .qs-auth-side::before{
    width:150px;
    height:150px;
    top:-76px;
    right:-48px;
    opacity:.62;
  }

  body.qs-auth-body .qs-auth-side::after{
    width:110px;
    height:110px;
    left:-42px;
    bottom:-58px;
    opacity:.38;
  }

  body.qs-auth-body .qs-auth-side-top,
  body.qs-auth-body .qs-signup-side-top-simple{
    display:block;
    min-width:0;
  }

  body.qs-auth-body .qs-auth-brand,
  body.qs-auth-body .qs-auth-brand-simple{
    margin:0 0 7px;
    gap:9px;
    min-width:0;
  }

  body.qs-auth-body .qs-auth-brand-mark{
    width:34px;
    height:34px;
    border-radius:12px;
    font-size:16px;
  }

  body.qs-auth-body .qs-auth-brand-copy strong,
  body.qs-auth-body .qs-auth-brand-simple .qs-auth-brand-copy strong{
    font-size:21px;
    line-height:1.05;
    letter-spacing:.01em;
  }

  body.qs-auth-body .qs-auth-brand-copy span,
  body.qs-auth-body .qs-auth-brand-simple .qs-auth-brand-copy span{
    margin-top:2px;
    font-size:11px;
    line-height:1.25;
    letter-spacing:.08em;
    opacity:.82;
    text-transform:uppercase;
  }

  body.qs-auth-body .qs-auth-eyebrow{
    min-height:25px;
    width:max-content;
    max-width:100%;
    padding:0 10px;
    font-size:11px;
    line-height:1;
    white-space:nowrap;
  }

  body.qs-auth-body .qs-auth-side h2,
  body.qs-auth-body .qs-signup-side-top-simple h2{
    margin:5px 0 5px;
    font-size:clamp(22px, 7vw, 28px);
    line-height:1.08;
    letter-spacing:-.025em;
    max-width:100%;
    overflow-wrap:anywhere;
  }

  body.qs-auth-body .qs-auth-side p,
  body.qs-auth-body .qs-signup-side-top-simple p{
    max-width:100%;
    font-size:13px;
    line-height:1.38;
    color:rgba(255,255,255,.84);
  }

  /* Doppelte/sekundäre Desktop-Erklärungen auf Mobile ausblenden. */
  body.qs-auth-body .qs-auth-side-bottom,
  body.qs-auth-body .qs-auth-side-bottom-links,
  body.qs-auth-body .qs-auth-side-list,
  body.qs-auth-body .qs-auth-facts,
  body.qs-auth-body .qs-auth-points,
  body.qs-auth-body .qs-auth-side-link-row,
  body.qs-auth-body .qs-signup-facts,
  body.qs-auth-body .qs-verify-facts{
    display:none !important;
  }

  /* Signup: blaues Panel als kompakter Fortschrittskopf, nicht als zweite Erklärkarte. */
  body.qs-auth-body.qs-signup-page .qs-auth-side{
    padding:16px;
  }

  body.qs-auth-body.qs-signup-page .qs-auth-side p{
    display:none;
  }

  body.qs-auth-body.qs-signup-page .qs-auth-side h2{
    margin:5px 0 10px;
    font-size:clamp(23px, 7.2vw, 29px);
  }

  body.qs-auth-body.qs-signup-page .qs-signup-stage-rail{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:7px;
    margin:10px 0 0;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-stage-card{
    min-width:0;
    min-height:40px;
    padding:7px 8px;
    border-radius:14px;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:7px;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-stage-index{
    flex:0 0 24px;
    width:24px;
    height:24px;
    font-size:12px;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-stage-card div{
    min-width:0;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-stage-card strong{
    display:block;
    font-size:12px;
    line-height:1.1;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-stage-card span:last-child{
    display:none !important;
  }

  /* Hauptinhalt: Karten kompakter und sofort als Fokus erkennbar. */
  body.qs-auth-body .qs-auth-card,
  body.qs-auth-body .qs-login-card,
  body.qs-auth-body .qs-auth-card-signup{
    width:100%;
    max-width:100%;
    padding:18px;
    border-radius:22px;
    box-shadow:0 14px 36px rgba(11,43,76,.08);
  }

  body.qs-auth-body .qs-auth-card-head,
  body.qs-auth-body .qs-login-head,
  body.qs-auth-body .qs-auth-card-head-simple,
  body.qs-auth-body .qs-auth-card-head-signup{
    display:block;
    margin-bottom:12px;
  }

  body.qs-auth-body .qs-auth-kicker{
    min-height:0;
    width:max-content;
    max-width:100%;
    padding:6px 11px;
    font-size:12px;
    line-height:1.1;
    border-radius:999px;
  }

  body.qs-auth-body .qs-auth-card h1{
    margin:6px 0 8px;
    font-size:clamp(25px, 8vw, 33px);
    line-height:1.08;
    letter-spacing:-.025em;
    overflow-wrap:anywhere;
  }

  body.qs-auth-body .qs-auth-card h2,
  body.qs-auth-body .qs-auth-card h3{
    font-size:clamp(18px, 5.8vw, 22px);
    line-height:1.15;
  }

  body.qs-auth-body .qs-auth-card p,
  body.qs-auth-body .qs-auth-help,
  body.qs-auth-body .qs-auth-note,
  body.qs-auth-body .qs-auth-list,
  body.qs-auth-body .qs-auth-checklist{
    font-size:14px;
    line-height:1.48;
  }

  body.qs-auth-body .qs-auth-alert{
    margin-top:12px;
    padding:12px 14px;
    border-radius:17px;
    font-size:14px;
    line-height:1.45;
    overflow-wrap:anywhere;
  }

  body.qs-auth-body .qs-auth-grid,
  body.qs-auth-body .qs-auth-grid.cols-2,
  body.qs-auth-body .qs-auth-grid--recovery-steps,
  body.qs-auth-body .qs-signup-data-form,
  body.qs-auth-body .qs-verify-form{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    margin-top:14px;
  }

  body.qs-auth-body .qs-auth-field,
  body.qs-auth-body .qs-auth-fieldset{
    gap:7px;
  }

  body.qs-auth-body .qs-auth-field label,
  body.qs-auth-body .qs-auth-label,
  body.qs-auth-body .qs-login-label-row{
    font-size:13px;
    line-height:1.25;
  }

  body.qs-auth-body input[type="text"],
  body.qs-auth-body input[type="email"],
  body.qs-auth-body input[type="password"],
  body.qs-auth-body input[type="tel"],
  body.qs-auth-body input[type="number"],
  body.qs-auth-body select,
  body.qs-auth-body .qs-auth-input{
    width:100%;
    min-height:48px;
    padding:0 14px;
    border-radius:14px;
    font-size:16px;
  }

  body.qs-auth-body textarea{
    width:100%;
    min-height:94px;
    padding:12px 14px;
    border-radius:14px;
    font-size:16px;
  }

  body.qs-auth-body .qs-auth-actions{
    margin-top:14px;
    gap:10px;
  }

  body.qs-auth-body .qs-auth-actions,
  body.qs-auth-body .qs-auth-links,
  body.qs-auth-body .qs-login-links{
    flex-wrap:wrap;
  }

  body.qs-auth-body .qs-auth-btn,
  body.qs-auth-body button,
  body.qs-auth-body .qs-auth-link-button{
    min-height:48px;
    border-radius:15px;
    font-size:15px;
  }

  body.qs-auth-body .qs-auth-actions .qs-auth-btn,
  body.qs-auth-body .qs-auth-actions button{
    flex:1 1 150px;
  }

  body.qs-auth-body .qs-auth-btn.is-ghost{
    background:#fff;
  }

  body.qs-auth-body .qs-auth-footer{
    margin-top:16px;
    padding-top:14px;
    gap:10px;
    font-size:13px;
  }

  /* Role/Setup-Karten im Signup bleiben lesbar, aber weniger massiv. */
  body.qs-auth-body.qs-signup-page .qs-auth-role-grid,
  body.qs-auth-body.qs-signup-page .qs-signup-role-grid{
    grid-template-columns:1fr;
    gap:10px;
  }

  body.qs-auth-body.qs-signup-page .qs-auth-role-card,
  body.qs-auth-body.qs-signup-page .qs-signup-role-card{
    padding:14px;
    border-radius:18px;
    gap:10px;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-role-top{
    gap:12px;
    align-items:center;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-role-icon{
    width:36px;
    height:36px;
    border-radius:12px;
    font-size:18px;
  }

  body.qs-auth-body.qs-signup-page .qs-auth-role-card h3{
    margin:0 0 4px;
    font-size:18px;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-role-copy,
  body.qs-auth-body.qs-signup-page .qs-auth-role-card p{
    font-size:13px;
    line-height:1.42;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-progress{
    gap:8px;
    margin:14px 0 0;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-progress span{
    height:7px;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-step-note,
  body.qs-auth-body.qs-signup-page .qs-signup-data-form .qs-signup-data-field-primary{
    padding:12px 14px;
    border-radius:17px;
  }

  /* Verify / 2FA: Eingaben dürfen nicht ausbrechen. */
  body.qs-auth-body .qs-auth-otp{
    display:grid;
    grid-template-columns:repeat(6, minmax(0, 1fr));
    gap:7px;
  }

  body.qs-auth-body .qs-auth-otp-digit{
    width:100%;
    min-width:0;
    height:46px;
    font-size:20px;
    border-radius:13px;
  }

  body.qs-auth-body .qs-auth-segmented,
  body.qs-auth-body .qs-auth-inline,
  body.qs-auth-body .qs-auth-inline--choice{
    flex-wrap:wrap;
  }

  body.qs-auth-body .qs-auth-mode-panel,
  body.qs-auth-body .qs-auth-choice-copy{
    min-width:0;
  }
}

@media (max-width: 380px){
  body.qs-auth-body .qs-auth-shell,
  body.qs-auth-body .qs-auth-shell-signup,
  body.qs-auth-body .qs-auth-shell--recovery{
    padding:8px 10px 22px;
    gap:10px;
  }

  body.qs-auth-body .qs-auth-side{
    padding:14px;
    border-radius:20px;
  }

  body.qs-auth-body .qs-auth-side h2{
    font-size:23px;
  }

  body.qs-auth-body .qs-auth-side p{
    font-size:12.5px;
  }

  body.qs-auth-body .qs-auth-card{
    padding:16px;
    border-radius:20px;
  }

  body.qs-auth-body .qs-auth-card h1{
    font-size:26px;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-stage-rail{
    gap:6px;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-stage-card{
    justify-content:center;
    padding:7px 5px;
  }

  body.qs-auth-body.qs-signup-page .qs-signup-stage-card strong{
    display:none;
  }
}
