/* ============================================================
   CALENDÁRIO OLÍMPICO — Camada visual "Avance Olímpico"
   Sub-fase 1 (tela principal): cabeçalho da marca + remap de
   accents (azul→roxo/ouro) + refino de painéis, filtros, tabela,
   abas de "eventos importantes", control bar e cards mobile.
   Escopo: #view-calendario (não afeta outras abas).
   Temas: body:not(.theme-light) = ESCURO | body.theme-light = CLARO
   Cores herdadas de #avanceBrandHardening: --av-roxo / --av-ouro
   ============================================================ */

/* ---- Tipografia da marca ---- */
#view-calendario{ font-family:'Inter', system-ui, -apple-system, "Segoe UI", sans-serif; }
#view-calendario h1,
#view-calendario h2,
#view-calendario h3,
#view-calendario h4{ font-family:'Poppins','Inter',sans-serif; letter-spacing:.01em; }

/* ---- Refino de cantos de inputs e painéis ---- */
#view-calendario input,
#view-calendario select,
#view-calendario textarea{ border-radius:12px !important; }
#view-calendario .rounded-2xl{ border-radius:18px !important; }
#view-calendario .rounded-xl{ border-radius:13px !important; }

/* ============================================================
   Cabeçalho da seção (faixa roxa com logo + total)
   ============================================================ */
#view-calendario .av-cal-header{
  display:flex; align-items:center; gap:14px;
  background:linear-gradient(135deg,#5B1F7E,#3C1457);
  border-radius:18px; padding:16px 20px; border:none;
}
#view-calendario .av-cal-header h2{ color:#fff !important; font-size:20px; font-weight:600; margin:0; }
#view-calendario .av-cal-header p{ color:rgba(255,255,255,.72) !important; margin:2px 0 0; font-size:12.5px; }
#view-calendario .av-cal-headtext{ flex:1; min-width:0; }
#view-calendario .av-cal-logo{
  width:44px; height:44px; border-radius:12px; background:rgba(255,255,255,.14);
  display:flex; align-items:center; justify-content:center; position:relative; flex:0 0 auto;
}
#view-calendario .av-cal-logo b{ color:#fff; font-family:'Poppins',sans-serif; font-size:23px; line-height:1; }
#view-calendario .av-cal-logo::after{
  content:""; position:absolute; left:9px; bottom:10px; width:12px; height:3px;
  background:var(--av-ouro); border-radius:1px;
}
#view-calendario .av-cal-total{
  background:rgba(255,255,255,.15); color:#fff; border-radius:999px;
  padding:8px 16px; font-size:12.5px; white-space:nowrap; align-self:center;
}
#view-calendario .av-cal-total span{ color:var(--av-ouro); font-weight:600; }
@media (max-width:640px){
  #view-calendario .av-cal-header{ flex-wrap:wrap; }
  #view-calendario .av-cal-total{ order:3; width:100%; text-align:center; }
}

/* ============================================================
   Remap de accents AZUL → ROXO/OURO da marca
   (a tela vinha em azul; a identidade é roxo + ouro)
   ============================================================ */
#view-calendario .text-blue-400,
#view-calendario .text-blue-300{ color:#C9A6E8 !important; }
#view-calendario .bg-blue-600,
#view-calendario .bg-blue-700{ background-color:var(--av-roxo) !important; }
#view-calendario .hover\:bg-blue-700:hover{ background-color:#6E2A94 !important; }
#view-calendario .border-blue-500{ border-color:rgba(155,111,212,.6) !important; }
#view-calendario .border-blue-900\/50{ border-color:rgba(155,111,212,.4) !important; }
#view-calendario .text-blue-400.hover\:bg-blue-950\/30:hover,
#view-calendario .hover\:bg-blue-950\/30:hover{ background-color:rgba(91,31,126,.22) !important; }
#view-calendario .shadow-blue-950\/30{ box-shadow:0 8px 22px rgba(46,16,68,.4) !important; }
/* datas em ouro da marca */
#view-calendario .text-amber-400{ color:var(--av-ouro) !important; }

body.theme-light #view-calendario .text-blue-400,
body.theme-light #view-calendario .text-blue-300{ color:var(--av-roxo) !important; }

/* ============================================================
   Painéis (Adicionar evento manual / Importar via Excel)
   ============================================================ */
#view-calendario > div > div.rounded-2xl{ transition:border-color .15s ease, box-shadow .15s ease; }
#view-calendario > div > div.rounded-2xl:hover{ border-color:rgba(155,111,212,.5) !important; }
body.theme-light #view-calendario > div > div.rounded-2xl:hover{ border-color:rgba(91,31,126,.45) !important; }

/* botão "Registrar Evento" = roxo da marca, formato consistente */
#view-calendario #formCadCronograma button[type="submit"]{
  background:var(--av-roxo) !important; border:1px solid var(--av-roxo) !important;
  text-transform:none !important; letter-spacing:0 !important; font-weight:600 !important;
}
#view-calendario #formCadCronograma button[type="submit"]:hover{ filter:brightness(1.12); }

/* dropzone de importação realça em ouro */
#view-calendario #dropZoneCronograma:hover{ border-color:rgba(212,175,55,.55) !important; }

/* ============================================================
   Card principal "Calendário Operacional" + filtros
   ============================================================ */
#view-calendario .grid label{ font-weight:600; }

/* faixa de filtros: leve realce roxo no foco */
#view-calendario select:focus,
#view-calendario input:focus,
#view-calendario textarea:focus{
  outline:none; border-color:rgba(155,111,212,.7) !important;
  box-shadow:0 0 0 3px rgba(91,31,126,.18) !important;
}

/* ============================================================
   Control bar de paginação (#calendarioLimpoControle)
   ============================================================ */
#view-calendario #calendarioLimpoControle{ background:rgba(91,31,126,.10) !important; border-color:rgba(155,111,212,.28) !important; }
body.theme-light #view-calendario #calendarioLimpoControle{ background:#faf8fc !important; border-color:rgba(91,31,126,.18) !important; }
#view-calendario #calendarioLimpoInfo b,
#view-calendario #calendarioImportantePager b{ color:var(--av-ouro) !important; }

/* ============================================================
   TABELA do calendário (desktop)
   ============================================================ */
#view-calendario table thead tr{
  background:linear-gradient(135deg, rgba(91,31,126,.55), rgba(60,20,87,.55)) !important;
}
#view-calendario table thead th{ color:#E7DCF2 !important; }
body.theme-light #view-calendario table thead tr{
  background:linear-gradient(135deg, rgba(91,31,126,.10), rgba(91,31,126,.05)) !important;
}
body.theme-light #view-calendario table thead th{ color:var(--av-roxo) !important; }
#view-calendario tbody tr{ transition:background .12s ease; }
#view-calendario tbody tr:hover{ background:rgba(91,31,126,.16) !important; }
body.theme-light #view-calendario tbody tr:hover{ background:rgba(91,31,126,.05) !important; }

/* chip de etapa padronizada com tom da marca */
#view-calendario tbody td .px-2.bg-gray-900{
  background:rgba(91,31,126,.18) !important; border-color:rgba(155,111,212,.32) !important; color:#E7DCF2 !important;
}
body.theme-light #view-calendario tbody td .px-2.bg-gray-900{
  background:rgba(91,31,126,.07) !important; border-color:rgba(91,31,126,.2) !important; color:var(--av-roxo) !important;
}

/* botões de linha (Editar / Relatar): forma consistente */
#view-calendario tbody td button,
#view-calendario .calendario-mobile-btn{
  border-radius:10px !important; text-transform:none !important; letter-spacing:0 !important;
}

/* ============================================================
   "Eventos importantes da olimpíada" — card + abas
   ============================================================ */
#view-calendario #calendarioEventosImportantes .fa-star{ color:var(--av-ouro) !important; }

/* aba ATIVA já vem com bg-blue-700 (remapeado p/ roxo acima);
   reforço de acabamento/transição das abas */
#view-calendario .calendario-importante-aba{
  transition:background .12s ease, border-color .12s ease, color .12s ease;
}
#view-calendario .calendario-importante-aba:hover{ border-color:rgba(155,111,212,.5) !important; }

/* ============================================================
   CARDS MOBILE — refino da marca (complementa responsive.css)
   ============================================================ */
@media (max-width:768px){
  #view-calendario .calendario-mobile-card{
    border-color:rgba(155,111,212,.26) !important;
    background:rgba(91,31,126,.08) !important;
  }
  body.theme-light #view-calendario .calendario-mobile-card{
    background:#fff !important; border-color:rgba(91,31,126,.16) !important;
  }
  #view-calendario .calendario-mobile-date{ color:var(--av-ouro) !important; }
  #view-calendario .calendario-mobile-btn.is-edit{
    color:#C9A6E8 !important; border-color:rgba(155,111,212,.45) !important;
  }
  body.theme-light #view-calendario .calendario-mobile-btn.is-edit{
    color:var(--av-roxo) !important; border-color:rgba(91,31,126,.35) !important;
  }
}

/* ============================================================
   Estado vazio
   ============================================================ */
#view-calendario .calendario-mobile-empty{ color:#9c93b3; }
body.theme-light #view-calendario .calendario-mobile-empty{ color:var(--av-light-muted); }

/* ============================================================
   SUB-FASE 2 — Toggle de visualização + LINHA DO TEMPO (agenda)
   ============================================================ */
#view-calendario .av-cal-viewtoggle{ display:inline-flex; background:rgba(0,0,0,.25); border:1px solid rgba(155,111,212,.28); border-radius:11px; padding:3px; gap:3px; }
body.theme-light #view-calendario .av-cal-viewtoggle{ background:#f1edf6; border-color:rgba(91,31,126,.18); }
#view-calendario .av-cal-viewbtn{ display:inline-flex; align-items:center; gap:6px; border:none; background:transparent; color:#9c93b3; font-size:11.5px; font-weight:600; padding:6px 11px; border-radius:9px; cursor:pointer; transition:background .12s ease, color .12s ease; white-space:nowrap; }
#view-calendario .av-cal-viewbtn i{ font-size:11px; }
#view-calendario .av-cal-viewbtn:hover{ color:#e7def4; }
body.theme-light #view-calendario .av-cal-viewbtn:hover{ color:var(--av-roxo); }
#view-calendario .av-cal-viewbtn.is-active{ background:var(--av-roxo); color:#fff; box-shadow:0 2px 8px rgba(46,16,68,.4); }
body.theme-light #view-calendario .av-cal-viewbtn.is-active{ color:#fff; }

#view-calendario .av-cal-timeline{ display:flex; flex-direction:column; gap:18px; padding:6px 4px 4px; }
#view-calendario .av-cal-month-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:10px; padding-bottom:7px; border-bottom:1px solid rgba(155,111,212,.22); }
body.theme-light #view-calendario .av-cal-month-head{ border-bottom-color:rgba(91,31,126,.16); }
#view-calendario .av-cal-month-name{ font-family:'Poppins','Inter',sans-serif; font-size:14px; font-weight:600; color:#E7DCF2; text-transform:capitalize; }
body.theme-light #view-calendario .av-cal-month-name{ color:var(--av-roxo); }
#view-calendario .av-cal-month-count{ font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--av-ouro); white-space:nowrap; }
#view-calendario .av-cal-month-list{ display:flex; flex-direction:column; gap:10px; }

#view-calendario .av-cal-tl-card{ display:grid; grid-template-columns:18px 1fr; gap:12px; background:rgba(91,31,126,.08); border:1px solid rgba(155,111,212,.22); border-radius:14px; padding:13px 15px; transition:border-color .12s ease, transform .1s ease; }
#view-calendario .av-cal-tl-card:hover{ border-color:rgba(155,111,212,.5); transform:translateX(2px); }
body.theme-light #view-calendario .av-cal-tl-card{ background:#fff; border-color:var(--av-light-line); box-shadow:0 3px 12px rgba(91,31,126,.06); }
body.theme-light #view-calendario .av-cal-tl-card:hover{ border-color:rgba(91,31,126,.4); }

#view-calendario .av-cal-tl-rail{ display:flex; justify-content:center; padding-top:4px; position:relative; }
#view-calendario .av-cal-tl-rail::before{ content:""; position:absolute; top:14px; bottom:-17px; width:2px; background:rgba(155,111,212,.22); }
body.theme-light #view-calendario .av-cal-tl-rail::before{ background:rgba(91,31,126,.14); }
#view-calendario .av-cal-month-list > .av-cal-tl-card:last-child .av-cal-tl-rail::before{ display:none; }
#view-calendario .av-cal-tl-dot{ width:12px; height:12px; border-radius:50%; background:#9c93b3; z-index:1; box-shadow:0 0 0 3px rgba(155,111,212,.14); }
#view-calendario .av-cal-tl-card.is-agora  .av-cal-tl-dot{ background:var(--av-ouro); box-shadow:0 0 0 4px rgba(212,175,55,.22); }
#view-calendario .av-cal-tl-card.is-proximo .av-cal-tl-dot{ background:#1D9E75; box-shadow:0 0 0 4px rgba(29,158,117,.2); }
#view-calendario .av-cal-tl-card.is-futuro  .av-cal-tl-dot{ background:#9B6FD4; box-shadow:0 0 0 4px rgba(155,111,212,.2); }
#view-calendario .av-cal-tl-card.is-passado .av-cal-tl-dot,
#view-calendario .av-cal-tl-card.is-semdata .av-cal-tl-dot{ background:#6b6480; }
#view-calendario .av-cal-tl-card.is-passado{ opacity:.72; }

#view-calendario .av-cal-tl-top{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
#view-calendario .av-cal-tl-date{ display:inline-flex; align-items:center; font-family:'Inter',sans-serif; font-size:12.5px; font-weight:600; color:var(--av-ouro); }
#view-calendario .av-cal-tl-top .mt-1{ margin-top:0 !important; }
#view-calendario .av-cal-tl-oli{ font-family:'Poppins','Inter',sans-serif; font-size:15px; font-weight:600; color:#f4f1fa; margin:6px 0 3px; }
body.theme-light #view-calendario .av-cal-tl-oli{ color:var(--av-carvao); }
#view-calendario .av-cal-tl-etapa{ margin-bottom:4px; }
#view-calendario .av-cal-tl-etapa span{ background:rgba(91,31,126,.18) !important; border-color:rgba(155,111,212,.32) !important; color:#E7DCF2 !important; font-size:11px; }
body.theme-light #view-calendario .av-cal-tl-etapa span{ background:rgba(91,31,126,.07) !important; border-color:rgba(91,31,126,.2) !important; color:var(--av-roxo) !important; }
#view-calendario .av-cal-tl-acao{ font-size:12.5px; line-height:1.5; color:#c9c2d8; margin:6px 0 0; }
body.theme-light #view-calendario .av-cal-tl-acao{ color:#4a4357; }
#view-calendario .av-cal-tl-foot{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:8px; margin-top:10px; }
#view-calendario .av-cal-tl-tag{ display:inline-flex; align-items:center; gap:6px; font-size:11.5px; color:#9c93b3; }
body.theme-light #view-calendario .av-cal-tl-tag{ color:var(--av-light-muted); }
#view-calendario .av-cal-tl-tag i{ color:var(--av-ouro); font-size:11px; }
#view-calendario .av-cal-tl-actions{ display:flex; flex-wrap:wrap; gap:7px; }
#view-calendario .av-cal-tl-btn{ display:inline-flex; align-items:center; gap:5px; border-radius:9px; padding:6px 11px; font-size:11.5px; font-weight:600; cursor:pointer; border:1px solid transparent; background:transparent; transition:background .12s ease; }
#view-calendario .av-cal-tl-btn.is-edit{ color:#C9A6E8; border-color:rgba(155,111,212,.45); }
#view-calendario .av-cal-tl-btn.is-edit:hover{ background:rgba(91,31,126,.22); }
body.theme-light #view-calendario .av-cal-tl-btn.is-edit{ color:var(--av-roxo); border-color:rgba(91,31,126,.35); }
#view-calendario .av-cal-tl-btn.is-report{ color:#E6C158; border-color:rgba(212,175,55,.4); }
#view-calendario .av-cal-tl-btn.is-report:hover{ background:rgba(212,175,55,.14); }

#view-calendario .av-cal-tl-empty{ border-radius:14px; padding:34px 20px; text-align:center; background:rgba(91,31,126,.08); border:1px dashed rgba(155,111,212,.3); color:#9c93b3; }
body.theme-light #view-calendario .av-cal-tl-empty{ background:#faf8fc; border-color:rgba(91,31,126,.2); color:var(--av-light-muted); }

@media (max-width:640px){
  #view-calendario .av-cal-viewtoggle{ width:100%; }
  #view-calendario .av-cal-viewbtn{ flex:1; justify-content:center; }
}

/* ============================================================
   SUB-FASE 3 — Modal "Relatar problema" (próprio do calendário)
   Fica fora de #view-calendario (anexado ao body) → escopo por id.
   ============================================================ */
#modalProblemaCalendario.av-cal-modal{ position:fixed; inset:0; z-index:95; display:flex; align-items:center; justify-content:center; padding:24px 16px; font-family:'Inter',system-ui,-apple-system,"Segoe UI",sans-serif; }
#modalProblemaCalendario .av-cal-modal-overlay{ position:absolute; inset:0; background:rgba(8,4,12,.8); backdrop-filter:blur(4px); }
#modalProblemaCalendario .av-cal-modal-card{ position:relative; width:100%; max-width:560px; background:#1b1626; border:1px solid rgba(155,111,212,.28); border-radius:18px; box-shadow:0 24px 60px rgba(0,0,0,.5); overflow:hidden; }
body.theme-light #modalProblemaCalendario .av-cal-modal-card{ background:#fff; border-color:var(--av-light-line); }

#modalProblemaCalendario .av-cal-modal-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:18px 20px; background:linear-gradient(135deg,#5B1F7E,#3C1457); }
#modalProblemaCalendario .av-cal-modal-head-main{ display:flex; gap:12px; min-width:0; }
#modalProblemaCalendario .av-cal-modal-icon{ width:40px; height:40px; flex:0 0 auto; border-radius:11px; background:rgba(212,175,55,.18); color:var(--av-ouro); display:flex; align-items:center; justify-content:center; font-size:18px; }
#modalProblemaCalendario .av-cal-modal-head h3{ font-family:'Poppins','Inter',sans-serif; color:#fff; font-size:16px; font-weight:600; margin:0; }
#modalProblemaCalendario .av-cal-modal-oli{ color:var(--av-ouro); font-weight:600; font-size:12.5px; margin:3px 0 0; }
#modalProblemaCalendario .av-cal-modal-sub{ color:rgba(255,255,255,.66); font-size:11.5px; margin:2px 0 0; }
#modalProblemaCalendario .av-cal-modal-close{ background:rgba(255,255,255,.12); border:none; color:#fff; width:30px; height:30px; border-radius:9px; cursor:pointer; flex:0 0 auto; }
#modalProblemaCalendario .av-cal-modal-close:hover{ background:rgba(255,255,255,.22); }

#modalProblemaCalendario .av-cal-modal-body{ padding:18px 20px; display:flex; flex-direction:column; gap:12px; }
#modalProblemaCalendario .av-cal-modal-legend{ font-size:11px; text-transform:uppercase; letter-spacing:.04em; font-weight:700; color:#9c93b3; margin:0; }
body.theme-light #modalProblemaCalendario .av-cal-modal-legend{ color:var(--av-light-muted); }
#modalProblemaCalendario .av-cal-modal-tipos{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
#modalProblemaCalendario .av-cal-modal-check{ display:flex; align-items:center; gap:8px; font-size:12.5px; color:#cfc7de; background:rgba(0,0,0,.22); border:1px solid rgba(155,111,212,.2); border-radius:10px; padding:9px 11px; cursor:pointer; transition:border-color .12s ease; }
#modalProblemaCalendario .av-cal-modal-check:hover{ border-color:rgba(155,111,212,.45); }
body.theme-light #modalProblemaCalendario .av-cal-modal-check{ background:#f7f4fb; border-color:rgba(91,31,126,.16); color:#4a4357; }
#modalProblemaCalendario .av-cal-modal-check input{ accent-color:var(--av-roxo); width:15px; height:15px; flex:0 0 auto; }
#modalProblemaCalendario .av-cal-modal-textarea{ width:100%; padding:11px 12px; border-radius:12px; background:rgba(0,0,0,.25); border:1px solid rgba(155,111,212,.22); color:#eee8f6; font-size:13px; line-height:1.5; resize:vertical; min-height:92px; }
#modalProblemaCalendario .av-cal-modal-textarea:focus{ outline:none; border-color:rgba(155,111,212,.7); box-shadow:0 0 0 3px rgba(91,31,126,.18); }
body.theme-light #modalProblemaCalendario .av-cal-modal-textarea{ background:#fff; border-color:var(--av-light-line); color:var(--av-carvao); }

#modalProblemaCalendario .av-cal-modal-foot{ display:flex; justify-content:flex-end; gap:10px; padding:0 20px 18px; }
#modalProblemaCalendario .av-cal-modal-btn-ghost,
#modalProblemaCalendario .av-cal-modal-btn-primary{ display:inline-flex; align-items:center; gap:7px; border-radius:11px; padding:9px 18px; font-size:12.5px; font-weight:600; cursor:pointer; }
#modalProblemaCalendario .av-cal-modal-btn-ghost{ background:transparent; border:1px solid rgba(155,111,212,.3); color:#c3bad6; }
#modalProblemaCalendario .av-cal-modal-btn-ghost:hover{ background:rgba(155,111,212,.14); }
body.theme-light #modalProblemaCalendario .av-cal-modal-btn-ghost{ border-color:rgba(91,31,126,.25); color:var(--av-roxo); }
#modalProblemaCalendario .av-cal-modal-btn-primary{ background:var(--av-roxo); border:1px solid var(--av-roxo); color:#fff; }
#modalProblemaCalendario .av-cal-modal-btn-primary:hover{ filter:brightness(1.12); }

@media (max-width:560px){
  #modalProblemaCalendario .av-cal-modal-tipos{ grid-template-columns:1fr; }
  #modalProblemaCalendario .av-cal-modal-foot{ flex-direction:column-reverse; }
  #modalProblemaCalendario .av-cal-modal-foot button{ width:100%; justify-content:center; }
}

/* ============================================================
   MELHORIAS — Exclusão em lote (checkbox + barra de ações)
   ============================================================ */
#view-calendario .av-cal-selbox{ display:inline-flex; align-items:center; margin-right:8px; vertical-align:middle; }
#view-calendario .av-cal-selbox input{ width:16px; height:16px; accent-color:var(--av-roxo); cursor:pointer; }
#view-calendario .av-cal-tl-top .av-cal-selbox{ margin-right:4px; }
#view-calendario #calBtnSelecaoLote.is-active{ background:rgba(226,75,74,.18) !important; color:#F09595 !important; border-color:rgba(226,75,74,.5) !important; }

.av-cal-selbar{ position:fixed; left:50%; bottom:20px; transform:translateX(-50%); z-index:99990; display:flex; flex-wrap:wrap; align-items:center; gap:14px; max-width:94vw; padding:12px 18px; border-radius:16px; background:#1b1626; border:1px solid rgba(155,111,212,.4); box-shadow:0 18px 50px rgba(0,0,0,.5); font-family:'Inter',system-ui,-apple-system,"Segoe UI",sans-serif; }
body.theme-light .av-cal-selbar{ background:#fff; border-color:var(--av-light-line); box-shadow:0 14px 40px rgba(91,31,126,.18); }
.av-cal-selbar-count{ font-size:13px; color:#e7def4; white-space:nowrap; }
.av-cal-selbar-count i{ color:var(--av-ouro); margin-right:4px; }
.av-cal-selbar-count b{ color:#fff; }
body.theme-light .av-cal-selbar-count{ color:#4a4357; }
body.theme-light .av-cal-selbar-count b{ color:var(--av-carvao); }
.av-cal-selbar-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
.av-cal-selbar-btn{ display:inline-flex; align-items:center; gap:6px; border-radius:10px; padding:8px 13px; font-size:12px; font-weight:600; cursor:pointer; border:1px solid rgba(155,111,212,.32); background:transparent; color:#c9c2d8; transition:background .12s ease, filter .12s ease; }
.av-cal-selbar-btn:hover{ background:rgba(155,111,212,.16); }
body.theme-light .av-cal-selbar-btn{ color:var(--av-roxo); border-color:rgba(91,31,126,.25); }
.av-cal-selbar-btn.is-ghost{ border-color:transparent; color:#8b83a0; }
.av-cal-selbar-btn.is-danger{ background:#E24B4A; border-color:#E24B4A; color:#fff; }
.av-cal-selbar-btn.is-danger:hover{ filter:brightness(1.1); }
.av-cal-selbar-btn:disabled{ opacity:.45; cursor:not-allowed; }
@media (max-width:560px){ .av-cal-selbar{ flex-direction:column; align-items:stretch; gap:10px; bottom:10px; } .av-cal-selbar-actions{ justify-content:stretch; } .av-cal-selbar-btn{ flex:1; justify-content:center; } }

/* ============================================================
   MELHORIAS — Filtros em checkbox (multi) + botão Filtrar
   ============================================================ */
#view-calendario #calFiltrosMulti{ display:flex; flex-wrap:wrap; align-items:flex-end; gap:12px; }
#view-calendario .av-cal-filtros-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(168px,1fr)); gap:10px; flex:1; min-width:0; }
#view-calendario .av-cal-filtro{ position:relative; }
#view-calendario .av-cal-filtro > summary{ list-style:none; cursor:pointer; display:flex; align-items:center; gap:8px; padding:9px 12px; border-radius:12px; background:#0e0a14; border:1px solid rgba(155,111,212,.28); font-size:12.5px; font-weight:600; color:#c9c2d8; }
#view-calendario .av-cal-filtro > summary::-webkit-details-marker{ display:none; }
body.theme-light #view-calendario .av-cal-filtro > summary{ background:#fff; border-color:var(--av-light-line); color:#4a4357; }
#view-calendario .av-cal-filtro > summary .lbl{ flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
#view-calendario .av-cal-filtro > summary .chev{ font-size:10px; transition:transform .15s ease; opacity:.7; }
#view-calendario .av-cal-filtro[open] > summary .chev{ transform:rotate(180deg); }
#view-calendario .av-cal-filtro.tem-sel > summary{ border-color:var(--av-roxo); color:#E7DCF2; }
body.theme-light #view-calendario .av-cal-filtro.tem-sel > summary{ color:var(--av-roxo); }
#view-calendario .av-cal-filtro > summary .cnt{ display:none; min-width:18px; height:18px; align-items:center; justify-content:center; font-size:10.5px; font-weight:700; border-radius:999px; color:#fff; }
#view-calendario .av-cal-filtro.tem-sel > summary .cnt{ display:inline-flex; background:var(--av-roxo); padding:0 5px; }
#view-calendario .av-cal-filtro-opts{ position:absolute; z-index:30; top:calc(100% + 4px); left:0; min-width:210px; max-width:300px; max-height:264px; overflow:auto; padding:6px; border-radius:12px; background:#171022; border:1px solid rgba(155,111,212,.4); box-shadow:0 16px 40px rgba(0,0,0,.5); display:flex; flex-direction:column; gap:2px; }
body.theme-light #view-calendario .av-cal-filtro-opts{ background:#fff; border-color:var(--av-light-line); box-shadow:0 12px 30px rgba(91,31,126,.16); }
#view-calendario .av-cal-filtro-op{ display:flex; align-items:center; gap:8px; padding:7px 9px; border-radius:9px; font-size:12.5px; color:#c9c2d8; cursor:pointer; }
#view-calendario .av-cal-filtro-op:hover{ background:rgba(155,111,212,.14); }
body.theme-light #view-calendario .av-cal-filtro-op{ color:#4a4357; }
#view-calendario .av-cal-filtro-op input{ accent-color:var(--av-roxo); width:15px; height:15px; flex:0 0 auto; }
#view-calendario .av-cal-filtro-vazio{ padding:8px; font-size:12px; color:#8b83a0; }
#view-calendario .av-cal-filtros-acoes{ display:flex; gap:8px; align-items:flex-end; }
#view-calendario .av-cal-filtrar-btn{ display:inline-flex; align-items:center; gap:4px; padding:9px 16px; border-radius:12px; background:var(--av-roxo); border:1px solid var(--av-roxo); color:#fff; font-size:12.5px; font-weight:600; cursor:pointer; transition:filter .12s ease; }
#view-calendario .av-cal-filtrar-btn:hover{ filter:brightness(1.12); }
#view-calendario .av-cal-limpar-btn{ padding:9px 14px; border-radius:12px; background:transparent; border:1px solid rgba(155,111,212,.3); color:#c3bad6; font-size:12.5px; font-weight:600; cursor:pointer; }
#view-calendario .av-cal-limpar-btn:hover{ background:rgba(155,111,212,.14); }
body.theme-light #view-calendario .av-cal-limpar-btn{ color:var(--av-roxo); border-color:rgba(91,31,126,.25); }
@media (max-width:640px){ #view-calendario .av-cal-filtros-acoes{ width:100%; } #view-calendario .av-cal-filtrar-btn{ flex:1; justify-content:center; } }

/* ============================================================
   IDEIAS — Próximos prazos + contagem regressiva (card destaque)
   ============================================================ */
#view-calendario .av-cal-prazos{ background:linear-gradient(135deg, rgba(91,31,126,.22), rgba(60,20,87,.12)); border:1px solid rgba(155,111,212,.3); border-radius:18px; padding:16px 18px; display:flex; flex-direction:column; gap:12px; }
body.theme-light #view-calendario .av-cal-prazos{ background:linear-gradient(135deg,#f7f1fb,#fff); border-color:rgba(91,31,126,.16); }
#view-calendario .av-cal-prazo-principal{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px; }
#view-calendario .av-cal-prazo-rotulo{ font-size:10.5px; text-transform:uppercase; letter-spacing:.05em; font-weight:700; color:var(--av-ouro); margin:0; }
#view-calendario .av-cal-prazo-rotulo i{ margin-right:5px; }
#view-calendario .av-cal-prazo-info h3{ font-family:'Poppins','Inter',sans-serif; font-size:18px; font-weight:600; color:#f4f1fa; margin:4px 0 2px; }
body.theme-light #view-calendario .av-cal-prazo-info h3{ color:var(--av-carvao); }
#view-calendario .av-cal-prazo-etapa{ font-size:12.5px; color:#b6adc9; margin:0; }
body.theme-light #view-calendario .av-cal-prazo-etapa{ color:#4a4357; }
#view-calendario .av-cal-prazo-cdwrap{ display:flex; align-items:center; gap:10px; }
#view-calendario .av-cal-prazo-cd{ display:flex; gap:8px; }
#view-calendario .av-cal-prazo-cd .cd-bloco{ min-width:54px; text-align:center; background:rgba(0,0,0,.25); border:1px solid rgba(212,175,55,.35); border-radius:12px; padding:8px 6px; }
body.theme-light #view-calendario .av-cal-prazo-cd .cd-bloco{ background:#fff; border-color:rgba(212,175,55,.5); }
#view-calendario .av-cal-prazo-cd .cd-bloco b{ display:block; font-family:'Poppins','Inter',sans-serif; font-size:22px; font-weight:600; color:var(--av-ouro); line-height:1; }
#view-calendario .av-cal-prazo-cd .cd-bloco span{ font-size:9.5px; text-transform:uppercase; letter-spacing:.04em; color:#8b83a0; }
#view-calendario .av-cal-prazo-agora{ display:inline-flex; align-items:center; gap:6px; font-size:14px; font-weight:700; color:var(--av-ouro); }
#view-calendario .av-cal-prazo-ics{ width:38px; height:38px; flex:0 0 auto; border-radius:11px; background:rgba(155,111,212,.16); border:1px solid rgba(155,111,212,.4); color:#C9A6E8; cursor:pointer; font-size:15px; transition:background .12s ease; }
#view-calendario .av-cal-prazo-ics:hover{ background:rgba(155,111,212,.3); }
#view-calendario .av-cal-prazo-ics.sm{ width:30px; height:30px; font-size:13px; }
body.theme-light #view-calendario .av-cal-prazo-ics{ color:var(--av-roxo); background:rgba(91,31,126,.08); border-color:rgba(91,31,126,.25); }
#view-calendario .av-cal-prazo-lista{ display:flex; flex-direction:column; gap:6px; border-top:1px solid rgba(155,111,212,.18); padding-top:10px; }
body.theme-light #view-calendario .av-cal-prazo-lista{ border-top-color:rgba(91,31,126,.12); }
#view-calendario .av-cal-prazo-item{ display:flex; align-items:center; gap:10px; }
#view-calendario .av-cal-prazo-dot{ width:9px; height:9px; border-radius:50%; flex:0 0 auto; background:#6b6480; }
#view-calendario .av-cal-prazo-dot.is-agora{ background:var(--av-ouro); }
#view-calendario .av-cal-prazo-dot.is-proximo{ background:#1D9E75; }
#view-calendario .av-cal-prazo-dot.is-futuro{ background:#9B6FD4; }
#view-calendario .av-cal-prazo-item-txt{ flex:1; min-width:0; display:flex; flex-direction:column; }
#view-calendario .av-cal-prazo-item-txt b{ font-size:12.5px; color:#e7def4; }
body.theme-light #view-calendario .av-cal-prazo-item-txt b{ color:var(--av-carvao); }
#view-calendario .av-cal-prazo-item-txt span{ font-size:11px; color:#8b83a0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
#view-calendario .av-cal-prazo-dias{ font-size:11.5px; font-weight:700; color:var(--av-ouro); white-space:nowrap; }
@media (max-width:560px){ #view-calendario .av-cal-prazo-cd .cd-bloco{ min-width:46px; } }

/* ============================================================
   IDEIAS — Visão Mês (grade de calendário)
   ============================================================ */
#view-calendario .av-cal-grade{ padding:14px 16px 18px; }
#view-calendario .av-cal-grade-head{ display:flex; align-items:center; gap:10px; margin-bottom:12px; }
#view-calendario .av-cal-grade-titulo{ flex:1; text-align:center; font-family:'Poppins','Inter',sans-serif; font-size:16px; font-weight:600; color:#E7DCF2; text-transform:capitalize; margin:0; }
body.theme-light #view-calendario .av-cal-grade-titulo{ color:var(--av-roxo); }
#view-calendario .av-cal-grade-titulo span{ font-size:11px; color:var(--av-ouro); text-transform:none; font-weight:700; }
#view-calendario .av-cal-grade-nav{ width:34px; height:34px; border-radius:10px; background:rgba(155,111,212,.14); border:1px solid rgba(155,111,212,.3); color:#C9A6E8; cursor:pointer; }
#view-calendario .av-cal-grade-nav:hover{ background:rgba(155,111,212,.28); }
body.theme-light #view-calendario .av-cal-grade-nav{ color:var(--av-roxo); background:rgba(91,31,126,.07); border-color:rgba(91,31,126,.2); }
#view-calendario .av-cal-grade-hoje{ padding:7px 12px; border-radius:10px; background:var(--av-roxo); border:1px solid var(--av-roxo); color:#fff; font-size:11.5px; font-weight:600; cursor:pointer; }
#view-calendario .av-cal-grade-hoje:hover{ filter:brightness(1.12); }
#view-calendario .av-cal-grade-semana{ display:grid; grid-template-columns:repeat(7,1fr); gap:6px; margin-bottom:6px; }
#view-calendario .av-cal-grade-semana > div{ text-align:center; font-size:10.5px; text-transform:uppercase; letter-spacing:.04em; font-weight:700; color:#8b83a0; }
#view-calendario .av-cal-grade-dias{ display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
#view-calendario .av-cal-dia{ min-height:92px; border-radius:10px; background:rgba(91,31,126,.06); border:1px solid rgba(155,111,212,.16); padding:5px 6px; display:flex; flex-direction:column; gap:3px; overflow:hidden; }
body.theme-light #view-calendario .av-cal-dia{ background:#faf8fc; border-color:rgba(91,31,126,.1); }
#view-calendario .av-cal-dia.is-vazio{ background:transparent; border-color:transparent; }
#view-calendario .av-cal-dia.tem-ev{ border-color:rgba(155,111,212,.4); }
#view-calendario .av-cal-dia.is-hoje{ border-color:var(--av-ouro); box-shadow:inset 0 0 0 1px var(--av-ouro); }
#view-calendario .av-cal-dia-num{ font-size:12px; font-weight:700; color:#c9c2d8; }
body.theme-light #view-calendario .av-cal-dia-num{ color:#4a4357; }
#view-calendario .av-cal-dia.is-hoje .av-cal-dia-num{ color:var(--av-ouro); }
#view-calendario .av-cal-dia-pill{ display:block; font-size:10px; font-weight:600; padding:2px 6px; border-radius:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; cursor:pointer; background:rgba(155,111,212,.22); color:#E7DCF2; border-left:3px solid #9B6FD4; }
#view-calendario .av-cal-dia-pill.is-agora{ border-left-color:var(--av-ouro); background:rgba(212,175,55,.18); color:#E6C158; }
#view-calendario .av-cal-dia-pill.is-proximo{ border-left-color:#1D9E75; background:rgba(29,158,117,.16); color:#7FD3B4; }
#view-calendario .av-cal-dia-pill.is-passado{ border-left-color:#6b6480; background:rgba(120,114,140,.14); color:#a39db5; }
body.theme-light #view-calendario .av-cal-dia-pill{ background:rgba(91,31,126,.1); color:var(--av-roxo); }
#view-calendario .av-cal-dia-mais{ font-size:9.5px; color:#8b83a0; font-weight:700; }
@media (max-width:640px){ #view-calendario .av-cal-dia{ min-height:62px; } #view-calendario .av-cal-dia-pill{ font-size:0; padding:0; height:5px; border-radius:3px; border-left:none; margin-bottom:2px; } }

/* ============================================================
   IDEIAS — "Meus eventos" (estrela seguir + toggle)
   ============================================================ */
#view-calendario .av-cal-star{ display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:8px; background:transparent; border:1px solid rgba(155,111,212,.3); color:#8b83a0; cursor:pointer; font-size:12px; transition:color .12s ease, background .12s ease, border-color .12s ease; }
#view-calendario .av-cal-star:hover{ color:var(--av-ouro); background:rgba(212,175,55,.12); }
#view-calendario .av-cal-star.is-on{ color:var(--av-ouro); border-color:rgba(212,175,55,.5); background:rgba(212,175,55,.14); }
body.theme-light #view-calendario .av-cal-star{ border-color:rgba(91,31,126,.2); }
#view-calendario .av-cal-tl-actions .av-cal-star{ width:30px; height:30px; }
#view-calendario #calBtnMeusEventos.is-active{ background:rgba(212,175,55,.16) !important; color:#E6C158 !important; border-color:rgba(212,175,55,.55) !important; }
