:root { --azul:#1f3b86; --cinza:#e5e7eb; --txt:#0f172a; }

body{
  font-family:system-ui,-apple-system, Segoe UI, Roboto, Arial, sans-serif;
  margin:0; background:#1e3a8a; color:var(--txt);
}

.wrap{max-width:1100px; margin:28px auto; padding:0 16px;}
h1{margin:0 0 16px; color:var(--azul);}
#calendar{
  background:#fff; border:1px solid #e5e7eb; border-radius:12px; padding:12px;
  box-shadow:0 8px 24px rgba(2,6,23,.08);
}

/* Modal */
.modal{
  position:fixed; inset:0; background:rgba(2,6,23,.45); display:none;
  align-items:center; justify-content:center; padding:16px; z-index:50;
}
.modal.open{ display:flex; }

.card{
  background:#fff; border-radius:14px; max-width:480px; width:100%; padding:18px;
  border:1px solid #e5e7eb; box-shadow:0 10px 30px rgba(2,6,23,.20);
}
.card h2{ margin:0 0 10px; font-size:18px; }

.row{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.row-1{ display:grid; grid-template-columns:1fr; gap:10px; }

label{ font-size:13px; color:#475569; }
input,select,textarea{
  width:100%; padding:10px; border:1px solid #e2e8f0; border-radius:10px; background:#f8fafc;
}
textarea{ min-height:60px; resize:vertical; }

.actions{ display:flex; gap:10px; justify-content:flex-end; margin-top:12px; }
.btn{ padding:10px 14px; border-radius:10px; border:1px solid transparent; cursor:pointer; font-weight:600; }
.btn-primary{ background:linear-gradient(135deg,#3b82f6,#2563eb); color:#fff; }
.btn-ghost{ background:#fff; border-color:#e2e8f0; }
.color-dot{
  display:inline-block; width:14px; height:14px; border-radius:50%;
  vertical-align:middle; margin-right:6px; border:1px solid #cbd5e1;
}


#calendar { min-height: 520px; }

.fc-filters{
  display:flex; gap:10px; align-items:center; margin:10px 0 8px;
}
.fc-filters input{
  flex:1; max-width:320px; padding:10px;
  border:1px solid #e2e8f0; border-radius:10px; background:#f8fafc;
}
.fc-filters .btn-ghost{
  padding:10px 14px; border-radius:10px; border:1px solid #e2e8f0;
}
.fc-filters .btn-ghost.active{
  border-color:#2563eb; color:#2563eb;
}

/* Força cor legível para o texto dos eventos em todas as views */
#calendar { --fc-event-text-color: #0f172a; }

/* Lista (listMonth/listWeek): título e horário em cor escura */
.fc-theme-standard .fc-list .fc-list-event-title a,
.fc-theme-standard .fc-list .fc-list-event-time {
  color: #0f172a !important;
}

/* Hover suave na lista (opcional) */
.fc-theme-standard .fc-list .fc-list-event:hover td {
  background: #f1f5f9;
}

/* Força cor legível do texto de eventos em TODAS as views */
#calendar {
  --fc-event-text-color: #0f172a;        /* grid/agenda */
  --fc-list-event-text-color: #0f172a;   /* lista (listMonth/listWeek/listDay) */
}

/* Lista — garante cor escura mesmo se houver estilos globais de <a> */
#calendar .fc-list-event-title,
#calendar .fc-list-event-title a,
#calendar .fc-list-event-time {
  color: #0f172a !important;
}

/* (Opcional) se existir algum a { color: #fff } global, neutraliza dentro do calendário */
#calendar a { color: inherit !important; }

/* ===== MOBILE ===== */
@media (max-width: 640px){
  /* Filtro e botão: empilhar e ocupar 100% */
  .fc-filters{
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .fc-filters input,
  .fc-filters .btn-ghost{
    width: 100%;
  }

  /* Toolbar do FullCalendar em 2 linhas com título abaixo */
  .fc .fc-toolbar.fc-header-toolbar{
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "nav views"
      "title title";
    row-gap: 8px;
    align-items: center;
  }
  .fc .fc-toolbar-chunk:nth-child(1){ grid-area: nav; }   /* prev/next/hoje */
  .fc .fc-toolbar-chunk:nth-child(2){ grid-area: title; } /* título */
  .fc .fc-toolbar-chunk:nth-child(3){ grid-area: views; } /* Mês/Semana/Dia */

  /* Título menor e centralizado */
  .fc .fc-toolbar-title{
    font-size: 1.25rem;
    text-align: center;
  }

  /* Botões mais compactos */
  .fc .fc-button{ padding: 6px 10px; border-radius: 8px; }
  .fc .fc-button-group .fc-button{ margin: 0; }
}

/* ===== Legibilidade na view de LISTA ===== */

/* Cabeçalhos de dia (ex.: "10 de outubro de 2025") */
#calendar .fc-list-day-cushion,
#calendar .fc-list-day-text,
#calendar .fc-list-day-text a,
#calendar .fc-list-day-side-text,
#calendar .fc-list-day-side-text a {
  color: #0f172a !important; /* força texto escuro */
}

/* Título e horário de cada evento na lista */
#calendar .fc-list-event-title,
#calendar .fc-list-event-title a,
#calendar .fc-list-event-time {
  color: #0f172a !important;
}

/* Neutraliza qualquer regra global que pinte links de branco */
#calendar a { color: inherit !important; }

/* ===== MOBILE: toolbar e botões mais compactos ===== */
@media (max-width: 640px){
  /* Toolbar em 2 linhas, com título abaixo */
  #calendar .fc .fc-toolbar.fc-header-toolbar{
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "nav views"
      "title title";
    row-gap: 8px;
    align-items: center;
  }
  #calendar .fc .fc-toolbar-chunk:nth-child(1){ grid-area: nav; }   /* prev/next/hoje */
  #calendar .fc .fc-toolbar-chunk:nth-child(2){ grid-area: title; } /* título */
  #calendar .fc .fc-toolbar-chunk:nth-child(3){ grid-area: views; } /* mês/semana/dia */

  /* Título menor e centralizado */
  #calendar .fc .fc-toolbar-title{ font-size: 1.25rem; text-align: center; }

  /* Botões menores, sem sombras exageradas */
  #calendar .fc .fc-button{ 
    padding: 6px 10px; 
    font-size: 14px; 
    line-height: 1.1;
    border-radius: 10px; 
    box-shadow: none;
  }
  #calendar .fc .fc-button-group{ gap: 6px; }
}

/* Cabeçalho do dia (ex.: "1 de novembro de 2025") */
#calendar .fc-list-day-cushion{
  border-radius: 10px;
  border: 1px solid #cbd5e1;
  background: #eef2ff;
  box-shadow: 0 1px 0 rgba(0,0,0,.04);
  margin: 8px 0 6px;
}

/* Cada evento na LISTA:
   - remove fundo/borda do lado do HORÁRIO,
   - aplica cartão apenas no lado do TÍTULO,
   - corrige a bolinha de cor. */
#calendar .fc-list-event-time .fc-list-event-cushion{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 12px 8px !important;
}

#calendar .fc-list-event-title .fc-list-event-cushion{
  display: block;
  background: #eaf2ff !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: 12px !important;
  padding: 12px 12px !important;
  box-shadow: 0 1px 0 rgba(0,0,0,.04);
}

/* Hover suave no cartão da lista */
#calendar .fc-list-event:hover .fc-list-event-title .fc-list-event-cushion{
  background: #e2e8f0 !important;
}

/* Alinha o marcador de cor (bolinha) e dá respiro */
#calendar .fc-list-event-graphic{ padding-left: 6px; padding-right: 6px; }


/* ===== LIST VIEW (mobile e desktop) — manter linha única do evento ===== */

/* Centraliza verticalmente as 3 células (tempo, bolinha, título) */
#calendar .fc-list .fc-list-table td {
  vertical-align: middle !important;
}

/* Deixa o horário menos alto para não "empurrar" a bolinha para baixo */
#calendar .fc-list-event-time .fc-list-event-cushion {
  padding-top: 6px !important;
  padding-bottom: 6px !important;
}

/* Mantém a coluna da bolinha estreita, sem altura extra */
#calendar .fc-list-event-graphic {
  width: 18px;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* Cartão do título com respiro, mas sem exagero que quebre a linha */
#calendar .fc-list-event-title .fc-list-event-cushion {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

/* Garante que o texto do título não quebre por estilos globais */
#calendar .fc-list-event-title a {
  display: inline-block;
  line-height: 1.25;
}

/* ===== LIST VIEW — alinhar bolinha e título na MESMA LINHA ===== */

/* alinhar topo em todas as células da linha da lista */
#calendar .fc-list .fc-list-table td{
  vertical-align: top !important;
}

/* célula da bolinha: usa flex para alinhar ao texto e sem altura extra */
#calendar .fc-list-event-graphic{
  display: flex;
  align-items: center;
  width: 18px;               /* estreita */
  padding: 8px 6px 0 !important;  /* pequeno top para casar com o título */
}

/* horário menor, sem “empurrar” a linha pra baixo */
#calendar .fc-list-event-time .fc-list-event-cushion{
  padding: 6px 8px !important;      /* top/bottom iguais e curtos */
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* “cartão” do título com altura parecida (não exagere no padding) */
#calendar .fc-list-event-title .fc-list-event-cushion{
  display: block;
  padding: 8px 12px !important;     /* ↓ um pouco no top/bottom para nivelar */
  border: 1px solid #cbd5e1 !important;
  border-radius: 12px !important;
  background: #eaf2ff !important;
  box-shadow: 0 1px 0 rgba(0,0,0,.04);
}

/* título não quebra por estilo global e mantém linha “apertada” */
#calendar .fc-list-event-title a{
  display: inline-block;
  line-height: 1.25;
}

/* chip de horário inserido no título (lista) */
#calendar .fc-inline-time{
  display:inline-block;
  font-weight:600;
  margin-right:8px;
  color:#0f172a; /* legível em fundo claro */
}

/* Alinhamentos finos na list view */
#calendar .fc-list .fc-list-table td{ vertical-align:middle; }
#calendar .fc-list-event-graphic{ width:18px; padding:0 6px; }
#calendar .fc-list-event-title .fc-list-event-cushion{
  padding:8px 12px !important;
}

/* Botão/caret no cabeçalho do DIA (list view) */
#calendar .ens-day-btn{
  float: right;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 8px;
}
#calendar .ens-day-btn:hover{ background: rgba(0,0,0,.06); }
#calendar .ens-day-caret{
  display: inline-block;
  transition: transform .18s ease;
}
#calendar .ens-day-caret.open{ transform: rotate(180deg); }

/* “chip” de horário in-line no título do evento (já usado antes) */
#calendar .fc-inline-time{
  display:inline-block; font-weight:600; margin-right:8px; color:#0f172a;
}
