:root {
  --primaria: #d35b1e;        /* laranja do logo da ORSSE */
  --primaria-escura: #b04712;
  --primaria-suave: #fdeadd;
  --tinta: #ffffff;           /* texto sobre o laranja */
  --dourado: #fbb419;         /* cor de apoio (destaques) */
  --dourado-suave: #fff3d6;
  --fundo: #fdf9f0;           /* creme, mesmo tom do fundo do logo */
  --cartao: #ffffff;
  --texto: #2a2318;
  --mudo: #857a63;
  --borda: #ede4cf;
  --realce: #b04712;          /* laranja escuro para links (legível no branco) */
  --ok: #1d7a3e;
  --ok-fundo: #e8f5ec;
  --erro: #b3261e;
  --erro-fundo: #fdeceb;
  --info-fundo: #fff8e6;
  --info: #8a5b00;
}

* { box-sizing: border-box; }

html { color-scheme: light; }

/* garante que o atributo hidden sempre esconda, mesmo com classes que definem display */
[hidden] { display: none !important; }

body {
  margin: 0;
  font-family: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  background: var(--fundo);
  color: var(--texto);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* ---------- Topo ---------- */
.topo { background: var(--primaria); color: var(--tinta); box-shadow: 0 1px 4px rgba(80, 35, 0, .2); }
.topo-inner {
  max-width: 900px; margin: 0 auto; padding: .6rem 1rem;
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: .5rem;
}
.marca { color: var(--tinta); text-decoration: none; font-size: 1.05rem; display: inline-flex; align-items: center; gap: .5rem; }
.marca strong { letter-spacing: .05em; margin-left: .25rem; }
.logo-topo {
  width: 34px; height: 34px; border-radius: 50%; object-fit: cover;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, .55);
}
.logo-login {
  display: block; width: 70%; max-width: 260px; margin: 2.2rem auto 0;
  border-radius: 12px;
}
.logo-login + .cartao-login { margin-top: 1.2rem; }
.menu { display: flex; flex-wrap: wrap; align-items: center; gap: .9rem; }
.menu a { color: #ffe0cb; text-decoration: none; font-size: .92rem; font-weight: 600; }
.menu a:hover { color: #fff; }
.botao-link {
  background: none; border: none; color: #ffe0cb; cursor: pointer;
  font-size: .92rem; font-weight: 600; padding: 0; font-family: inherit;
}
.botao-link:hover { color: #fff; }

/* ---------- Layout ---------- */
.conteudo { max-width: 900px; margin: 0 auto; padding: 1rem; }
.rodape { text-align: center; color: var(--mudo); font-size: .8rem; padding: 1.5rem 1rem 2rem; }

h1 { font-size: 1.45rem; margin: .8rem 0 .4rem; }
h2 { font-size: 1.1rem; margin: .2rem 0 .5rem; }
h3 { font-size: .98rem; margin: 1rem 0 .4rem; }
a { color: var(--realce); }
.mudo { color: var(--mudo); }
.pequeno { font-size: .85rem; }
.ok { color: var(--ok); }
.alerta { color: var(--erro); }
.inline { display: inline; }
.apagado { opacity: .55; }

/* ---------- Cartões ---------- */
.cartao {
  background: var(--cartao); border: 1px solid var(--borda); border-radius: 12px;
  padding: 1rem 1.1rem; margin: .8rem 0;
}
.cartao-link { display: block; text-decoration: none; color: inherit; }
.cartao-link:hover { border-color: var(--primaria); box-shadow: 0 2px 8px rgba(251, 180, 25, .25); }
.cartao-login { max-width: 420px; margin: 2.5rem auto; }
.destaque { border: 2px solid var(--primaria); }
.concerto-futuro { background: #f2faf3; }   /* verde bem claro: ainda vai acontecer */
.concerto-passado { background: #fdf3f2; }  /* vermelho bem claro: já realizado */
.etiqueta {
  background: var(--dourado); color: #3b2a00; font-size: .7rem; border-radius: 6px;
  padding: .1rem .45rem; vertical-align: middle; letter-spacing: .05em; font-weight: 700;
}
.linha-entre { display: flex; justify-content: space-between; align-items: center; gap: .8rem; }
.selo { text-align: center; min-width: 4.2rem; }
.selo-num { display: block; font-size: 1.3rem; font-weight: 700; color: var(--realce); }
.selo-rotulo { display: block; font-size: .7rem; color: var(--mudo); }

/* ---------- Painel de resumo (admin) ---------- */
.painel-resumo {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: .6rem; margin: .8rem 0;
}
.resumo-item {
  background: var(--primaria-suave); border: 1px solid var(--borda); border-radius: 12px;
  text-align: center; padding: .7rem .4rem;
}
.resumo-num { display: block; font-size: 1.6rem; font-weight: 800; color: var(--realce); }
.resumo-rotulo { display: block; font-size: .75rem; color: var(--mudo); }
.resumo-atencao { background: var(--erro-fundo); }
.resumo-atencao .resumo-num { color: var(--erro); }

.pilula {
  display: inline-block; border-radius: 999px; padding: .1rem .6rem;
  font-size: .8rem; font-weight: 700; margin-right: .3rem;
}
.pilula-ok { background: var(--ok-fundo); color: var(--ok); }
.pilula-atencao { background: var(--primaria-suave); color: var(--realce); }
.linha-pendente td { background: #fffaf0; }
.tabela-musicos .pequeno { display: inline-block; margin-right: .5rem; }

/* ---------- Formulários ---------- */
label { display: block; font-size: .88rem; font-weight: 600; margin: .7rem 0 .25rem; }
input[type="text"], input[type="password"], input[type="search"],
input[type="datetime-local"], select {
  width: 100%; padding: .65rem .7rem; font-size: 1rem;
  border: 1px solid var(--borda); border-radius: 8px; background: #fff; color: var(--texto);
}
input:focus, select:focus { outline: 2px solid var(--primaria); outline-offset: 1px; }
.caixa-check { font-weight: 400; font-size: .85rem; color: var(--mudo); }
.caixa-check input { width: auto; margin-right: .35rem; }

.botao {
  display: inline-block; background: var(--primaria); color: var(--tinta); border: none;
  border-radius: 8px; padding: .6rem 1rem; font-size: .95rem; font-weight: 700; cursor: pointer;
  text-decoration: none; font-family: inherit; margin-top: .6rem;
}
.botao:hover { background: var(--primaria-escura); }
.botao-cheio { width: 100%; }
.botao-mini { padding: .3rem .6rem; font-size: .8rem; margin-top: 0; }
.botao-perigo { background: var(--erro); color: #fff; }
.botao-perigo:hover { background: #8f1e18; }
.botao-ok { background: var(--ok); color: #fff; font-size: .95rem; padding: .5rem .9rem; margin-top: 0; white-space: nowrap; }
.botao-ok:hover { background: #145c2e; }
.acoes { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .6rem; align-items: center; }

/* ---------- Mensagens ---------- */
.flash { border-radius: 10px; padding: .8rem 1rem; margin: .8rem 0; font-size: .95rem; }
.flash-sucesso { background: var(--ok-fundo); color: var(--ok); border: 1px solid #bfe3cb; }
.flash-erro { background: var(--erro-fundo); color: var(--erro); border: 1px solid #f2c4c1; }
.aviso { border-radius: 10px; padding: .7rem 1rem; margin: .8rem 0; font-size: .92rem; }
.aviso-info { background: var(--info-fundo); color: var(--info); border: 1px solid #f3e0ac; }
.aviso-alerta { background: var(--erro-fundo); color: var(--erro); }

/* ---------- Listas e tabelas ---------- */
.lista { list-style: none; margin: .5rem 0; padding: 0; }
.lista-item {
  display: flex; justify-content: space-between; align-items: center; gap: .8rem;
  padding: .55rem 0; border-bottom: 1px solid var(--borda);
}
.lista-item:last-child { border-bottom: none; }

.tabela { width: 100%; border-collapse: collapse; font-size: .92rem; }
.tabela th, .tabela td { text-align: left; padding: .5rem .4rem; border-bottom: 1px solid var(--borda); }
.tabela th { font-size: .8rem; text-transform: uppercase; letter-spacing: .04em; color: var(--mudo); }

/* ---------- Portaria ---------- */
.contador {
  background: var(--primaria); color: var(--tinta); border-radius: 12px; text-align: center;
  padding: .8rem; font-size: 1.05rem; margin: .8rem 0; font-weight: 600;
}
.contador strong { font-size: 1.4rem; }
.busca { margin: .8rem 0; display: flex; gap: .5rem; align-items: stretch; }
.busca input { flex: 1; font-size: 1.15rem; padding: .85rem .9rem; }
.busca #mostrar-todos { margin-top: 0; white-space: nowrap; }
.lista-portaria .lista-item { padding: .8rem .2rem; }
.nome-convidado { display: block; font-size: 1.1rem; font-weight: 600; }
.item-convidado.entrou { background: var(--ok-fundo); border-radius: 8px; padding-left: .6rem; padding-right: .6rem; }
.item-convidado .pequeno { display: block; }

/* Oferta de cessão aguardando aceite */
.oferta {
  background: var(--dourado-suave); border: 1px solid #f0dfae; border-radius: 10px;
  padding: .7rem .9rem; margin: .6rem 0;
}
.oferta p { margin: .2rem 0; }

details > summary { cursor: pointer; list-style: none; }
details > summary::before { content: '▸ '; }
details[open] > summary::before { content: '▾ '; }
details > summary h2 { display: inline; }

/* ---------- Telas pequenas ---------- */
@media (max-width: 520px) {
  .tabela thead { display: none; }
  .tabela tr { display: block; border-bottom: 2px solid var(--borda); padding: .4rem 0; }
  .tabela td { display: block; border: none; padding: .15rem .2rem; }
  .tabela-musicos td[data-rotulo]::before {
    content: attr(data-rotulo) ': '; font-size: .75rem; color: var(--mudo);
  }
  .tabela-musicos td[data-rotulo="Músico"]::before { content: ''; }
}
