/* Reset básico + base */
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font: 400 var(--font-body)/1.45 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color: var(--text);
  background: var(--surface-1, #fafafa);
  letter-spacing: -0.01em;
}

/* Utilidade de ritmo vertical (stack) */
.stack > * + * { margin-top: var(--stack-space, var(--space-4)); }

/* Página */
.auth-page {
  min-height: 100dvh;
  display: grid;
  place-items: center;
  padding: var(--space-7) var(--space-3);
}

/* Card */
.card {
  width: 100%;
  max-width: var(--card-max-w, var(--container-w-sm));
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-1);
  padding: var(--space-6);
}

.card:has(.grid-2) {
  max-width: var(--card-max-w, var(--container-w-md));
}

.card__header, .title{
  margin: 0;
  font-size: var(--font-title);
  letter-spacing: -0.02em;
  text-align: center;
}
.subtitle {
  margin: 0;
  color: var(--text-muted);
  font-size: var(--font-subtitle);
}

/* Mensagens (Django messages) */
.messages { list-style: none; padding: 0; margin: 0; }
.messages.stack > * + * { margin-top: var(--space-2); }

.message {
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--border);
  border-left-width: 4px;
  border-radius: var(--radius-md);
  background: var(--surface-2);
  color: var(--text);
}
.message.success { background: var(--success-bg); color: var(--success-text); border-color: var(--success-text); }
.message.warning { background: var(--warning-bg); color: var(--warning-text); border-color: var(--warning-text); }
.message.error   { background: var(--error-bg);   color: var(--error-text);   border-color: var(--error-text); }
.message.info    { background: var(--info-bg);    color: var(--info-text);    border-color: var(--info-text); }

/* Formulário */
.form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-4) var(--space-4);
  margin: 0;
}

/* Cada <p> do {{ form.as_p }} vira um item do grid */
.form > p { margin: 0; }

/* Campos que devem ocupar a linha toda */
.form .span-2 { grid-column: 1 / -1; }

/* Botão de submit ocupando a largura toda (ou troque por justify-self: end) */
.form > .btn { grid-column: 1 / -1; }

.form p { margin: 0; } /* Necessário por causa do {{ form.as_p }} */
.form label {
  display: block;
  font-weight: 600;
  font-size: 0.95rem;
  margin-bottom: var(--space-2);
}
.form input[type="text"],
.form input[type="email"],
.form input[type="password"],
.form input[type="number"],
.form select,
.form textarea {
  width: 100%;
  min-height: var(--control-h);
  padding: 0 var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--text);
  font-size: 1rem;
  outline: none;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
.form input:focus,
.form select:focus,
.form textarea:focus {
  border-color: var(--primary-600);
  box-shadow: 0 0 0 4px var(--ring);
}

/* Linhas específicas com 2 colunas */
.form .grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: var(--space-4);
}

/* Empilha no mobile */
@media (max-width: 640px) {
  .form .grid-2 { grid-template-columns: 1fr; }
}

/* Opcional: estilinho para help text */
.form .help {
  display: block;
  margin-top: var(--space-1);
  color: var(--text-muted);
  font-size: 0.9rem;
}
/* Cada linha de pares ocupa toda a largura do grid do formulário */
.form > .grid-2 {
  grid-column: 1 / -1;
}

/* Botões */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  cursor: pointer;
  text-decoration: none;
  user-select: none;
  height: var(--control-h);
  padding: 0 var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  font-weight: 600;
  font-size: 0.98rem;
}
.btn:focus { outline: none; box-shadow: 0 0 0 4px var(--ring); }

.btn-primary { background: var(--primary-500); color: #fff; border-color: var(--primary-500); }
.btn-primary:hover { background: var(--primary-600); border-color: var(--primary-600); }
.btn-primary:active { background: var(--primary-700); border-color: var(--primary-700); }

.btn-outline { background: #fff; color: var(--primary-700); border-color: var(--primary-200); }
.btn-outline:hover { background: var(--primary-50); border-color: var(--primary-300); }

.btn-ghost { background: transparent; color: var(--primary-700); border-color: var(--border); }
.btn-ghost:hover { background: var(--primary-50); border-color: var(--primary-200); }

/* Ações (CTA duplo) */
.actions {
  display: grid;
  grid-auto-flow: column;
  gap: var(--space-3);
}

/* Divisor e rodapé */
.divider {
  height: 1px;
  background: var(--border);
  border-radius: 1px;
  margin: 0; /* usamos .stack para o espaçamento vertical */
}
.footer { color: var(--text-muted); font-size: 0.9rem; }

/* Responsividade */
@media (max-width: 480px) {
  .card { padding: var(--space-5); border-radius: var(--radius-md); }
  .actions { grid-auto-flow: row; }
}
