/* ===== Alericos — Agendamento (padrão visual do alx-rec) ===== */
.alx-agenda{
  --bg:#001219; --panel:#ffffff; --text:#001219; --muted:rgba(0,0,0,.72);
  --line:#e6eef5; --link:#042569; --brand:#219EBC; --brand-hover:#023047;
  --ok:#10b981; --warn:#f59e0b; --err:#ef4444;
  font:500 14px/1.5 ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto;
  color:var(--text);
}
.alx-agenda *{ box-sizing:border-box }
.alx-agenda__wrap{ max-width:980px; margin:16px auto; padding:0 12px; }
.alx-agenda__head{ margin:8px 0 16px }
.alx-agenda__title{ margin:0 0 4px; font-size:22px; color:var(--text) }
.alx-agenda__hint{ color:var(--muted); margin:0 }

/* ---------- Botões (força prioridade contra tema) ---------- */
.alx-agenda .alx-btn{
  background:var(--brand) !important; color:#fff !important; border:none;
  border-radius:10px; padding:10px 14px; cursor:pointer; font-weight:600;
  transition:background-color .2s ease, transform .02s ease, box-shadow .2s ease;
  box-shadow:none;
}
.alx-agenda .alx-btn:hover,
.alx-agenda .alx-btn:focus{ background:var(--brand-hover) !important; color:#fff !important; }
.alx-agenda .alx-btn:active{ transform:translateY(1px) }
.alx-agenda .alx-btn[disabled]{ opacity:.5; cursor:not-allowed }
.alx-agenda .alx-btn--ghost{
  background:#fff !important; color:var(--brand) !important; border:1px solid var(--brand) !important;
}
.alx-agenda .alx-btn--ghost:hover,
.alx-agenda .alx-btn--ghost:focus{
  background:var(--brand) !important; color:#fff !important;
}

/* ===================================================================
   MODALIDADES — cards
   =================================================================== */
.alx-mods{
  display:grid; grid-template-columns:repeat(12,1fr); gap:14px; margin:10px 0 18px;
}
.alx-mod{
  grid-column:span 6; position:relative; overflow:hidden;
  background:var(--panel); border:1px solid var(--line);
  border-radius:14px; padding:16px; box-shadow:0 4px 24px rgba(0,0,0,.06);
  transition:border-color .2s ease, box-shadow .2s ease, transform .02s ease-in;
}
.alx-mod:hover{ border-color:#cfeaf3; box-shadow:0 8px 32px rgba(0,0,0,.08) }
.alx-mod.is-selected{ border-color:var(--brand); box-shadow:0 0 0 3px rgba(33,158,188,.18) }
.alx-mod__head{ display:flex; justify-content:space-between; align-items:flex-start; gap:10px }
.alx-mod__title{ font-size:18px; font-weight:700; margin:0 0 6px }
.alx-mod__meta{ display:flex; align-items:center; gap:10px; color:var(--muted) }
.alx-mod__actions{ margin-top:12px; display:flex; gap:10px; align-items:center; flex-wrap:wrap }

/* Overlay clicável do card — impede herança do tema (rosa) */
.alx-mod__select{
  position:absolute; inset:0; z-index:1; border-radius:14px;
  background:transparent !important; border:0 !important; text-indent:-9999px;
  cursor:pointer; box-shadow:none !important; outline:none !important;
}
.alx-mod__select:hover,
.alx-mod__select:focus,
.alx-mod__select:focus{
  /* azul da marca com leve opacidade */
  background: rgba(33, 158, 188, .20) !important; /* #219EBC @ 20% */
  box-shadow: none !important;
  outline: none !important;
}


/* sem crédito */
.alx-mod--no-credit{ opacity:.5 }
.alx-mod--no-credit .alx-mod__select{ display:none }
.alx-mod--no-credit .alx-mod__actions .alx-mod__buy{ display:inline-flex }
.alx-mod__buy{ display:none }

@media (max-width:860px){ .alx-mod{ grid-column:1 / -1 } }

/* ---------- créditos do usuário ---------- */
.alx-creditos{ margin:8px 0 16px }
.alx-creditos__ul{ margin:6px 0 0; padding-left:18px }

/* ===================================================================
   CARD DO AGENDAMENTO (calendário + colunas de horários)
   =================================================================== */
.alx-book{ margin-top:8px; }
.alx-book__head{
  display:flex; justify-content:space-between; align-items:center; gap:10px; margin-bottom:12px;
}
.alx-book__title{ margin:0; font-size:16px; font-weight:700 }
.alx-book__tz{ color:var(--muted); font-size:13px }

.alx-book__grid{ display:grid; grid-template-columns:280px 1fr; gap:20px; }
@media (max-width:860px){ .alx-book__grid{ grid-template-columns:1fr } }

/* calendário (o Flatpickr será inserido aqui) */
#alx-cal{ position:relative; }
#alx-cal-input{ display:none } /* input técnico oculto */

/* colunas da semana */
.alx-week{ display:grid; grid-template-columns:repeat(5,1fr); gap:12px; }
@media (max-width:860px){ .alx-week{ grid-template-columns:repeat(2,1fr) } }

.alx-col{ border:1px solid var(--line); border-radius:12px; padding:10px; background:#fff; min-height:120px }
.alx-col__head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:8px }
.alx-col__dow{ font-weight:700; text-transform:uppercase; color:var(--muted) }
.alx-col__date{ font-weight:700 }
.alx-col__slots{ display:flex; flex-direction:column; gap:8px }
.alx-col__empty{ color:#9aa7b4; text-align:center }

/* pílulas de horário */
.alx-slot{
  padding:8px 12px; border:1px solid var(--brand) !important; background:#fff !important; color:var(--brand) !important;
  border-radius:999px; cursor:pointer; transition:background-color .15s, color .15s, border-color .15s;
  text-align:center;
}
.alx-slot:hover,
.alx-slot:focus{
  background:var(--brand) !important; color:#fff !important; border-color:var(--brand) !important;
}
.alx-slot:active{ transform:translateY(1px) }

/* estado vazio */
.alx-week-empty{ text-align:center; color:var(--muted); margin-top:10px }

/* estados/avisos */
.alx-empty{ color:#666 }
.alx-loading{ color:#333 }
.alx-feedback{ margin-top:14px; padding:8px 10px; border-radius:8px; background:#f8fafc; border:1px solid var(--line) }
.alx-feedback.is-ok{ border-color:var(--ok); color:#065f46 }
.alx-feedback.is-warn{ border-color:var(--warn); color:#92400e }
.alx-feedback.is-err{ border-color:var(--err); color:#991b1b }

/* overlay */
.alx-overlay[hidden]{ display:none }
.alx-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.35); display:grid; place-items:center; z-index:9999; }
.alx-spinner{ background:#fff; padding:14px 16px; border-radius:12px; border:1px solid var(--line); font-weight:700 }

/* ===================== DARK (opt-in) ===================== */
.alx-agenda[data-theme="dark"]{ --panel:transparent; --line:#2A4459; }
.alx-agenda[data-theme="dark"] .alx-mod,
.alx-agenda[data-theme="dark"] .alx-col{ background:transparent; border-color:#2A4358 }
.alx-agenda[data-theme="dark"] .alx-agenda__title,
.alx-agenda[data-theme="dark"] .alx-mod__title{ color:#fff }

/* ===== Calendário inline: alinhamento e espaçamento ===== */

/* Desktop: mais respiro entre calendário e colunas */
.alx-book__grid{
  grid-template-columns: minmax(280px, 320px) 1fr;
  column-gap: 26px;            /* antes era 20px */
  align-items: flex-start;
}
/* leve acolchoamento do lado do calendário */
.alx-book__cal{ padding-right: 6px; }

/* Centraliza o calendário dentro do seu bloco */
#alx-cal .flatpickr-calendar{
  display:block;
  margin: 0 auto;              /* centraliza horizontalmente */
  border-radius: 12px;
}
/* Garante que o flatpickr inline não vire absoluto por CSS do tema */
#alx-cal .flatpickr-calendar.inline{ position: static !important; }

/* Mobile: uma coluna, calendário centralizado e com gap confortável */
@media (max-width: 860px){
  .alx-book__grid{
    grid-template-columns: 1fr;
    row-gap: 16px;
  }
  .alx-book__cal{
    display:flex;
    justify-content:center;    /* centraliza o calendário */
  }
  #alx-cal .flatpickr-calendar{
    margin-left:auto;
    margin-right:auto;
  }
}

/* =========================================================
   LISTAGEM DE AGENDAMENTOS — DARK THEME (opt-in)
   Ative com: <div class="alx-ag-list" data-theme="dark">…</div>
   (ou adicione a classe .alx-aglist--dark ao wrapper)
   ========================================================= */

.alx-ag-list.alx-aglist--dark,
.alx-ag-list[data-theme="dark"]{
  --line:#2A4459;
  --panel:transparent; /* .alx-card usa var(--panel) */
}

/* Cabeçalhos e destaques em branco */
.alx-ag-list.alx-aglist--dark h3,
.alx-ag-list.alx-aglist--dark strong,
.alx-ag-list.alx-aglist--dark em,
.alx-ag-list[data-theme="dark"] h3,
.alx-ag-list[data-theme="dark"] strong,
.alx-ag-list[data-theme="dark"] em{
  color:#fff !important;
}

/* Cada item: fundo transparente + borda #2A4358 */
.alx-ag-list.alx-aglist--dark .alx-ref-item,
.alx-ag-list[data-theme="dark"] .alx-ref-item{
  background:transparent !important;
  border-color:#2A4358 !important;
}

/* Card externo segue as variáveis (fundo transparente + borda --line) */
.alx-ag-list.alx-aglist--dark .alx-card,
.alx-ag-list[data-theme="dark"] .alx-card{
  background:var(--panel) !important;
  border-color:var(--line) !important;
}

/* Texto secundário mais legível no escuro */
.alx-ag-list.alx-aglist--dark .alx-rec__muted,
.alx-ag-list[data-theme="dark"] .alx-rec__muted,
.alx-ag-list.alx-aglist--dark .alx-ref-meta,
.alx-ag-list[data-theme="dark"] .alx-ref-meta{
  color:rgba(255,255,255,.78);
}

/* Tags com borda suave no dark */
.alx-ag-list.alx-aglist--dark .alx-tag,
.alx-ag-list[data-theme="dark"] .alx-tag{
  border-color:#163044;
}

/* ===== Listing – ações ===== */
.alx-ref-actions { display:flex; gap:.5rem; align-items:center; }
.alx-btn--ok { background:#0ea5e9; color:#fff; }
.alx-btn--ok:hover { filter:brightness(0.95); }
.alx-btn--ghost { background:transparent; border:1px solid var(--line,#163044); color:inherit; }

/* DARK: herdando suas variáveis do bloco já existente */
.alx-rec[data-theme="dark"] .alx-ref-actions .alx-btn--ghost { border-color:#2A4358; }

/* ===== Listing de agendamentos (escopo dark) ===== */
.alx-ag-list[data-theme="dark"]{
  --brand:#219EBC;
  --brand-hover:#023047;
  --line:#2A4459;
  --panel:transparent;
}

/* Botão padrão/primário — força override do tema */
.alx-ag-list .alx-btn,
#alx-modal .alx-btn{
  background:var(--brand, #219EBC) !important;
  color:#fff !important;
  border:none !important;
  border-radius:10px !important;
  padding:10px 14px !important;
  font-weight:600 !important;
  cursor:pointer !important;
  transition:background-color .2s ease, transform .02s ease-in, box-shadow .2s ease !important;
  display:inline-block;
}
.alx-ag-list .alx-btn:hover,
.alx-ag-list .alx-btn:focus,
#alx-modal .alx-btn:hover,
#alx-modal .alx-btn:focus{
  background:var(--brand-hover, #023047) !important;
}
.alx-ag-list .alx-btn:active,
#alx-modal .alx-btn:active{ transform:translateY(1px) }
.alx-ag-list .alx-btn[disabled],
#alx-modal .alx-btn[disabled]{ opacity:.5; cursor:not-allowed }

/* Variantes */
.alx-ag-list .alx-btn--ghost{ 
  background:transparent !important; 
  color:var(--brand, #219EBC) !important; 
  border:1px solid var(--brand, #219EBC) !important;
}
.alx-ag-list .alx-btn--ghost:hover{ 
  color:#fff !important; 
  background:var(--brand, #219EBC) !important; 
}
.alx-ag-list .alx-btn--ok{
  background:#10b981 !important; /* verde */
}
.alx-ag-list .alx-btn--ok:hover{ background:#0a8a60 !important; }

/* ===== Modal de remarcação ===== */

/* Grid: calendário (esq) + 2 colunas (dir) com espaço */
#alx-modal .alx-resched-grid{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:18px;               /* espaço entre cal e colunas */
  align-items:start;
}
#alx-modal .alx-resched-cal{ 
  min-width:260px;
}

/* Input do flatpickr oculto (sem aria-hidden) para evitar warning */
#alx-modal .alx-resched-cal .flatpickr-input{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}

/* Cabeçalho dos dias com contraste */
#alx-modal .alx-resched-day__head{
  display:inline-block;
  background:#122f40;
  color:#fff;
  border:1px solid #2A4358;
  border-radius:10px;
  padding:6px 10px;
  margin-bottom:8px;
}

/* Coluna de slots usa as pílulas já existentes */
#alx-modal .alx-resched-day{ margin-bottom:14px; }
#alx-modal .alx-resched-day__slots .alx-pill{ margin:4px 6px 0 0; }

/* Responsivo: empilha no mobile e mantém o espaço */
@media (max-width: 720px){
  #alx-modal .alx-resched-grid{
    grid-template-columns: 1fr;
    gap:14px;            /* espaço entre cal e colunas no mobile */
  }
}

/* Pequeno ajuste visual do rodapé do modal (botões) */
#alx-modal .alx-modal__footer .alx-btn{ margin-left:8px; }
