/* =====================================================================
   Sistema de Agendamento de Recursos — estilos compartilhados
   Paleta: tons de verde-petróleo (institucional, calmo) + âmbar
   (disponibilidade) + vermelho terracota (indisponibilidade)
   ===================================================================== */

:root {
  --cor-fundo: #F5F4F0;
  --cor-superficie: #FFFFFF;
  --cor-primaria: #2F5D62;
  --cor-primaria-escura: #234548;
  --cor-acento: #E08E45;
  --cor-texto: #20302E;
  --cor-texto-suave: #6B7770;
  --cor-borda: #E1DED4;

  --cor-disponivel: #3C8B6D;
  --cor-parcial: #D9A441;
  --cor-indisponivel: #C45B4D;

  --raio: 10px;
  --sombra: 0 2px 10px rgba(32, 48, 46, 0.08);
  --fonte: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  font-family: var(--fonte);
  background: var(--cor-fundo);
  color: var(--cor-texto);
}

a { color: var(--cor-primaria); text-decoration: none; }

h1, h2, h3 {
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0 0 .5rem;
}

/* ---------- Barra superior ---------- */
.barra-topo {
  background: var(--cor-primaria);
  color: #fff;
  padding: .9rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: var(--sombra);
}

.barra-topo .marca {
  font-weight: 800;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
}

.barra-topo .marca small {
  display: block;
  font-weight: 400;
  font-size: .72rem;
  opacity: .8;
}

.barra-topo .usuario {
  display: flex;
  align-items: center;
  gap: .75rem;
  font-size: .85rem;
}

.crachá-perfil {
  background: rgba(255,255,255,.18);
  padding: .2rem .55rem;
  border-radius: 999px;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.btn-saida {
  background: transparent;
  border: 1px solid rgba(255,255,255,.4);
  color: #fff;
  padding: .35rem .8rem;
  border-radius: var(--raio);
  cursor: pointer;
  font-size: .8rem;
}
.btn-saida:hover { background: rgba(255,255,255,.12); }

/* ---------- Navegação ---------- */
.nav-secao {
  display: flex;
  gap: .4rem;
  padding: .6rem 1.25rem;
  background: var(--cor-primaria-escura);
  overflow-x: auto;
}
.nav-secao a {
  color: rgba(255,255,255,.82);
  padding: .45rem .8rem;
  border-radius: var(--raio);
  font-size: .85rem;
  white-space: nowrap;
}
.nav-secao a.ativo, .nav-secao a:hover {
  background: rgba(255,255,255,.14);
  color: #fff;
}

/* ---------- Layout geral ---------- */
.conteudo {
  max-width: 1080px;
  margin: 0 auto;
  padding: 1.25rem 1rem 3rem;
}

.cartao {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  box-shadow: var(--sombra);
  padding: 1.1rem 1.2rem;
  margin-bottom: 1rem;
}

/* ---------- Formulários ---------- */
label {
  display: block;
  font-size: .78rem;
  color: var(--cor-texto-suave);
  margin: .6rem 0 .25rem;
  font-weight: 600;
}

input, select, textarea {
  width: 100%;
  padding: .55rem .65rem;
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  font-family: var(--fonte);
  font-size: .92rem;
  background: #fff;
  color: var(--cor-texto);
}
input:focus, select:focus, textarea:focus {
  outline: 2px solid var(--cor-primaria);
  outline-offset: 1px;
}

.btn {
  display: inline-block;
  border: none;
  border-radius: var(--raio);
  padding: .6rem 1.1rem;
  font-weight: 600;
  font-size: .9rem;
  cursor: pointer;
  font-family: var(--fonte);
}
.btn-primario { background: var(--cor-primaria); color: #fff; }
.btn-primario:hover { background: var(--cor-primaria-escura); }
.btn-acento { background: var(--cor-acento); color: #fff; }
.btn-acento:hover { filter: brightness(.93); }
.btn-discreto { background: transparent; color: var(--cor-texto-suave); border: 1px solid var(--cor-borda); }
.btn-perigo { background: var(--cor-indisponivel); color: #fff; }
.btn[disabled] { opacity: .5; cursor: not-allowed; }

/* ---------- Tabelas ---------- */
table { width: 100%; border-collapse: collapse; font-size: .88rem; }
th, td { text-align: left; padding: .55rem .5rem; border-bottom: 1px solid var(--cor-borda); }
th {
  cursor: pointer;
  color: var(--cor-texto-suave);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .03em;
  user-select: none;
}
th:hover { color: var(--cor-primaria); }
th .seta { opacity: .5; margin-left: .25rem; }
tbody tr:hover { background: #FAFAF7; }

/* ---------- Filtros ---------- */
.filtros {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: .6rem;
  margin-bottom: .8rem;
}

/* ---------- Calendário ---------- */
.calendario-cabecalho {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: .8rem;
}
.calendario-cabecalho .titulo-mes {
  font-size: 1.15rem;
  font-weight: 700;
}
.calendario-nav { display: flex; gap: .4rem; }
.calendario-nav button {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  width: 2.1rem; height: 2.1rem;
  cursor: pointer;
  font-size: 1rem;
}

.grade-semana {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: .4rem;
  margin-bottom: .4rem;
}
.grade-semana .rotulo-dia {
  text-align: center;
  font-size: .72rem;
  font-weight: 700;
  color: var(--cor-texto-suave);
  text-transform: uppercase;
}

.grade-mes {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: .4rem;
}

.dia-celula {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  min-height: 64px;
  padding: .4rem;
  cursor: pointer;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
.dia-celula:hover { border-color: var(--cor-primaria); }
.dia-celula.fora-do-mes { opacity: .35; cursor: default; }
.dia-celula.hoje { border: 2px solid var(--cor-primaria); }
.dia-celula.selecionado { background: #EFF5F1; border-color: var(--cor-disponivel); }
.dia-celula .numero { font-size: .85rem; font-weight: 600; }
.dia-celula .indicador {
  position: absolute;
  bottom: .4rem;
  left: .5rem;
  width: .5rem; height: .5rem;
  border-radius: 50%;
}

/* ---------- Painel do dia / cartões de recurso ---------- */
.lista-recursos-dia {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: .7rem;
}

.cartao-recurso {
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  padding: .8rem;
  cursor: pointer;
  background: #fff;
  transition: transform .08s ease;
}
.cartao-recurso:hover { transform: translateY(-2px); box-shadow: var(--sombra); }
.cartao-recurso.indisponivel { opacity: .55; cursor: not-allowed; }

.cartao-recurso .nome-recurso { font-weight: 700; font-size: .92rem; }
.cartao-recurso .tipo-recurso { font-size: .72rem; color: var(--cor-texto-suave); text-transform: uppercase; }

.selo-disponibilidade {
  display: inline-block;
  margin-top: .45rem;
  font-size: .75rem;
  font-weight: 700;
  padding: .15rem .5rem;
  border-radius: 999px;
}
.selo-disponivel { background: rgba(60,139,109,.14); color: var(--cor-disponivel); }
.selo-parcial { background: rgba(217,164,65,.16); color: var(--cor-parcial); }
.selo-indisponivel { background: rgba(196,91,77,.14); color: var(--cor-indisponivel); }

.bloco-horario { margin-bottom: 1.1rem; }
.bloco-horario h3 { font-size: .95rem; color: var(--cor-texto-suave); margin-bottom: .5rem; }

/* ---------- Modal ---------- */
.sobreposicao-modal {
  position: fixed; inset: 0;
  background: rgba(32,48,46,.45);
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
  z-index: 50;
}
.caixa-modal {
  background: #fff;
  border-radius: var(--raio);
  padding: 1.4rem;
  max-width: 380px;
  width: 100%;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}
.mensagem-erro {
  background: rgba(196,91,77,.1);
  color: var(--cor-indisponivel);
  border-radius: var(--raio);
  padding: .55rem .7rem;
  font-size: .85rem;
  margin: .6rem 0;
}
.mensagem-sucesso {
  background: rgba(60,139,109,.12);
  color: var(--cor-disponivel);
  border-radius: var(--raio);
  padding: .55rem .7rem;
  font-size: .85rem;
  margin: .6rem 0;
}

.acoes-modal { display: flex; gap: .5rem; margin-top: 1rem; }
.acoes-modal .btn { flex: 1; }

/* ---------- Utilidades ---------- */
.linha-acoes { display: flex; gap: .5rem; justify-content: flex-end; margin-top: .8rem; }
.texto-suave { color: var(--cor-texto-suave); font-size: .82rem; }
.vazio { text-align: center; padding: 2rem 1rem; color: var(--cor-texto-suave); }

@media (max-width: 640px) {
  .conteudo { padding: 1rem .6rem 3rem; }
  .dia-celula { min-height: 48px; }
}
