:root {
  /* Paleta do manual */
  --cream: #f6e8c5;   /* fundo claro oficial */
  --rose:  #cb8e7b;   /* tom rosado */
  --red:   #901b12;   /* vermelho fechado */
  --brown: #401a0d;   /* marrom escuro principal */

  /* Tokens da UI */
  --bg: var(--cream);
  --ink: #2b2b2b;
  --muted: #6b7280;
  --card: #ffffff;
  --line: #e5e7eb;
}
* { box-sizing: border-box }
html, body { height: 100% }
body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Inter, Arial, sans-serif;
  background: var(--bg);
  color: var(--ink);
}

/* Header segue a diretriz: logo em fundo escuro → primeira variação */
.site-header {
  background: var(--brown);
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.08);
  display: flex;
  align-items: center;
}
.wrap { width: min(960px, 92%); margin-inline: auto; justify-content: center;  }
.hero { padding: 1rem 0; display: flex; align-items: center; gap: .8rem }


/* Logo – respeitando margem de segurança e redução mínima (100px) */
.brand-logo {
  height: 48px;           /* usa altura fixa para consistência */
  width: auto;
  min-width: 100px;       /* limite de redução do manual */
  display: block;
  object-fit: contain;
}

.brand-logo-login {
  height: 120px;           /* usa altura fixa para consistência */
  width: auto;
  min-width: 100px;       /* limite de redução do manual */
  object-fit: contain;
  align-items: center;
}

h1 { font-size: clamp(1.2rem, 2.6vw, 1.6rem); margin: 0; text-align: center; }
.sub { margin: 0; color: #ffeecf; font-size: .95rem }

/* Card de login */
.gate { display: grid; place-items: center; min-height: calc(100dvh - 72px) }
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 10px 24px rgba(2,6,23,.08);
  padding: 1.25rem;
  width: min(520px, 92%);
}

.brand-mini { display: flex; flex-direction: column; align-items: center; gap: .7rem; margin-bottom: .25rem }
.brand-mini h2 { margin: .25rem 0 0; font-size: 2rem; text-align: center; margin-bottom: 1rem;}
.hint { color: var(--muted); font-size: .9rem; margin-top: .15rem }

.grid { display: grid; gap: 1rem }
.field { display: flex; flex-direction: column; gap: .35rem }
label { font-weight: 600; font-size: .95rem }
input {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: .75rem .9rem;
  font-size: 1rem;
  background: #fff;
}
input:focus { outline: 3px solid rgba(203,142,123,.35); border-color: var(--rose) }

.actions { display: flex; gap: .75rem; align-items: center; justify-content: center; margin-top: 1rem }
.btn {
  appearance: none;
  border: 1px solid var(--line);
  background: var(--brown);
  color: #fff;
  border-radius: 40px;
  padding: 1rem 13.5rem;
  font-weight: 700;
  cursor: pointer;
}
.btn.secondary { background: #fff; color: var(--brown) }

.msg { display: none; margin-top: -.5rem; font-size: .9rem; color: var(--red) }
.msg.show { display: block }



