/* ============================================================
   POWERFULL — adições: filtro de calendário (Power BI) + popup
   de credenciais. Usa só tokens já definidos em theme.css.
   ============================================================ */

/* ----------------------------------------------------------
   FILTRO DE CALENDÁRIO (estilo Power BI)
   ---------------------------------------------------------- */
.cal-filter{ position:relative; }
.cal-trigger{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--bg-2); border:1px solid var(--border-2); border-radius:var(--r);
  color:var(--text); font-family:'Barlow Condensed',sans-serif;
  text-transform:uppercase; letter-spacing:0.05em; font-size:13px; font-weight:600;
  padding:9px 12px; cursor:pointer; transition:border-color .13s, box-shadow .13s, background .12s;
  white-space:nowrap;
}
.cal-trigger:hover{ border-color:#3a455c; }
.cal-trigger.active{ border-color:var(--petrol-line); background:var(--petrol-tint); color:#dbeefc; }
.cal-trigger svg{ width:15px; height:15px; }
.cal-trigger .cal-cap{ display:inline-flex; align-items:center; gap:6px; }
.cal-trigger .cal-val{ font-family:'Share Tech Mono',monospace; text-transform:none; letter-spacing:0; font-size:12px; }
.cal-trigger .cal-chev{ width:14px; height:14px; color:var(--text-3); transition:transform .15s; }
.cal-filter.open .cal-trigger .cal-chev{ transform:rotate(180deg); }

.cal-panel{
  position:absolute; top:calc(100% + 7px); left:0; right:auto; z-index:80;
  width:312px; max-width:calc(100vw - 24px); box-sizing:border-box;
  background:var(--card); border:1px solid var(--border-2);
  border-radius:var(--r-lg); box-shadow:var(--shadow-lg);
  padding:14px; display:none;
}
.cal-filter.flip .cal-panel{ left:auto; right:0; }
.cal-filter.open .cal-panel{ display:block; }
.cal-panel-head{
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.08em;
  font-size:12px; color:var(--text-2); margin:0 0 10px; display:flex; align-items:center; gap:7px;
}
.cal-panel-head svg{ width:15px; height:15px; color:var(--petrol-300); }

/* modos: Ano / Mês / Dia / Período */
.cal-modes{ display:grid; grid-template-columns:repeat(4,1fr); gap:3px;
  background:var(--bg-2); border:1px solid var(--border-2); border-radius:var(--r); padding:3px; margin-bottom:12px; }
.cal-mode{
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.04em;
  font-size:12px; font-weight:600; color:var(--text-3);
  background:transparent; border:none; padding:6px 4px; border-radius:var(--r-sm);
  cursor:pointer; transition:all .12s;
}
.cal-mode:hover{ color:var(--text); }
.cal-mode.active{ background:var(--petrol-400); color:#fff; box-shadow:0 1px 6px rgba(46,144,217,0.25); }

.cal-fields{ display:flex; flex-direction:column; gap:9px; }
.cal-presets{ display:flex; flex-wrap:wrap; gap:6px; margin-top:11px; }
.cal-chip{
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.04em;
  font-size:11.5px; font-weight:600; color:var(--text-2);
  background:var(--bg-2); border:1px solid var(--border-2); border-radius:var(--r);
  padding:5px 10px; cursor:pointer; transition:all .12s;
}
.cal-chip:hover{ border-color:var(--petrol-line); color:var(--text); }
.cal-chip.on{ background:var(--petrol-tint); border-color:var(--petrol-line); color:#dbeefc; }
.cal-frow{ display:flex; gap:8px; }
.cal-frow > *{ flex:1 1 0; min-width:0; }
.cal-frow .select,
.cal-frow .input{ width:100%; min-width:0; box-sizing:border-box; }
.cal-flabel{ font-size:11px; color:var(--text-3); font-family:'Barlow Condensed',sans-serif;
  text-transform:uppercase; letter-spacing:0.06em; margin-bottom:3px; display:block; }
.cal-panel .input, .cal-panel .select{ font-size:13px; padding:8px 11px; width:100%; box-sizing:border-box; }
.cal-panel input[type="date"]{ color-scheme:dark; }
:root[data-theme="light"] .cal-panel input[type="date"]{ color-scheme:light; }

/* período: confirmação DE/ATÉ */
.cal-apply-row{ display:flex; flex-direction:column; gap:8px; margin-top:11px; }
.cal-apply-hint{ font-size:11px; color:var(--text-3); font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.05em; }
.cal-apply{
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  height:36px; border-radius:var(--r); cursor:pointer;
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.05em;
  font-size:13px; font-weight:600;
  background:var(--card-2); color:var(--text-3); border:1px solid var(--border-2);
  transition:all .13s;
}
.cal-apply svg{ width:14px; height:14px; }
.cal-apply:disabled{ opacity:.5; cursor:not-allowed; }
.cal-apply.ready{ background:var(--action); color:#fff; border-color:var(--action); box-shadow:0 2px 10px rgba(42,147,171,0.28); }
.cal-apply.ready:hover{ background:var(--action-h); border-color:var(--action-h); }

.cal-foot{ display:flex; align-items:center; gap:8px; margin-top:13px;
  padding-top:12px; border-top:1px solid var(--border); }
.cal-now{
  display:inline-flex; align-items:center; gap:6px;
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.05em;
  font-size:12px; font-weight:600; color:var(--petrol-300);
  background:var(--petrol-tint); border:1px solid var(--petrol-line); border-radius:var(--r);
  padding:7px 11px; cursor:pointer; transition:all .12s;
}
.cal-now:hover{ background:rgba(58,150,190,0.24); }
.cal-now svg{ width:14px; height:14px; }
.cal-clear{
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.05em;
  font-size:12px; font-weight:600; color:var(--text-3);
  background:transparent; border:1px solid transparent; border-radius:var(--r);
  padding:7px 10px; cursor:pointer; margin-left:auto;
}
.cal-clear:hover{ color:var(--text); background:var(--card-2); }

/* ----------------------------------------------------------
   POPUP DE CREDENCIAIS
   ---------------------------------------------------------- */
.cred-intro{
  display:flex; gap:11px; align-items:flex-start;
  background:var(--green-tint); border:1px solid rgba(19,184,132,0.32); border-radius:var(--r);
  padding:11px 13px; margin-bottom:16px; color:var(--text-2); font-size:13px; line-height:1.5;
}
.cred-intro svg{ width:18px; height:18px; color:var(--green-2); flex-shrink:0; margin-top:1px; }
.cred-intro b{ color:var(--text); }

.cred-list{ display:flex; flex-direction:column; gap:9px; margin-bottom:18px; }
.cred-item{
  display:flex; align-items:center; gap:12px;
  background:var(--bg-2); border:1px solid var(--border-2); border-radius:var(--r); padding:11px 13px;
}
.cred-item .ci-key{
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.07em;
  font-size:11px; color:var(--text-3); width:64px; flex-shrink:0;
}
.cred-item .ci-val{ flex:1; font-size:14px; color:var(--text); word-break:break-all; }
.cred-item .ci-val.mono{ font-family:'Share Tech Mono',monospace; letter-spacing:0.02em; }
.cred-item.pass .ci-val{ color:var(--amber); font-size:16px; }
.cred-copy{
  display:inline-flex; align-items:center; justify-content:center; gap:5px;
  width:32px; height:32px; flex-shrink:0;
  background:var(--card-2); border:1px solid var(--border-2); border-radius:var(--r);
  color:var(--text-3); cursor:pointer; transition:all .12s;
}
.cred-copy:hover{ color:var(--text); border-color:#3a455c; background:var(--card-3); }
.cred-copy svg{ width:15px; height:15px; }
.cred-copy.ok{ color:var(--green-2); border-color:var(--green); }

.btn-wa{
  background:#25D366; color:#072b16; border-color:#25D366;
  box-shadow:0 2px 12px rgba(37,211,102,0.28); font-weight:700;
}
.btn-wa:hover{ background:#1fbb59; border-color:#1fbb59; }
.btn-wa svg{ width:17px; height:17px; }
.cred-msg-preview{
  font-family:'Share Tech Mono',monospace; font-size:11.5px; line-height:1.55;
  color:var(--text-3); background:var(--bg-2); border:1px dashed var(--border-2);
  border-radius:var(--r); padding:10px 12px; margin-top:14px;
}
.cred-msg-preview .cmp-lbl{
  display:block; font-family:'Barlow Condensed',sans-serif; text-transform:uppercase;
  letter-spacing:0.08em; font-size:10px; color:var(--text-3); margin-bottom:5px;
}

/* ----------------------------------------------------------
   FEEDBACK / COMENTÁRIOS no detalhe do serviço/mapa
   ---------------------------------------------------------- */
.fb-block{ margin-top:18px; border-top:1px solid var(--border); padding-top:16px; }
.fb-head{
  display:flex; align-items:center; gap:8px; margin-bottom:12px;
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.06em;
  font-size:13px; color:var(--text-2);
}
.fb-head svg{ width:16px; height:16px; color:var(--petrol-300); }
.fb-head .fb-count{
  margin-left:auto; font-family:'Share Tech Mono',monospace; font-size:11px;
  color:var(--text-3); background:var(--bg-2); border:1px solid var(--border-2);
  border-radius:999px; padding:1px 9px;
}
.fb-thread{ display:flex; flex-direction:column; gap:10px; margin-bottom:14px; }
.fb-empty{
  font-size:12.5px; color:var(--text-3); background:var(--bg-2);
  border:1px dashed var(--border-2); border-radius:var(--r); padding:13px 14px; text-align:center;
}
.fb-item{ display:flex; gap:11px; }
.fb-avatar{
  width:32px; height:32px; flex-shrink:0; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:13px; letter-spacing:0.03em;
  background:var(--petrol-tint); color:var(--petrol-300); border:1px solid var(--petrol-line);
}
.fb-avatar.adm{ background:var(--silver-tint); color:var(--silver); border-color:var(--silver-line); }
.fb-bubble{ flex:1; background:var(--bg-2); border:1px solid var(--border-2); border-radius:var(--r); padding:9px 12px; }
.fb-meta{ display:flex; align-items:baseline; gap:8px; margin-bottom:3px; }
.fb-meta b{ font-size:13px; color:var(--text); }
.fb-meta .fb-role{
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.05em;
  font-size:9.5px; color:var(--text-3); background:var(--card-2); border:1px solid var(--border-2);
  border-radius:3px; padding:0 5px;
}
.fb-meta time{ margin-left:auto; font-family:'Share Tech Mono',monospace; font-size:10.5px; color:var(--text-3); }
.fb-text{ font-size:13px; color:var(--text-2); line-height:1.5; white-space:pre-wrap; word-break:break-word; }
.fb-rating{ display:inline-flex; gap:1px; margin-bottom:4px; }
.fb-rating svg{ width:13px; height:13px; color:var(--amber); fill:var(--amber); }
.fb-compose{ display:flex; flex-direction:column; gap:9px; }
.fb-stars{ display:flex; align-items:center; gap:4px; }
.fb-stars .fbs-lbl{ font-size:11px; color:var(--text-3); margin-right:4px;
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.05em; }
.fb-star{ background:none; border:none; cursor:pointer; padding:2px; line-height:0; }
.fb-star svg{ width:18px; height:18px; color:var(--text-3); transition:color .1s, fill .1s; }
.fb-star.on svg, .fb-star:hover svg{ color:var(--amber); fill:var(--amber); }
.fb-compose textarea{ resize:vertical; min-height:64px; font-family:'Barlow',sans-serif; }
.fb-compose .fb-actions{ display:flex; align-items:center; gap:10px; }
.fb-compose .fb-note{ font-size:11px; color:var(--text-3); margin-left:auto; }

/* ============================================================
   TASK A–E (ajustes de UX) — usa só tokens já definidos
   ============================================================ */

/* A) Empilhamento: diálogo de confirmação e popup de credenciais SEMPRE
   acima dos modais de formulário; toasts acima de tudo. */
#modalConfirm{ z-index:130; }
#modalCred{ z-index:128; }
.toast-stack{ z-index:150; }

/* C) Catálogo de referência ao lado dos mapas (Novo serviço) */
.novo-maps-row{ display:grid; grid-template-columns:1fr 248px; gap:16px; align-items:start; }
.cat-ref{
  background:var(--bg-2); border:1px solid var(--border-2); border-radius:var(--r);
  overflow:hidden; align-self:stretch;
}
.cat-ref-h{
  display:flex; align-items:center; gap:7px; padding:9px 12px;
  background:linear-gradient(180deg,#0c0e11,var(--bg-2)); border-bottom:1px solid var(--border-2);
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.07em;
  font-size:11.5px; font-weight:600; color:var(--text-2);
}
.cat-ref-h svg{ width:14px; height:14px; color:var(--petrol-300); }
.cat-ref-list{ max-height:236px; overflow-y:auto; }
.cat-ref-row{
  display:grid; grid-template-columns:auto 1fr auto; gap:8px; align-items:center;
  padding:6px 12px; border-bottom:1px solid var(--border); font-size:12px;
}
.cat-ref-row:last-child{ border-bottom:none; }
.cat-ref-row .crr-cod{ font-size:10.5px; color:var(--petrol-300); }
.cat-ref-row .crr-tipo{ color:var(--text-2); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cat-ref-row .crr-preco{ font-size:11.5px; color:var(--text); }
.cat-ref-foot{ padding:7px 12px; font-size:10.5px; color:var(--text-3); border-top:1px solid var(--border-2); background:var(--bg); }
@media (max-width:680px){ .novo-maps-row{ grid-template-columns:1fr; } .cat-ref-list{ max-height:170px; } }

/* D) Resumo do período na visão Oficina (Meus serviços) */
.serv-summary{
  display:flex; flex-wrap:wrap; gap:10px; margin-bottom:14px;
}
.serv-summary .ss-item{
  flex:1; min-width:130px;
  background:linear-gradient(180deg,var(--card),var(--card-deep));
  border:1px solid var(--border); border-radius:var(--r); padding:12px 14px;
  display:flex; flex-direction:column; gap:5px; position:relative; overflow:hidden;
}
.serv-summary .ss-item::before{
  content:""; position:absolute; top:0; left:0; width:100%; height:2px;
  background:var(--petrol-400); box-shadow:0 0 12px var(--petrol-400); opacity:.7;
}
.serv-summary .ss-item.pos::before{ background:var(--green-2); box-shadow:0 0 12px var(--green-2); }
.serv-summary .ss-lbl{
  font-family:'Barlow Condensed',sans-serif; text-transform:uppercase; letter-spacing:0.1em;
  font-size:10.5px; font-weight:600; color:var(--text-3);
}
.serv-summary .ss-val{ font-size:19px; color:var(--text); line-height:1; }
.serv-summary .ss-item.pos .ss-val{ color:var(--green-2); }

/* E) Data dos serviços no detalhamento de Relatórios */
.rep-sub-date{ font-size:11px; color:var(--text-3); margin-left:6px; }

/* [GEO-REMOVIDO] tabela de Oficinas sem a coluna "Local / Região" → 5 colunas
   (era: auto 1.6fr 1.2fr 1fr 90px 130px). Restaurar: ver REGIAO-REMOVIDO.md */
.of-row{ grid-template-columns:auto 1.6fr 1.2fr 90px 130px; }
