/* === COMPONENTS: modal, toast, side panel agenda === */

/* MODAL */
/* -- MODAL -- */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(26,8,22,.52);backdrop-filter:blur(2px);z-index:200;align-items:center;justify-content:center;padding:16px}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border-radius:var(--radius);border:none;width:520px;max-height:88vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
/* Cantos sempre arredondados: nos modais com cabe?alho/corpo, s? o CORPO rola ? a scrollbar
   n?o fica mais no .modal, ent?o n?o "quadra" os cantos. Cabe?alho e rodap? ficam fixos.
   Vale s? p/ modais com .modal-body direto; os demais mant?m o comportamento antigo. */
.modal:has(> .modal-body){overflow:hidden;display:flex;flex-direction:column}
.modal:has(> .modal-body) > .modal-head{flex-shrink:0}
.modal:has(> .modal-body) > .modal-body{overflow-y:auto;flex:1 1 auto;min-height:0}
.modal:has(> .modal-body) > .modal-footer{flex-shrink:0}
.modal-head{padding:15px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.modal-head-title{font-weight:700;font-size:16px;flex:1;color:var(--txt);letter-spacing:.01em}
/* Cabeçalho de modais criados via JS (usam .modal-header). Sem esta regra ficava
   sem padding (texto/X colados na borda). Espelha o .modal-head. */
.modal-header{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}
.modal-header h3{flex:1;margin:0}
.modal-body{padding:20px 22px}
.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-group.full{grid-column:1/-1}
.form-label{font-size:11px;font-weight:500;color:var(--txt2)}
.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border2);border-radius:var(--radius-sm);padding:8px 11px;font-size:12.5px;font-family:inherit;color:var(--txt);background:var(--surface);outline:none;width:100%;transition:border-color .13s,box-shadow .13s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(155,61,143,.13)}
.form-group textarea{resize:vertical;min-height:70px}

/* ------------------------------------------------------------
   ESTILO PADR?O GLOBAL ? inputs, selects e textareas em todo o sistema
   Usa :where() pra ter especificidade ZERO, o que permite que qualquer
   regra mais espec?fica (.search-row input, .login-field input etc.)
   continue funcionando do jeito que j? era. Aplica em campos que N?O
   est?o dentro de .form-group, .switch ou .pill-radio.
   ------------------------------------------------------------ */
:where(input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=color]):not([type=range]):not([type=hidden]):not([type=submit]):not([type=button]):not([type=image])),
:where(select),
:where(textarea){
  border:1px solid var(--border2);
  border-radius:var(--radius-sm);
  padding:8px 11px;
  font-size:12.5px;
  font-family:inherit;
  color:var(--txt);
  background:var(--surface);
  outline:none;
  transition:border-color .13s, box-shadow .13s;
}
:where(input,select,textarea):focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(155,61,143,.13);
}
:where(input,select,textarea):disabled{
  background:var(--bg);
  color:var(--txt3);
  cursor:not-allowed;
}

/* Areas chips grid (multi-select de ?reas em cadastros) */
.areas-chips-grid{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:10px;
  border:1px solid var(--border2);border-radius:var(--radius-sm);
  background:var(--bg);
  min-height:50px;max-height:200px;overflow-y:auto;
}
.areas-chip-group-label{
  width:100%;font-size:10px;font-weight:600;color:var(--txt3);
  text-transform:uppercase;letter-spacing:.05em;
  margin-top:4px;margin-bottom:2px;
}
.areas-chip-group-label:first-child{margin-top:0}
.area-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 11px;border-radius:20px;
  border:1.5px solid var(--border2);background:var(--surface);
  font-size:11.5px;color:var(--txt2);cursor:pointer;
  transition:all .15s;font-weight:500;user-select:none;
}
.area-chip:hover{border-color:var(--primary);color:var(--primary)}
.area-chip.on{
  background:var(--primary-l);
  border-color:var(--primary);
  color:var(--primary);
}
.area-chip.on::before{
  content:"";display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--primary);
}

/* Swatch de cor redondo (etapas do CRM) */
.crm-cor-swatch{width:30px;height:30px;min-width:30px;border-radius:50%;border:none;
  box-shadow:0 0 0 2px #fff, 0 0 0 3px var(--border2);padding:0;cursor:pointer;background:none}
.crm-cor-swatch:hover{box-shadow:0 0 0 2px #fff, 0 0 0 3px var(--primary)}
.crm-cor-swatch::-webkit-color-swatch-wrapper{padding:0}
.crm-cor-swatch::-webkit-color-swatch{border:none;border-radius:50%}
.crm-cor-swatch::-moz-color-swatch{border:none;border-radius:50%}

/* Bot?o "olho" para mostrar/esconder senha (login, minha conta, admin) */
.pwd-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--txt3);cursor:pointer;font-size:16px;padding:4px;line-height:1;display:flex;align-items:center}
.pwd-eye:hover{color:var(--primary)}

/* Seletor de servi?os estilo plano no avulso/finaliza??o (lista + cards) */
.pk-lista{
  border:1px solid var(--border2);border-radius:var(--radius-sm);
  background:var(--surface);max-height:220px;overflow-y:auto;
}
.pk-lista .nv2-serv-item{border-bottom:1px solid var(--border)}
.pk-lista .nv2-serv-item:last-child{border-bottom:none}
.pk-cards{display:flex;flex-direction:column;gap:10px}

/* Valores/sess?es individuais por ?rea (cadastro de servi?o) */
.serv-areas-valores{
  margin-top:10px;border:1px solid var(--border2);border-radius:var(--radius-sm);
  background:var(--bg);padding:10px 12px;
}
.serv-areas-valores-hint{
  font-size:11px;color:var(--txt3);margin-bottom:8px;line-height:1.4;
}
.serv-area-valor-row{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:6px 0;border-bottom:1px dashed var(--border);
}
.serv-area-valor-row:last-child{border-bottom:none}
.serv-area-valor-nome{
  flex:1;min-width:120px;font-size:12.5px;font-weight:500;color:var(--txt);
}
.serv-area-valor-field{
  display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--txt3);
}
.serv-area-valor-field input{
  width:78px;border:1px solid var(--border2);border-radius:5px;
  padding:4px 7px;font-size:12.5px;font-family:inherit;text-align:right;
  color:var(--primary);font-weight:600;background:var(--surface);
}
.serv-area-valor-field input.serv-area-sessoes-input{width:56px;color:var(--txt)}

/* Hint inline abaixo do campo (valida??o inline) */
.field-hint{
  font-size:11px;line-height:1.4;margin-top:4px;
  display:none;  /* s? aparece quando tem classe .error ou .warning */
  align-items:center;gap:6px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.field-hint.error,.field-hint.warning{display:flex}
.field-hint.error{color:#A32D2D}
.field-hint.warning{color:#7A4F08}
.field-hint i{font-size:14px;flex-shrink:0}
.field-hint.error i{color:#E24B4A}
.field-hint.warning i{color:var(--amber)}
.field-hint span{overflow:hidden;text-overflow:ellipsis}
.field-hint b{font-weight:600}

/* Estado de erro/aviso no input */
.form-group input.has-error{border-color:#E24B4A;background:#FDF5F5}
.form-group input.has-error:focus{box-shadow:0 0 0 2px rgba(226,75,74,.15)}
.form-group input.has-warning{border-color:var(--amber);background:#FDF8EE}
.form-group input.has-warning:focus{box-shadow:0 0 0 2px rgba(186,117,23,.15)}


/* CONFIRMA??O (modal-confirm) */
.confirm-icon-wrap{
  display:flex;justify-content:center;
  padding:28px 24px 16px;
}
.confirm-icon{
  width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:#FCEBEB;color:#E24B4A;
  font-size:30px;
  box-shadow:0 0 0 8px #FDF5F5;
}
.confirm-icon.warning{background:var(--amber-l);color:var(--amber);box-shadow:0 0 0 8px #FDF8EE}
.confirm-icon.info{background:var(--blue-l);color:var(--blue);box-shadow:0 0 0 8px #F1F7FD}
.confirm-icon.success{background:var(--teal-l);color:var(--teal);box-shadow:0 0 0 8px #ECF6F1}
.confirm-title{
  font-size:19px;font-weight:700;color:var(--txt);
  margin-bottom:8px;
}
.confirm-message{
  font-size:13px;color:var(--txt2);
  line-height:1.5;
  margin-bottom:6px;
}
.confirm-highlight{
  font-size:13px;font-weight:500;color:var(--primary);
  background:var(--primary-l);
  padding:8px 14px;border-radius:8px;
  margin-top:10px;
  word-break:break-word;
}


/* SIDE PANEL AGENDA */
/* -- SIDE PANEL AGENDA -- */
.agenda-layout{display:flex;gap:16px;align-items:flex-start}
.agenda-main{flex:1;min-width:0}
.agenda-side{width:260px;flex-shrink:0}
.side-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:12px}
.side-card-head{padding:10px 14px;border-bottom:1px solid var(--border);font-size:12px;font-weight:500;color:var(--txt);display:flex;align-items:center;gap:6px}
.side-card-head i{color:var(--primary);font-size:13px}
.side-body{padding:12px 14px}

/* TOAST */
/* -- TOAST -- */
.toast{position:fixed;bottom:20px;right:24px;background:#27500A;color:#eaf3de;padding:9px 16px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;display:none;align-items:center;gap:7px;z-index:400;box-shadow:var(--shadow-md);max-width:90vw}
.toast.on{display:flex}
.toast.toast-success{background:#27500A;color:#eaf3de}
.toast.toast-error{background:#A32D2D;color:#fff;border-left:4px solid #FCEBEB}
.toast.toast-warning{background:#BA7517;color:#fff;border-left:4px solid #FAEEDA}


/* Z-index escalonado: modais que abrem sobre outros modais ficam por cima */
#modal-ag-detalhe.modal-overlay{z-index:210}
#modal-detalhe-venda.modal-overlay{z-index:210}
#modal-fim-pagto.modal-overlay{z-index:220}
#modal-ag-avulso.modal-overlay{z-index:230}
#modal-receber-parcela.modal-overlay{z-index:240}
#modal-assinatura.modal-overlay{z-index:250}
#modal-escolher-contrato.modal-overlay{z-index:250}
#modal-link-assinatura.modal-overlay{z-index:250}
/* Cadastro de cliente fica acima da venda (editar cadastro sem sair da venda) */
#modal-cliente.modal-overlay{z-index:260}
#modal-confirm.modal-overlay{z-index:9999}

/* -- Quadro de assinatura do contrato -- */
.ass-pad-wrap{position:relative;border:2px dashed var(--border2);border-radius:8px;background:#fff;overflow:hidden}
.ass-canvas{display:block;width:100%;height:200px;touch-action:none;cursor:crosshair}
.ass-pad-hint{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--txt3);font-size:12px;pointer-events:none}

.ass-consent{display:flex;align-items:flex-start;gap:8px;margin-top:12px;cursor:pointer;
  font-size:11px;color:var(--txt2);line-height:1.5}
.ass-consent input{accent-color:var(--primary);width:16px;height:16px;flex-shrink:0;margin-top:1px}

.ass-foto-box{margin-top:12px;border:1px solid var(--border);border-radius:8px;padding:10px 12px;background:var(--bg)}
.ass-foto-tit{font-size:11.5px;font-weight:600;color:var(--primary-d);margin-bottom:8px}
#ass-video{width:100%;max-height:240px;border-radius:8px;background:#000;display:block}
#ass-foto-img{max-width:150px;border-radius:8px;display:block;border:1px solid var(--border2)}
