/* ===== базовые переменные уже есть в твоём :root =====
:root { ... из main ... }
*/

/* ===== Утилиты ===== */
[hidden]{display:none!important;}
.u-center{display:flex;justify-content:center;align-items:center;}
.mt-2{margin-top:12px;}
.w-100{width:100%;}
.inline{display:flex;align-items:center;gap:8px;}
.inline--gap-sm{gap:8px;}

/* ===== Макет ===== */
.auth-wrap{display:grid;place-items:center;padding:24px 16px;background:var(--bg);}
.auth-card{width:100%;max-width:440px;}
.card{
  background:var(--w);
  border:1px solid var(--bd);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px 20px;
}

/* ===== Шапка ===== */
.auth-head{display:grid;gap:6px;margin-bottom:12px;text-align:center;}
.auth-title{
  margin:0;
  font:700 22px/1.2 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--t);
}
.auth-sub{margin:0;color:var(--m);font-size:14px}

/* ===== Формы ===== */
.form{display:grid;gap:14px;}
.field{display:grid;gap:6px;}
.label{font-weight:600;color:var(--t);font-size:14px;}
.input{
  width:100%;
  padding:12px 12px;
  border-radius:var(--rs);
  border:1px solid var(--bd);
  background:var(--ws);
  color:var(--t);
  outline:0;
  transition:border-color .15s,box-shadow .15s,background .15s;
}
.input:focus{
  border-color:#c7cdd8;
  background:var(--w);
  box-shadow:0 0 0 3px rgba(17,17,17,.06);
}
.error{margin:0;color:var(--danger);font-size:13px;}
.hint{margin:6px 0 0;font-size:13px;color:var(--m)}

/* ===== Чекбокс согласия ===== */
.checkbox{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:var(--t);
  font-size:14px;
  line-height:1.4;
}
.checkbox input{margin-top:3px;flex:0 0 auto}
.checkbox__text{display:inline;white-space:normal}
.checkbox__text .link{display:inline;white-space:nowrap}

/* ===== Кнопки ===== */
.btn{
  appearance:none;
  border:1px solid transparent;
  border-radius:var(--rs);
  padding:10px 14px;
  cursor:pointer;
  background:#eef2f7;
  color:var(--t);
  font-weight:600;
  transition:filter .15s,transform .02s,background .15s,border-color .15s;
}
.btn:hover{filter:brightness(0.98)}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:2px solid rgba(17,24,39,.25);outline-offset:2px}
.btn:disabled{opacity:.6;cursor:not-allowed}

.btn-primary{background:var(--a);color:var(--ac);}
.btn-sm{padding:8px 12px}
.btn--pill{border-radius:9999px}

/* Призрачные кнопки */
.btn-ghost{
  background:transparent;
  border-color:var(--bd);
  color:var(--t);
}
.btn-ghost:hover{background:#f3f4f6}
.btn-ghost:active{background:#eef2f7}

/* ===== Код ===== */
.code-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:center;
}
.code-input{text-align:center;letter-spacing:.2em;font-weight:700;}
@media (max-width:520px){
  .code-row{grid-template-columns:1fr;}
}

/* Блок действий под кодом */
.code-actions{
  display:flex;
  gap:10px;
  justify-content:space-between;
  flex-wrap:wrap;
}
@media (max-width:520px){
  .code-actions{flex-direction:column;align-items:stretch}
}

/* ===== Divider ===== */
.divider{
  display:flex;align-items:center;gap:10px;
  margin:10px 0 6px;color:var(--m);font-size:12px;justify-content:center
}
.divider::before,.divider::after{
  content:"";height:1px;background:var(--bd);
  flex:1 1 24px;max-width:120px
}

/* ===== Legal ===== */
.legal{margin:10px 0 0;font-size:12px;color:var(--m);text-align:center}

/* ===== Ссылки ===== */
.link{color:var(--link);text-decoration:none}
.link:hover{text-decoration:underline}
