:root {
  --verde: #107a56;
  --verde-escuro: #084632;
  --verde-claro: #e7f4ee;
  --tinta: #16241d;
  --cinza: #6b7a73;
  --linha: #e2e8e4;
  --branco: #ffffff;
  --fundo: #f4f7f5;
  --erro: #c0392b;
  --sombra: 0 6px 24px rgba(8, 70, 50, 0.10);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
[hidden] { display: none !important; }

body {
  font-family: "Inter", system-ui, sans-serif;
  color: var(--tinta);
  background: var(--fundo);
  min-height: 100svh;
  -webkit-font-smoothing: antialiased;
}

h1, h2, .marca__nome, .topo__marca strong { font-family: "Oswald", sans-serif; }

/* ===== LOGIN ===== */
.login {
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 18px;
  padding: 24px;
  background: linear-gradient(160deg, var(--verde) 0%, var(--verde-escuro) 100%);
}
.login__card {
  width: 100%;
  max-width: 380px;
  background: var(--branco);
  border-radius: 20px;
  padding: 30px 24px 26px;
  box-shadow: var(--sombra);
}
.marca { display: flex; align-items: center; gap: 14px; margin-bottom: 6px; }
.marca__logo { width: 56px; height: 56px; border-radius: 14px; }
.marca__nome {
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 0.98;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  color: var(--verde-escuro);
}
.login__sub { color: var(--cinza); margin: 4px 0 20px; font-size: 0.95rem; }

.campo { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.campo > span { font-size: 0.82rem; font-weight: 600; color: var(--cinza); }
.campo input, .campo select {
  font-family: inherit;
  font-size: 1rem;
  padding: 12px 14px;
  border: 1.5px solid var(--linha);
  border-radius: 12px;
  background: #fbfdfc;
  color: var(--tinta);
  transition: border-color 0.15s;
}
.campo input:focus, .campo select:focus {
  outline: none;
  border-color: var(--verde);
}

.btn {
  font-family: inherit;
  font-size: 1rem;
  font-weight: 600;
  padding: 13px 20px;
  border-radius: 12px;
  border: none;
  cursor: pointer;
  transition: transform 0.08s, opacity 0.15s, background 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.btn:active { transform: scale(0.98); }
.btn--primario { background: var(--verde); color: #fff; width: 100%; }
.btn--primario:hover { background: #0c6347; }
.btn--primario:disabled { opacity: 0.6; cursor: progress; }
.btn--fantasma { background: transparent; color: var(--cinza); border: 1.5px solid var(--linha); }

.erro {
  color: var(--erro);
  background: #fdecea;
  border: 1px solid #f5cdc7;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 0.88rem;
  margin-bottom: 12px;
}
.rodape-login { color: rgba(255,255,255,0.85); font-size: 0.82rem; }

/* ===== APP ===== */
.topo {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: max(14px, env(safe-area-inset-top)) 18px 14px;
  background: linear-gradient(160deg, var(--verde), var(--verde-escuro));
  color: #fff;
}
.topo__marca { display: flex; align-items: center; gap: 10px; font-size: 1.1rem; text-transform: uppercase; letter-spacing: 0.02em; }
.topo__logo { width: 34px; height: 34px; border-radius: 9px; }
.btn-sair {
  background: rgba(255,255,255,0.16);
  color: #fff;
  border: none;
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
}

.conteudo { max-width: 620px; margin: 0 auto; padding: 18px 16px 90px; }

/* Form */
.form {
  background: var(--branco);
  border: 1px solid var(--linha);
  border-radius: 16px;
  padding: 18px;
  box-shadow: var(--sombra);
  margin-bottom: 24px;
}
.form__titulo { font-size: 1.15rem; font-weight: 600; margin-bottom: 14px; color: var(--verde-escuro); }
.form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.campo--curto { max-width: 120px; }
.form .campo { margin-bottom: 0; }
.form__acoes { display: flex; gap: 10px; margin-top: 16px; }
.form__acoes .btn { width: auto; flex: 1; }

/* Lista */
.lista__cabecalho { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 12px; }
.lista__cabecalho h2 { font-size: 1.3rem; color: var(--verde-escuro); }
.contador { color: var(--cinza); font-size: 0.9rem; font-weight: 500; }

.lista { list-style: none; display: grid; gap: 10px; }
.cartao {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--branco);
  border: 1px solid var(--linha);
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: 0 2px 8px rgba(8,70,50,0.05);
  animation: aparecer 0.25s ease;
}
@keyframes aparecer { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.cartao__camisa {
  flex-shrink: 0;
  width: 46px; height: 46px;
  display: grid; place-items: center;
  background: var(--verde-claro);
  color: var(--verde-escuro);
  border-radius: 12px;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 1.25rem;
}
.cartao__info { flex: 1; min-width: 0; }
.cartao__nome { font-weight: 600; font-size: 1.05rem; }
.cartao__meta { display: flex; align-items: center; gap: 8px; margin-top: 3px; flex-wrap: wrap; }
.cartao__time { color: var(--cinza); font-size: 0.9rem; }
.badge {
  font-size: 0.72rem;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.cartao__acoes { display: flex; gap: 6px; flex-shrink: 0; }
.icone-btn {
  width: 38px; height: 38px;
  border: 1px solid var(--linha);
  background: #fff;
  border-radius: 10px;
  cursor: pointer;
  font-size: 1.05rem;
  display: grid; place-items: center;
  transition: background 0.15s;
}
.icone-btn:hover { background: var(--verde-claro); }
.icone-btn--apagar:hover { background: #fdecea; }

/* Cores das posições */
.pos-Goleiro  { background: #fbeed0; color: #855011; }
.pos-Zagueiro { background: #e0edfb; color: #185fa5; }
.pos-Lateral  { background: #d9f2ea; color: #0f6e56; }
.pos-Volante  { background: #ecebfb; color: #443a9c; }
.pos-Meia     { background: #e6f3de; color: #3b6d11; }
.pos-Atacante { background: #fde7df; color: #99421d; }
.pos-Técnico  { background: #ececec; color: #444; }
.pos-vazia    { background: #eef1ef; color: #6b7a73; }

.vazio { text-align: center; color: var(--cinza); padding: 30px 16px; background: var(--branco); border: 1px dashed var(--linha); border-radius: 14px; }

/* Toggle de visão (Campo / Lista) */
.visao-toggle { display: inline-flex; background: #e7eee9; border-radius: 999px; padding: 3px; gap: 2px; }
.toggle-btn {
  border: none; background: transparent; cursor: pointer;
  font-family: inherit; font-size: 0.85rem; font-weight: 600; color: var(--cinza);
  padding: 7px 14px; border-radius: 999px; transition: background 0.15s, color 0.15s;
}
.toggle-btn.ativo { background: var(--branco); color: var(--verde-escuro); box-shadow: 0 1px 4px rgba(8,70,50,0.12); }

/* Campo de futebol */
#campo.campo {
  position: relative;
  aspect-ratio: 68 / 100;
  width: 100%;
  border-radius: 14px;
  border: 2px solid rgba(255,255,255,0.6);
  background:
    repeating-linear-gradient(0deg, #1f9e63 0 9.5%, #1c9259 9.5% 19%);
  box-shadow: var(--sombra);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 14px 6px;
  gap: 4px;
}
/* linha central + círculo */
#campo.campo::before {
  content: ""; position: absolute; left: 0; right: 0; top: 50%;
  border-top: 2px solid rgba(255,255,255,0.55);
}
#campo.campo::after {
  content: ""; position: absolute; left: 50%; top: 50%;
  width: 34%; aspect-ratio: 1; transform: translate(-50%, -50%);
  border: 2px solid rgba(255,255,255,0.55); border-radius: 50%;
}
/* áreas (gol em cima e embaixo) */
.area { position: absolute; left: 50%; transform: translateX(-50%); width: 52%; height: 12%; border: 2px solid rgba(255,255,255,0.5); }
.area--cima { top: -2px; border-top: none; border-radius: 0 0 6px 6px; }
.area--baixo { bottom: -2px; border-bottom: none; border-radius: 6px 6px 0 0; }

.campo__linha { position: relative; z-index: 2; display: flex; justify-content: space-evenly; align-items: center; flex-wrap: wrap; gap: 6px; min-height: 56px; }

/* peça (jogador no campo) */
.peca { display: flex; flex-direction: column; align-items: center; width: 60px; }
.peca__camisa {
  width: 40px; height: 40px; border-radius: 50%;
  background: #fff; color: var(--verde-escuro);
  display: grid; place-items: center;
  font-family: "Oswald", sans-serif; font-weight: 700; font-size: 1.05rem;
  border: 2px solid var(--verde-escuro);
  box-shadow: 0 2px 6px rgba(0,0,0,0.25);
}
.peca__nome {
  margin-top: 3px; max-width: 64px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-size: 0.7rem; font-weight: 600; color: #fff;
  background: rgba(0,0,0,0.32); padding: 1px 6px; border-radius: 6px;
}
.peca--tecnico .peca__camisa { background: #ffd24a; border-color: #8a6a00; color: #5a4500; }

.campo__tecnico { position: absolute; bottom: 8px; left: 8px; z-index: 3; }

.campo__vazio-msg { position: absolute; inset: 0; display: grid; place-items: center; color: rgba(255,255,255,0.9); font-weight: 600; text-align: center; padding: 20px; z-index: 3; }

/* Banco (sem posição) */
.banco { margin-top: 12px; background: var(--branco); border: 1px solid var(--linha); border-radius: 12px; padding: 12px 14px; }
.banco__titulo { font-size: 0.82rem; font-weight: 600; color: var(--cinza); }
.banco__lista { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.banco .peca__nome { color: var(--tinta); background: var(--verde-claro); }
.banco .peca__camisa { width: 34px; height: 34px; font-size: 0.9rem; }

/* Toast */
.toast {
  position: fixed;
  left: 50%; bottom: 24px;
  transform: translateX(-50%);
  background: var(--verde-escuro);
  color: #fff;
  padding: 12px 20px;
  border-radius: 999px;
  font-size: 0.92rem;
  font-weight: 500;
  box-shadow: var(--sombra);
  z-index: 30;
  animation: subir 0.25s ease;
}
@keyframes subir { from { opacity: 0; transform: translate(-50%, 10px); } to { opacity: 1; transform: translate(-50%, 0); } }

.instalar {
  position: fixed;
  z-index: 20;
  right: 16px;
  bottom: max(16px, env(safe-area-inset-bottom));
  background: var(--verde);
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 11px 18px;
  font-weight: 600;
  font-size: 0.9rem;
  box-shadow: var(--sombra);
  cursor: pointer;
}

:focus-visible { outline: 2px solid var(--verde); outline-offset: 2px; }

@media (max-width: 380px) {
  .form__grid { grid-template-columns: 1fr; }
  .campo--curto { max-width: none; }
}
