:root{
  --bg:#0b0f17;
  --panel:#121826;
  --muted:#8ea0b8;
  --text:#e6eef8;
  --primary:#5aa2ff;
  --primary-press:#3e84e6;
  --danger:#ff6b6b;
  --ring: rgba(90,162,255,.35);
  --radius: 18px;
}

*{box-sizing:border-box}
html,body{height:100%}

/* ===== Layout geral (duas colunas iguais) ===== */
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Helvetica Neue", sans-serif;
  background:
    radial-gradient(1200px 800px at 70% -10%, #14213d 0%, transparent 60%),
    var(--bg);
  color:var(--text);
}

.wrap{
  height:100%;
  max-width:1200px;
  margin:0 auto;
  padding:32px 20px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  align-items:center;
  justify-items:center;
  gap:36px;
}

/* ===== Painéis com mesmo tamanho ===== */
.panel{
  width:100%;
  max-width:520px;          /* MESMA largura para ambos */
  min-height:520px;         /* MESMA altura para ambos */
  border-radius:var(--radius);
  box-shadow:0 24px 50px rgba(0,0,0,.60);
  overflow:hidden;          /* garante bordas limpas */
}

/* ===== Painel da imagem ===== */
.image-panel{
  background: #0d1424;
  border:1px solid rgba(255,255,255,.08);
  position:relative;
}
.image-panel .image-fill{
  position:absolute; inset:0;          /* margem interna para “moldura” */
  background-image:url("/static/avatar.jpg");
  background-repeat:no-repeat;
  background-position:center;
  background-size:cover;                   /* preenche sem distorcer */
  border-radius:12px;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.05);
}

/* ===== Painel do card (login) ===== */
.card{
  background: linear-gradient(180deg, rgba(18,24,38,.86), rgba(18,24,38,.76));
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
  padding:32px;
  display:flex;
  flex-direction:column;
  justify-content:space-between; /* mantém rodapé embaixo mesmo com pouco conteúdo */
}

.brand{ text-align:center; margin-bottom:18px; }
.brand-title{ font-size:28px; margin:8px 0 4px; letter-spacing:.6px; }
.brand-sub{ margin:0; color:var(--muted); font-size:15px; }

.form{display:grid; gap:14px; margin-top:8px;}
.field{display:grid; gap:8px;}
.field label{font-size:13px; color:#c9d7ef}
.field input{
  width:100%;
  background:#0c1322;
  border:1px solid rgba(255,255,255,.08);
  color:var(--text);
  border-radius:12px;
  padding:14px 14px;
  outline:none;
}
.field input:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 6px var(--ring);
}

.password-wrap{position:relative}
.password-wrap input{padding-right:44px}
.toggle{
  position:absolute; right:8px; top:50%; transform:translateY(-50%);
  background:transparent; border:0; color:#cbd7ee; font-size:16px; cursor:pointer;
  width:32px; height:32px; border-radius:8px;
}
.toggle:hover{background:rgba(255,255,255,.06)}
.error{color:var(--danger); font-size:12px; min-height:16px}

.row{ display:flex; align-items:center; justify-content:space-between; margin-top:4px; }
.remember{ display:flex; align-items:center; gap:8px; font-size:13px; color:#c9d7ef }
.link{ font-size:13px; color:#9fb0c9; text-decoration:none; opacity:.9 }
.link[aria-disabled="true"]{ opacity:.4; cursor:not-allowed }

.btn{
  margin-top:4px;
  width:100%;
  padding:14px 18px;
  border-radius:12px;
  border:0;
  background:linear-gradient(180deg, var(--primary), var(--primary-press));
  color:white; font-weight:600; letter-spacing:.3px; cursor:pointer;
  transition: transform .04s ease;
}
.btn:active{ transform: translateY(1px) scale(0.998) }

.footer{
  margin-top:18px; text-align:center; color:#9fb0c9; font-size:12px;
  border-top:1px solid rgba(255,255,255,.06); padding-top:12px;
}

/* ===== Responsivo: empilha no mobile e mantém proporção ===== */
@media (max-width: 980px){
  .wrap{ grid-template-columns: 1fr; gap:28px; }
  .panel{ max-width:560px; min-height:480px; }
  .image-panel .image-fill{ inset:10px; border-radius:12px; }
}

@media (max-width: 420px){
  .panel{ max-width:100%; min-height:440px; }
  .card{ padding:22px; }
}
