/* modal_form.css - estilos modernos e profissionais para modal e formulário */
:root{
  --bg:#f4f6f8;
  --card:#ffffff;
  --primary-500:#2f3ba0;
  --primary-700:#1a237e;
  --accent:#2aa6a3;
  --muted:#6b7a90;
  --surface-border: #e6ecf3;
  --glass: rgba(255,255,255,0.6);
  /* Altura padrão reduzida para o conjunto Serviços + Coluna Direita */
  --prest-grid-height: 500px; /* altura ampliada conforme pedido */
}

/* Reset/typo */
html,body{height:100%;}
body{background:var(--bg); font-family: 'Roboto', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial; color:#152b6e;}

.wrap{max-width:1100px;margin:32px auto;padding:26px;background:var(--card);border-radius:14px;box-shadow:0 8px 36px rgba(15,23,42,0.06);border:1px solid rgba(23,37,84,0.03)}

/* Header */
.header{display:flex;align-items:center;gap:16px}
.assist-logo{width:72px;height:72px;border-radius:12px;background:linear-gradient(135deg,#eef5fb,#ffffff);display:flex;align-items:center;justify-content:center;border:1px solid var(--surface-border);overflow:hidden}
.assist-logo img{width:100%;height:100%;object-fit:cover;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}
.assist-logo-initial{font-weight:800;color:var(--primary-500);font-size:1.2rem}
.title{font-size:1.45rem;font-weight:800;color:var(--primary-700);margin:0}
.meta{display:flex;gap:10px;align-items:center}
.pill{background:#f7fbfb;border-radius:999px;padding:6px 12px;color:var(--muted);border:1px solid var(--surface-border)}

/* Toolbar */
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.icon-btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--surface-border);background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .14s ease}
.icon-btn:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(31,50,86,0.06)}
.icon{width:18px;height:18px;color:var(--primary-700)}

/* Cards / grid */
.data-grid{display:grid;grid-template-columns:220px 1fr;gap:14px 20px;background:linear-gradient(180deg,#fbfdff,#ffffff);padding:18px;border-radius:12px;border:1px solid var(--surface-border)}
.data-grid .key{color:var(--primary-700);font-weight:700}
.data-grid .val{color:#10193f;display:flex;align-items:center;gap:10px}
.copy-btn{width:30px;height:30px;border-radius:8px;border:1px solid var(--surface-border);background:#fff;color:var(--primary-700);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.copy-btn:hover{background:linear-gradient(180deg,#f5f8ff,#ffffff)}
.copy-btn.copied{background:#e7f6ee;color:#0b6b3b;border-color:#c8f0d6}

/* Modal modern */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:28px;z-index:1200}
.modal.open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,15,52,0.42),rgba(8,15,52,0.62))}
/* Reduzida largura total do modal para deixar formulário mais compacto */
.modal-dialog{position:relative;z-index:2;width:min(94vw,520px);background:linear-gradient(180deg,var(--card),#fbfdff);border-radius:12px;padding:12px 12px 12px 12px;box-shadow:0 12px 34px rgba(20,30,70,0.12);border:1px solid rgba(32,45,90,0.04);max-height:92vh;overflow:auto}
.modal-dialog .section-title{margin-top:0;margin-bottom:10px;font-size:1.15rem}
/* Modal header styles */
.modal-header{display:flex;gap:14px;align-items:center;margin-bottom:10px}
.modal-icon{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1.1rem;box-shadow:0 6px 18px rgba(31,50,86,0.08)}
.modal-icon img{width:100%;height:100%;object-fit:contain;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}
.modal-titles{display:flex;flex-direction:column}
.modal-title{font-size:1.18rem;font-weight:800;color:var(--primary-700);margin:0}
.modal-subtitle{font-size:0.95rem;color:var(--muted);margin:4px 0 0}
.modal-divider{height:1px;background:linear-gradient(90deg,rgba(26,35,126,0.06),rgba(26,35,126,0.02));border:none;margin:12px 0;border-radius:2px}

/* Icon add button - round and subtle */
.icon-add{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--surface-border);background:linear-gradient(180deg,#fff,#fbfdff);color:var(--primary-700);font-weight:600;cursor:pointer}
.icon-add:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(31,50,86,0.06)}

/* Close button */
#modalCloseBtn{position:absolute;right:14px;top:12px;border:0;background:#fff;width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(31,50,86,0.08);cursor:pointer;color:var(--primary-700);font-size:1.1rem}
#modalCloseBtn:hover{transform:translateY(-2px)}

/* Shared close button style for all modals */
.modal-close{position:absolute;right:14px;top:12px;border:0;background:linear-gradient(180deg,#fff,#f7fbff);width:38px;height:38px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(31,50,86,0.08);cursor:pointer;color:var(--primary-700);font-size:1.15rem;z-index:9999;transition:transform .12s, background .12s, box-shadow .12s;}
.modal-close:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(31,50,86,0.12)}
.modal-close:active{transform:translateY(0)}


/* Form compact (atualiza visual) */
/* Ajuste: largura máxima menor para formulário mais estreito */
.form-compact{background:linear-gradient(180deg,#fff,#fbfdff);border-radius:10px;padding:4px 6px 6px 6px;display:flex;flex-direction:column;gap:6px;border:1px solid var(--surface-border);max-width:100%;}
.form-compact label{font-weight:600;color:var(--primary-700);font-size:.94rem}
.form-compact input[type="text"],.form-compact input[type="email"],.form-compact input[type="file"],.form-compact textarea{width:100%;padding:8px 10px;border-radius:8px;border:1px solid #e6edf6;background:#fff;font-size:0.98rem;box-sizing:border-box;transition:all .12s ease}
.form-compact select{width:100%;padding:8px 10px;border-radius:8px;border:1px solid #e6edf6;background:#fff;font-size:0.98rem;box-sizing:border-box;transition:all .12s ease}
.form-compact input:focus,.form-compact textarea:focus{outline:none;box-shadow:0 6px 20px rgba(46,75,190,0.06);border-color:var(--primary-500)}
.form-compact select:focus{outline:none;box-shadow:0 6px 20px rgba(46,75,190,0.06);border-color:var(--primary-500)}
.form-row{display:flex;gap:12px;align-items:flex-start}
.form-row .input-group{flex:1}
/* Removido limite para ocupar toda largura disponível */
.form-col .input-group{max-width:none;width:100%}
/* Espaçamento vertical uniforme entre grupos */
.form-compact .input-group{margin-bottom:8px}
.form-compact .input-group:last-child{margin-bottom:0}
/* Dentro do bloco com upload movido, permitir que os input-groups ocupem toda a largura
  disponível para que encostem na área de upload (remover limite de 380px aqui). */
.fields-upload-row .fields-col .input-group{max-width:none}
.fields-upload-row .fields-col .input-group input{width:100%}
.form-row.fields-upload-row{display:flex;flex-direction:row;align-items:flex-start;gap:12px}
.fields-upload-row .fields-col{flex:1}
/* Alinhamento: garantir que a área que contém as 3 fields + a coluna de upload
   tenha a mesma largura do input superior (max-width 380px) mais a largura
   da coluna de upload (200px) e padding esquerdo (12px). Assim a borda direita
   do upload fica alinhada com a borda direita do campo "Assistência Responsável". */
.form-row.fields-upload-row{width:100%;max-width:none}
@media (max-width:760px){
  .form-row.fields-upload-row{width:100%;}
}
.moved-upload{align-self:stretch}
/* Restaurar largura fixa da coluna de upload da logo */
.aside-logo{flex:0 0 160px;min-width:160px}
/* Removido padding lateral para encostar a área de upload na borda */
.aside-logo{align-self:flex-start;padding-left:0;display:flex;align-items:flex-start;justify-content:center;margin-left:0;padding-top:6px}
/* Ajuste específico para a área de upload movida: largura reduzida e leve subida visual */
.fields-upload-row{position:relative}
/* Posicionamento absoluto para encaixe perfeito no espaço indicado */
.aside-logo.moved-upload{position:static;width:160px;margin-top:0;z-index:6}
.fields-upload-row .fields-col{margin-right:0;flex:1}

/* Make the drag area fill the aside logo vertically so it matches fields height */
.aside-logo .drag-area{height:176px;min-height:176px;width:100%;padding:6px;box-sizing:border-box;position:relative;display:flex;align-items:center;justify-content:center}
.aside-logo .drag-area .preview{position:absolute;inset:6px;width:calc(100% - 12px);height:calc(100% - 12px);object-fit:contain;border-radius:8px;display:none;margin:0}
.aside-logo .drag-area .placeholder{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}
/* Responsivo: voltar ao fluxo normal em telas pequenas */
@media (max-width:760px){
  .aside-logo.moved-upload{position:static;width:auto;margin-top:-6px}
  .fields-upload-row .fields-col{margin-right:0}
}
.emails-wrap, .contatos-wrap{display:flex;flex-direction:column;gap:8px;margin-top:6px}

/* Drag area */
.drag-area{border-radius:10px;border:1.25px dashed #d9eaf8;background:linear-gradient(180deg,#fbfdff,#f7fbff);padding:10px;display:flex;align-items:center;justify-content:center;min-height:110px;position:relative;overflow:hidden;width:100%}
.drag-area .placeholder{color:var(--muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:6px}
.drag-area .placeholder svg{width:64px;height:48px;color:var(--primary-500);opacity:0.98;display:block}
.drag-area{box-sizing:border-box}
.moved-upload .drag-area{height:176px;min-height:176px}
.drag-area.has-preview{background:transparent}
.drag-area.has-preview .placeholder{display:none}
.drag-area.has-preview .preview{display:block}
.drag-area .placeholder svg .illu-strokes { stroke: currentColor; }
.drag-area .placeholder svg .mountain { stroke-width:1.6; fill:none }
.drag-area .placeholder svg .badge { pointer-events:none }
.drag-area .preview{position:absolute;inset:6px;width:calc(100% - 12px);height:calc(100% - 12px);object-fit:contain;border-radius:8px;display:none}
/* Removido override de altura fixa; manter comportamento original baseado na coluna */

/* Make file input invisible but clickable over the whole drag area so the native button doesn't appear */
.drag-area input[type="file"]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;border:0;padding:0;margin:0}
.drag-area input[type="file"]::-webkit-file-upload-button{visibility:hidden}
.drag-area input[type="file"]::file-selector-button{visibility:hidden}

/* Email / contato rows */
.email-row,.contato-row{display:flex;gap:6px;align-items:center}
.email-row input,.contato-row input{flex:1;padding:8px 12px;border-radius:8px;border:1px solid #e6edf6;position:relative}
/* Garantir mesma fonte e cor do restante do formulário para campos de contato e emails extras */
.email-row input.with-type,
.contato-row input.with-type,
.contato-row .tel-input {
  font-family: 'Roboto', system-ui, -apple-system, 'Segoe UI', Arial, sans-serif;
  font-size: 0.98rem;
  color: #000; /* cor preta solicitada para conteúdo dos contatos e emails extras */
}
.contato-row .tel-input::placeholder,
.contato-row input.with-type::placeholder { color: var(--muted); }
/* Seletor embutido dentro do campo */
.type-embed{position:relative;flex:1;display:flex;align-items:center}
.type-embed select.type-select{position:absolute;left:8px;top:50%;transform:translateY(-50%);border:0;background:#f1f4f9;color:#1a237e;font-size:.70rem;font-weight:600;padding:4px 8px;border-radius:6px;cursor:pointer;appearance:none;line-height:1;letter-spacing:.5px;box-shadow:0 0 0 1px #d9e1ec inset;z-index:3;pointer-events:auto;width:110px;min-width:110px;text-align:left}
.type-embed select.type-select:focus{outline:none;box-shadow:0 0 0 2px rgba(57,73,171,.25)}
.type-embed input.with-type{padding-left:124px}
/* Ampliação de largura e distribuição das linhas email/contato para não ficar apertado */
.email-row .type-embed, .contato-row .type-embed{flex:1 1 65%;}
.email-row input.with-type, .contato-row input.with-type{width:100%;}
.contato-row .tel-input{flex:1 1 35%;}
@media (max-width:640px){
  .email-row .type-embed, .contato-row .type-embed{flex:1 1 100%;}
  .contato-row .tel-input{flex:1 1 100%;}
}
/* Pequeno ícone caret custom usando pseudo-elemento */
.type-embed select.type-select::-ms-expand{display:none}
.type-embed select.type-select::after{content:''}
/* Ajuste em mobile: ocupa linha própria se pouco espaço */
@media (max-width:640px){
  .type-embed{flex-direction:column;align-items:stretch}
  .type-embed select.type-select{position:static;transform:none;margin-bottom:4px;width:auto}
  .type-embed input.with-type{padding-left:12px}
}
.btn-remover-email,.btn-remover-contato{background:#fff;border:1px solid #f0f3f7;padding:5px 8px;border-radius:8px;cursor:pointer;min-width:36px}
.btn-remover-email:hover,.btn-remover-contato:hover{background:#fff7f7;border-color:#ffd6d6}

.group-header.inline-actions{display:flex;align-items:center;gap:8px;margin-bottom:4px;margin-top:6px}
.group-header.inline-actions .title{font-weight:700;color:var(--primary-700)}

/* helper for inline fields (label + input + button) */
.field-inline{display:flex;align-items:center;gap:8px}
.field-inline input{flex:1}

/* Buttons */
.form-actions{display:flex;justify-content:flex-start;gap:10px;margin-top:6px}
.btn{padding:10px 16px;border-radius:10px;border:1px solid var(--surface-border);background:#fff;cursor:pointer;font-weight:700}
.btn.secondary{background:#fff;border-color:#e9eef8;color:var(--primary-700)}
.btn.primary{background:linear-gradient(90deg,var(--primary-500),var(--primary-700));color:#fff;border:0}
.btn.ghost{background:transparent;border:1px dashed rgba(20,30,70,0.06)}

/* Cadastro compacto de assistencia */
#modalCadastro{align-items:flex-start;overflow:hidden;padding:calc(var(--header-offset, 84px) + 10px) 16px 16px;z-index:4100!important}
#modalCadastro .modal-backdrop{background:rgba(15,23,42,.58);z-index:4101!important}
#modalCadastro .modal-dialog{width:min(94vw,640px);height:min(620px, calc(100vh - var(--header-offset, 84px) - 26px));max-height:calc(100vh - var(--header-offset, 84px) - 26px);min-height:360px;display:flex;flex-direction:column;overflow:hidden;background:#fff;border:1px solid #cbd5e1;box-shadow:0 18px 46px rgba(15,23,42,.24);z-index:4102!important}
#modalCadastro .modal-title{color:#111827}
#modalCadastro .modal-subtitle{color:#475569}
#modalCadastro .modal-header{flex:0 0 auto;padding-right:44px}
#modalCadastro .modal-divider{margin:0 0 10px 0;flex:0 0 auto}
#modalCadastro .modal-body{flex:1 1 auto;min-height:0;overflow-y:scroll;overflow-x:hidden;padding-right:8px;padding-bottom:14px;scrollbar-width:thin;scrollbar-color:#8ea0b8 transparent}
#modalCadastro .modal-body::-webkit-scrollbar{width:9px}
#modalCadastro .modal-body::-webkit-scrollbar-track{background:transparent;border-radius:999px}
#modalCadastro .modal-body::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#aab8ca,#7f91aa);border-radius:999px;border:2px solid #fff}
#modalCadastro .modal-body::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#93a4bb,#667992)}
.assist-simple-form{padding:10px 12px 12px;gap:10px;background:#f8fafc;border-color:#cbd5e1}
.assist-simple-form label{color:#1e2a78;font-weight:800}
.assist-simple-form input[type="text"],
.assist-simple-form input[type="email"],
.assist-simple-form textarea{border-color:#cbd5e1;background:#fff;color:#0f172a}
.assist-simple-form input[type="text"]:focus,
.assist-simple-form input[type="email"]:focus,
.assist-simple-form textarea:focus{border-color:#3949ab;box-shadow:0 0 0 3px rgba(57,73,171,.12)}
.assist-simple-form input::placeholder{color:#64748b}
.assist-simple-form textarea::placeholder{color:#64748b}
.assist-simple-form textarea{resize:vertical;min-height:74px}
.assist-simple-layout{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:14px;align-items:start}
.assist-simple-fields{display:flex;flex-direction:column;gap:8px;min-width:0}
.assist-simple-form .input-group{margin-bottom:0}
.assist-simple-doc-row{display:grid;grid-template-columns:minmax(0,1fr) 170px;gap:8px;align-items:start}
.assist-simple-label-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}
.assist-mini-add{width:30px;height:30px;min-width:30px;border-radius:8px;font-size:17px;line-height:1;border-color:#cbd5e1;background:#fff;color:#1e2a78}
.assist-simple-repeat{gap:6px;margin-top:6px}
.assist-simple-form .email-row,
.assist-simple-form .contato-row{gap:6px;align-items:center}
.assist-simple-form .email-row .type-embed select.type-select,
.assist-simple-form .contato-row .type-embed select.type-select{display:none}
.assist-simple-form .email-row .type-embed input.with-type,
.assist-simple-form .contato-row .type-embed input.with-type{padding-left:10px}
.assist-simple-form .email-row .type-embed,
.assist-simple-form .contato-row .type-embed{flex:1 1 auto}
.assist-contact-row{display:grid;grid-template-columns:minmax(0,1fr) 150px 36px}
.assist-contact-row input{min-width:0}
.assist-simple-nf-block{display:flex;flex-direction:column;gap:8px}
.assist-simple-toggle{display:flex;align-items:center;gap:10px;cursor:pointer}
.assist-simple-toggle input[type="checkbox"]{width:16px;height:16px;accent-color:#2f3ba0;flex:0 0 auto}
.assist-simple-toggle span{color:#1e2a78;font-weight:700}
.assist-simple-nf-select-wrap{display:flex;flex-direction:column;gap:6px}
.assist-simple-select{width:100%;padding:8px 10px;border-radius:8px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;font-size:.95rem;box-sizing:border-box}
.assist-simple-select:focus{outline:none;border-color:#3949ab;box-shadow:0 0 0 3px rgba(57,73,171,.12)}
.assist-simple-side{display:flex;flex-direction:column;gap:10px;min-width:0}
.assist-simple-logo{display:flex;flex-direction:column;gap:6px}
.assist-simple-markers{display:flex;flex-direction:column;gap:8px}
.assist-simple-side-group{display:flex;flex-direction:column;gap:10px;padding:10px;border:1px solid #d8e1ef;border-radius:12px;background:#fff;box-shadow:0 8px 22px rgba(15,23,42,.06)}
.assist-simple-side-group .input-group + .input-group{padding-top:10px;border-top:1px solid #edf2f8}
.assist-logo-drop{height:174px;min-height:174px;border-radius:10px;border-color:#bfdbfe;background:#f8fbff}
.assist-logo-drop .placeholder{font-size:.9rem;line-height:1.25;color:#475569}
.assist-logo-drop .placeholder svg{width:62px;height:48px}
.assist-simple-actions{justify-content:flex-end;margin-top:2px}
@media (max-width:700px){
  #modalCadastro .modal-dialog{width:96vw}
  .assist-simple-layout{grid-template-columns:1fr}
  .assist-simple-doc-row{grid-template-columns:1fr}
  .assist-contact-row{grid-template-columns:1fr}
  .assist-contact-row .contato-action-btn,
  .assist-simple-form .btn-remover-contato{width:100%}
}

/* Responsivo */
@media (max-width:640px){
  .data-grid{grid-template-columns:1fr;}
  .modal-dialog{width:96vw;padding:16px}
}

/* Pequenas animações */
.modal-dialog{transform:translateY(8px);transition:transform .18s cubic-bezier(.22,.9,.3,1),opacity .18s}
.modal.open .modal-dialog{transform:none}

/* Forçar normalização de peso dos ícones + sinais + */
.icon-add, .contato-action-btn, .btn-remover-contato, .btn-remover-email{font-weight:400}

/* Ajustes finais: usar ::placeholder para não alterar cor do texto digitado */
.form-compact input::placeholder{color:var(--muted)}

/* Compact specific fields (increased width from 50% to 60%) */
.form-compact .compact-field{flex:0 0 60%;max-width:60%}
@media (max-width:760px){
  .form-compact .compact-field{flex:1;max-width:100%}
}

/* Ajuste: aumentar um pouco a largura dos campos compactos quando dentro do bloco com upload */
.fields-upload-row .fields-col .compact-field{flex:0 0 100%;max-width:100%}

/* Stacked control cards: ensure consistent full width and alignment */
.form-row.stacked-cards{display:flex;flex-direction:column;gap:10px;align-items:stretch}
.form-row.stacked-cards{display:flex;flex-direction:column;gap:10px;align-items:stretch;width:100%}
.modal-dialog .form-row.stacked-cards{max-width:520px;margin-left:auto;margin-right:auto}
.form-row.stacked-cards .control-card{width:100% !important;max-width:100% !important;min-width:0 !important;padding:12px 14px;box-sizing:border-box;display:flex;flex-direction:column;align-items:flex-start}
.form-row.stacked-cards .control-card .title{margin-bottom:6px}
.form-row.stacked-cards .control-card > .checkbox-row,
.form-row.stacked-cards .control-card > .radio-row,
.form-row.stacked-cards .control-card > .servicos-wrap{display:flex;align-items:center;gap:10px}

/* Ensures consistent look for the Tabela de Serviços button and alignment */
.form-row.stacked-cards .btn-tabela{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:8px;background:#0B5ED7;color:#fff;border:0;min-width:160px;align-self:flex-start}
.form-row.stacked-cards .btn-tabela svg{margin-right:8px}

/* Reduce gaps in stacked mode to keep the form compact */
.form-row.stacked-cards .control-card{margin-bottom:8px}

@media (max-width: 760px){
  .modal-dialog .form-row.stacked-cards{max-width:94vw;margin-left:auto;margin-right:auto}
  .form-row.stacked-cards .control-card{padding:10px}
  .form-row.stacked-cards .btn-tabela{width:100%;justify-content:center}
}
.fields-upload-row .fields-col .compact-field input{width:100%}
@media (max-width:760px){
  .fields-upload-row .fields-col .compact-field{flex:1;max-width:100%}
}

/* Serviços modal builder */
.servico-modal .modal-dialog{width:min(96vw,880px);max-height:94vh;padding:20px;border:1px solid rgba(32,45,90,0.08);background:linear-gradient(180deg,#fff,#f7f9ff);border-radius:14px;box-shadow:0 18px 40px rgba(15,23,42,0.16);display:flex;flex-direction:column;overflow:hidden;} 
.servico-modal .modal-header{padding:4px 6px 0 6px;align-items:flex-start;}
.servico-modal .modal-title{font-size:1.12rem;color:#0f172a;letter-spacing:.2px;}
.servico-modal .modal-subtitle{color:#667085;font-weight:500;}
.servico-modal .modal-divider{margin:10px 0 12px;background:linear-gradient(90deg,rgba(26,35,126,0.08),rgba(26,35,126,0));}
.servico-modal .modal-body{display:flex;flex-direction:column;gap:12px;flex:1 1 auto;overflow:auto;padding-right:6px;}
.servico-modal .srv-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px 12px;padding:12px 14px;border-radius:12px;background:linear-gradient(180deg,#f6f8ff,#ffffff);border:1px solid #dfe6f2;box-shadow:0 10px 24px rgba(15,23,42,0.10);} 
.servico-modal .srv-form-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));}
.servico-modal .srv-form-grid .col-2{grid-column:auto;}
.srv-field{display:flex;flex-direction:column;gap:4px;}
.srv-field label{font-size:0.78rem;font-weight:800;color:#1a237e;letter-spacing:.24px;text-transform:uppercase;}
.srv-field input,.srv-field select{border:1px solid #dfe6f2;border-radius:10px;padding:8px 10px;font-size:0.92rem;background:#fff;color:#0f172a;box-shadow:0 1px 6px rgba(15,23,42,0.08);height:38px;box-sizing:border-box;transition:all .14s ease;}
.srv-field input::placeholder{color:#9aa7bf;}
.srv-field input:focus,.srv-field select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 2px rgba(47,59,160,0.18),0 8px 22px rgba(24,39,85,0.12);} 
.srv-field.col-2{grid-column:span 2;}
.srv-action-row{grid-column:1/-1;display:flex;align-items:center;gap:10px;padding-top:0;flex-wrap:wrap;justify-content:flex-end;}
.srv-primary{border:0;border-radius:12px;padding:11px 20px;font-weight:800;letter-spacing:.2px;background:linear-gradient(90deg,#2f3ba0,#1a237e);color:#fff;cursor:pointer;box-shadow:0 10px 24px rgba(32,48,120,0.22);} 
.srv-primary:hover{filter:brightness(1.04);}
.srv-link{background:transparent;border:0;color:#526072;font-weight:700;cursor:pointer;text-decoration:underline;text-underline-offset:3px;padding:0;}
.srv-link:hover{color:var(--primary-500);}
.srv-groups-wrapper{display:grid;grid-template-columns:1fr;gap:10px;}
.srv-group-block{background:linear-gradient(180deg,#ffffff,#f8fbff);border:1px solid #dfe6f2;border-radius:12px;padding:12px 14px;box-shadow:0 14px 32px rgba(15,23,42,0.10);display:flex;flex-direction:column;min-height:200px;} 
.srv-group-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:10px;}
.srv-group-head h4{margin:0;font-size:0.92rem;color:#0f172a;letter-spacing:.2px;text-transform:uppercase;font-weight:800;}
.srv-count{font-size:0.8rem;font-weight:700;color:#0f172a;background:#eef2ff;border-radius:999px;padding:5px 12px;box-shadow:0 6px 18px rgba(47,59,160,0.12);} 
.srv-table-wrap{flex:1;overflow:auto;}
.srv-price-table{width:100%;border-collapse:collapse;min-width:520px;}
.srv-price-table th{font-size:0.72rem;text-transform:uppercase;letter-spacing:.5px;color:#4b5565;background:linear-gradient(180deg,#f2f5ff,#e7ebf6);padding:9px 10px;text-align:left;border-bottom:1px solid var(--surface-border);position:sticky;top:0;z-index:1;} 
.srv-price-table td{padding:9px 10px;border-bottom:1px solid #eef0f6;font-size:0.9rem;color:#0f172a;white-space:nowrap;background:#fff;} 
.srv-price-table tbody tr:hover td{background:#f7f9ff;}
.srv-price-table tr:last-child td{border-bottom:0;}
.srv-actions{display:flex;gap:8px;justify-content:flex-end;}
.srv-actions button{border:0;background:#eef2ff;color:var(--primary-700);border-radius:10px;padding:7px 12px;font-weight:700;cursor:pointer;box-shadow:0 6px 16px rgba(47,59,160,0.10);} 
.srv-actions button.danger{background:#fff5f5;color:#d92d20;} 
.srv-actions button:hover{filter:brightness(1.06);} 
.srv-empty-row{font-size:0.88rem;color:var(--muted);text-align:center;padding:24px 8px;}
.servicos-resumo{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px;min-height:38px;}
.servicos-resumo .srv-empty{font-size:0.85rem;color:var(--muted);}
.srv-chip-resumo{display:inline-flex;align-items:center;gap:8px;padding:7px 13px;border-radius:12px;border:1px solid var(--surface-border);background:#f8fafc;font-size:0.85rem;color:#0f172a;box-shadow:0 6px 18px rgba(15,23,42,0.06);} 
.srv-chip-resumo[data-cat="automotivo"]{background:#eef2ff;border-color:#cfd7ff;}
.srv-chip-resumo[data-cat="residencial"]{background:#ecfdf3;border-color:#c9f2da;}
.srv-chip-cat{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--primary-700);}
.srv-chip-resumo strong{font-weight:700;color:#101828;}
.srv-chip-resumo span:last-child{font-weight:600;color:#475467;}

@media (max-width:680px){
  .servico-modal .srv-form-grid{grid-template-columns:1fr;}
  .srv-field.col-2{grid-column:auto;}
  .servico-modal .modal-dialog{width:96vw;}
  .srv-price-table{min-width:100%;}
}

/* End */

/* Saving overlay */
.saving-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(8,15,52,0.38);backdrop-filter:saturate(140%) blur(2px);z-index:1600}
.saving-overlay.open{display:flex}
.saving-dialog{background:linear-gradient(180deg,var(--card),#fbfdff);border:1px solid rgba(32,45,90,0.08);box-shadow:0 10px 30px rgba(20,30,70,0.16);border-radius:12px;padding:18px 20px;display:flex;align-items:center;gap:12px;min-width:260px}
.saving-spinner{width:22px;height:22px;border-radius:50%;border:3px solid #e6ecf3;border-top-color:var(--primary-500);animation:saving-spin .9s linear infinite}
.saving-text{font-weight:700;color:var(--primary-700)}
@keyframes saving-spin{to{transform:rotate(360deg)}}

/* Emissor NF custom select display */
.nf-select-wrap{position:relative}
.nf-select-native{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.nf-combobox{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;border:1px solid #e6edf6;background:#fff;min-height:36px;cursor:pointer;font-size:0.88rem;color:#000;width:auto;max-width:100%;box-sizing:border-box;min-width:140px}
.nf-combobox:focus{outline:none;box-shadow:0 6px 20px rgba(46,75,190,0.06);border-color:var(--primary-500)}
.nf-combobox .nf-name{font-weight:700;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.nf-combobox .nf-cnpj{color:#000;font-weight:500;margin-left:8px;text-align:right}

/* In stacked mode the NF combobox should occupy full width */
.form-row.stacked-cards .nf-select-wrap{width:100%}
.form-row.stacked-cards .nf-combobox{width:100%;min-width:0}
/* Make the caret remain at the right */
.form-row.stacked-cards .nf-combobox .nf-caret{margin-left:auto}
.nf-combobox .nf-caret{margin-left:auto;color:var(--muted)}
.nf-options{position:absolute;z-index:20;bottom:100%;left:0;right:0;background:#fff;border:1px solid #e6edf6;border-radius:8px;margin:0 0 6px 0;display:none;max-height:220px;overflow:auto;box-shadow:0 10px 30px rgba(20,30,70,0.12);list-style:none;padding:0}
.nf-options.open{display:block}
.nf-option{padding:5px 10px;display:flex;align-items:center;gap:6px;cursor:pointer;font-size:0.88rem;justify-content:space-between;white-space:nowrap}
.nf-option .opt-name{font-weight:700;color:#000;flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nf-option .opt-cnpj{color:#000;font-weight:500;flex:0 0 auto;margin-left:12px;text-align:right;white-space:nowrap}
.nf-option:hover,.nf-option.active{background:linear-gradient(180deg,#f7fbff,#ffffff)}

/* Layout do modal de Acionamento (mapa + lista lateral de prestadores) */
#modalAcionarPrest .acionamento-map-dialog{
  width:min(96vw,980px);
  max-height:82vh;
  display:flex;
  flex-direction:column;
  overflow:hidden; /* rolagem fica nas áreas internas (lista/mapa), não no modal inteiro */
}
#modalAcionarPrest .acionar-layout{
  display:flex;
  gap:12px;
  align-items:stretch;
  min-height:300px;
  max-height:calc(82vh - 120px);
}
#modalAcionarPrest .acionar-sidebar{
  flex:0 0 280px;
  max-width:280px;
  display:flex;
  flex-direction:column;
  background:#f8fafc;
  border-radius:12px;
  border:1px solid #e2e8f0;
  padding:8px 10px;
  overflow-y:auto; /* barra de rolagem no próprio aside, em qualquer tamanho de tela */
  overflow-x:hidden;
}
#modalAcionarPrest .acionar-sidebar-header{
  font-weight:700;
  color:#0f172a;
  font-size:0.95rem;
  margin-bottom:6px;
}
#modalAcionarPrest .acionar-list{
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-top:4px;
}
#modalAcionarPrest .acionar-map-wrap{
  flex:1 1 auto;
  min-width:0;
  border-radius:12px;
  border:1px solid #e2e8f0;
  overflow:hidden;
  background:#e5e7eb;
}
#modalAcionarPrest .acionar-map{
  width:100%;
  height:100%;
  min-height:260px;
  border:0;
}
@media (max-width:900px){
  #modalAcionarPrest .acionar-layout{
    flex-direction:column;
    max-height:none;
  }
  #modalAcionarPrest .acionar-sidebar{
    flex:0 0 auto;
    max-width:none;
  }
  #modalAcionarPrest .acionar-map{
    min-height:220px;
  }
}

/* Prestadores Modal - Modern Clean Styling */
.prest-modal .modal-dialog { width: min(90vw, 760px); max-height: 92vh; }
.prest-modal { z-index: 3001; }
.prest-modal .modal-backdrop { z-index: 3000; }
.prest-modal .modal-dialog { z-index: 3002; max-height: calc(100vh - 80px); margin-top: 10px; margin-bottom: 10px; }
.prest-modal .modal-header { display:flex; align-items:center; gap:10px; }
.prest-modal .modal-title { color:#0f172a; font-weight:700; letter-spacing:.2px; }
.prest-modal .modal-subtitle { color:#64748b; }
.prest-modal .modal-divider { border-top: 1px solid #e2e8f0; }

.prest-head { display:flex; gap:16px; align-items:center; }
.prest-avatar { width:96px; height:96px; border-radius:12px; overflow:hidden; border:1px solid #e2e8f0; background:#fff; flex-shrink:0; }
.prest-avatar img { width:100%; height:100%; object-fit:cover; display:block; }
.prest-info { display:flex; flex-direction:column; gap:6px; }
.prest-info .name { font-weight:700; color:#0f172a; font-size:1.1rem; }
.prest-info .muted { color:#64748b; }

.prest-grid { display:grid; grid-template-columns: 1fr 1fr; gap:10px; }
/* Transformação para flex quando empilhado: garante mesma altura entre colunas */
.prest-grid.prest-grid-stacked { display:flex; gap:10px; align-items:stretch; height:var(--prest-grid-height); max-height:var(--prest-grid-height); }
/* Coluna direita (wrapper sem classe específica) */
.prest-grid.prest-grid-stacked > div:not(.prest-block) { display:flex; flex-direction:column; gap:10px; flex:1 1 0; min-height:0; }
/* Bloco genérico */
.prest-block { background:#fff; border:1px solid #e2e8f0; border-radius:12px; padding:12px; min-height:0; }
/* Bloco de serviços: ocupa mesma altura da coluna direita e cria scroll interno se exceder */
.prest-block.services { flex:1 1 0; display:flex; flex-direction:column; overflow:auto; scrollbar-width: thin; min-height:0; }
/* Ajuste visual de espaço interno dos grupos de chips */
.prest-block.services > div { margin-bottom:8px; }
.prest-block.services > div:last-child { margin-bottom:0; }
/* Fazer os três blocos da coluna direita dividirem igualmente a altura total */
.prest-grid.prest-grid-stacked > div:not(.prest-block) .prest-block { flex:1 1 0; display:flex; flex-direction:column; min-height:0; }
/* Permitir que conteúdo interno expanda sem estourar layout */
.prest-grid.prest-grid-stacked > div:not(.prest-block) .prest-block .title { flex:0 0 auto; }
.prest-grid.prest-grid-stacked > div:not(.prest-block) .prest-block > div { flex:1 1 auto; overflow:auto; }
/* Ajuste opcional: galeria de fotos sem barra até ultrapassar limite */
.prest-grid.prest-grid-stacked .prest-block .prest-gallery { overflow:auto; }
.prest-block.services::-webkit-scrollbar { width: 10px; }
.prest-block.services::-webkit-scrollbar-track { background: #f1f5f9; border-radius: 10px; }
.prest-block.services::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 10px; border: 2px solid #f1f5f9; }
.prest-block .title { font-weight:600; color:#1e293b; margin-bottom:8px; }
.chip { display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; border:1px solid #e2e8f0; color:#334155; background:#f8fafc; margin:2px 4px; }
.chip.btn { cursor:pointer; background:#eef2ff; border-color:#c7d2fe; color:#3730a3; }

.prest-gallery { display:flex; gap:12px; flex-wrap:wrap; margin-top:12px; }
.prest-photo { display:flex; flex-direction:column; gap:6px; }
.prest-photo .label { font-weight:600; color:#1e293b; }
.prest-photo img { border:1px solid #e2e8f0; border-radius:12px; box-shadow: 0 2px 10px rgba(0,0,0,.04); }

/* Modern scrollbars applied to modal content and other scrollable regions */
.modal-dialog, .container-wrap, .prest-block, .assistencias, .prest-gallery { scrollbar-width: thin; scrollbar-color: #cbd5e1 #f1f5f9; }
.modal-dialog::-webkit-scrollbar, .container-wrap::-webkit-scrollbar, .prest-block::-webkit-scrollbar, .assistencias::-webkit-scrollbar, .prest-gallery::-webkit-scrollbar { width: 10px; height: 10px; }
.modal-dialog::-webkit-scrollbar-track, .container-wrap::-webkit-scrollbar-track, .prest-block::-webkit-scrollbar-track, .assistencias::-webkit-scrollbar-track, .prest-gallery::-webkit-scrollbar-track { background: #f1f5f9; border-radius: 10px; }
.modal-dialog::-webkit-scrollbar-thumb, .container-wrap::-webkit-scrollbar-thumb, .prest-block::-webkit-scrollbar-thumb, .assistencias::-webkit-scrollbar-thumb, .prest-gallery::-webkit-scrollbar-thumb { background: linear-gradient(180deg,#cbd5e1,#bfcfe0); border-radius: 10px; border: 2px solid #f1f5f9; }
.modal-dialog::-webkit-scrollbar-thumb:hover, .prest-block::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg,#a7b7cc,#94a6bf); }

/* Destacar e fixar o botão de fechar no modal de serviços (não acompanha o scroll interno) */
.servico-modal .modal-close{position:sticky;top:14px;right:14px;align-self:flex-end;background:linear-gradient(135deg,#fee2e2,#fff5f5);color:#b42318;border:1px solid #fecdd3;box-shadow:0 10px 26px rgba(244,63,94,0.22);z-index:11000;}
.servico-modal .modal-close:hover{transform:translateY(-1px);filter:brightness(0.98);} 

/* Modo somente visualização da tabela de serviços */
.servico-modal.view-only .srv-form-grid,
.servico-modal.view-only .srv-action-row{display:none !important;}
.servico-modal.view-only th:last-child,
.servico-modal.view-only td:last-child{display:none;}
.servico-modal.view-only .srv-group-block{padding-top:6px;}
.servico-modal.view-only .srv-table-wrap{max-height:calc(94vh - 200px);}

/* Prestador wizard (admin modal) - tema claro alinhado ao painel */
.prestador-form-modal .modal-dialog{width:min(92vw,720px);background:linear-gradient(180deg,var(--card),#fbfdff);color:#152b6e;border:1px solid rgba(32,45,90,0.08);box-shadow:0 14px 32px rgba(15,23,42,0.16);padding:10px 12px 14px;}
.prestador-form-modal .modal-header{margin-bottom:6px;align-items:flex-start;}
.prestador-form-modal .modal-title{color:var(--primary-700);}
.prestador-form-modal .modal-subtitle{color:var(--muted);}
.prest-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:4px 4px 6px;background:#f8fafc;border:1px solid #e0e7f1;border-radius:999px;box-shadow:none;align-items:center;}
.prest-step-dot{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;padding:6px 8px;border-radius:999px;border:1px solid transparent;background:transparent;color:#6b7280;cursor:pointer;transition:all .16s ease;position:relative;min-height:0;}
.prest-step-dot .circle{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#e5e7eb;border:1px solid #d1d5db;font-weight:700;color:#4b5563;font-size:.78rem;}
.prest-step-dot .label{font-size:.72rem;font-weight:600;letter-spacing:.4px;text-transform:none;text-align:center;}
.prest-step-dot.active{border-color:var(--primary-500);background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#1e293b;box-shadow:0 4px 10px rgba(47,59,160,0.18);}
.prest-step-dot.active .circle{background:linear-gradient(135deg,var(--primary-500),var(--primary-700));color:#fff;box-shadow:0 0 0 3px rgba(47,59,160,0.18);}
.prest-step-dot.done{border-color:#1b8f6d;background:linear-gradient(135deg,#ecfdf3,#d1fae5);color:#166534;}
.prest-step-dot.done .circle{background:#16a34a;color:#ecfdf3;border-color:#22c55e;}
.prest-form-wrap{background:linear-gradient(180deg,#ffffff,#f7f9ff);border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px;box-shadow:0 8px 22px rgba(15,23,42,0.10);max-width:640px;margin:0 auto;}
.prest-form{display:flex;flex-direction:column;gap:14px;}
.prest-step{display:none;gap:14px;}
.prest-step.active{display:flex;flex-direction:column;}
.prest-grid{display:grid;gap:12px;}
.prest-grid.one{grid-template-columns:1fr;}
/* usar minmax(0,1fr) para permitir que o conteúdo encolha sem estourar o grid */
.prest-grid.two{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
.prest-step > .prest-grid{margin-bottom:8px;}
.prest-field{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#1f2937;}
.prest-field input,.prest-field select{width:100%;max-width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e6edf6;background:#ffffff;color:#0f172a;font-size:.98rem;box-shadow:0 1px 3px rgba(15,23,42,0.04) inset;transition:border .12s ease, box-shadow .12s ease;box-sizing:border-box;}
.prest-field input:focus,.prest-field select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px rgba(47,59,160,0.18);}
.prest-hint{color:#6b7a90;font-size:.78rem;}
.prest-upload{border:1px dashed #d9eaf8;background:linear-gradient(180deg,#fbfdff,#f7fbff);border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:10px;}
.prest-upload-header{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.prest-upload-title{font-weight:700;color:#1f2937;font-size:.95rem;}
.prest-upload-body{display:flex;align-items:flex-start;gap:12px;}
.prest-upload-thumb{flex:0 0 140px;width:140px;height:100px;border:1px solid #e2e8f0;border-radius:10px;background:#f9fafb;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 2px 8px rgba(15,23,42,0.06);}
.prest-upload-thumb img{max-width:100%;max-height:100%;object-fit:contain;display:block;}
.prest-upload-thumb .placeholder{color:var(--primary-500);font-size:1.4rem;opacity:0.9;}
.prest-selfie-thumb{flex:1 1 auto;width:100%;height:180px;}
.prest-selfie-thumb img{width:100%;height:100%;object-fit:cover;}
.prest-upload input[type="file"]{position:absolute;opacity:0;width:0;height:0;pointer-events:none;}
.prest-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:10px;border:1px solid #d1d5db;background:#ffffff;color:#1f2937;font-weight:700;cursor:pointer;transition:all .14s ease;min-width:110px;}
.prest-btn.primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border:0;color:#fff;box-shadow:0 10px 24px rgba(47,59,160,0.28);}
.prest-btn.secondary{background:#f3f4f6;border:1px solid #d1d5db;color:#1f2937;}
.prest-btn.success{background:linear-gradient(135deg,#16a085,#27ae60);border:0;color:#fff;box-shadow:0 10px 24px rgba(22,160,133,0.28);}
.prest-btn.ghost{background:transparent;border:1px dashed #d1d5db;color:#6b7280;}
.prest-btn:hover{filter:brightness(1.03);transform:translateY(-1px);}
.prest-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none;}
.prest-btn-tab{border:1px solid #d1d5db;background:#ffffff;color:#475569;padding:8px 12px;border-radius:10px;cursor:pointer;font-weight:700;transition:all .14s ease;}
.prest-btn-tab.active{background:linear-gradient(135deg,var(--primary-500),var(--primary-700));color:#fff;border-color:transparent;box-shadow:0 8px 20px rgba(47,59,160,0.24);}
.prest-tags{display:flex;flex-wrap:wrap;gap:8px;}
.prest-tag{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;border:1px solid #e2e8f0;background:#ffffff;color:#1f2937;font-weight:700;cursor:pointer;user-select:none;}
.prest-tag span{font-weight:700;color:#1f2937;}
.prest-tag input{display:none;}
.prest-tag input:checked + span,.prest-tag input:checked ~ .label{color:#fff;}
.prest-tag input:checked ~ *,.prest-tag:has(input:checked){background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-color:#4255a5;color:#fff;}
.prest-tag:has(input:checked) span{color:#fff;}
.prest-tag.active{background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-color:#4255a5;color:#fff;}
.prest-tag.active span{color:#fff;}
.prest-tag input:checked + label{color:#fff;}
.prest-tag input:checked + span::before{background:#fff;}
.prest-check{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#1f2937;margin:4px 0;}
.prest-check input{width:18px;height:18px;}
.prest-step-title{font-weight:800;color:#1f2937;font-size:1rem;margin-top:4px;}
.prest-cnh-block{display:flex;flex-direction:column;gap:10px;background:#f9fafb;border:1px solid #e2e8f0;border-radius:12px;padding:10px;}
.prest-cnh-tabs{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.prest-cnh-mode{display:block;}
.prest-cnh-mode #prestCnhDocPrev{margin-left:auto;margin-right:auto;}
.prest-wizard-actions{display:flex;align-items:center;gap:10px;margin-top:6px;}
.prest-alert{padding:10px 12px;border-radius:10px;font-weight:700;background:#e5f3ff;border:1px solid #c7e1ff;color:#102a43;}
.prest-alert.success{background:#ecfdf3;border-color:#a7f3d0;color:#065f46;}
.prest-alert.error{background:#2a1818;border-color:#c62828;color:#fddede;}
.file-pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border-radius:8px;border:1px solid #2a3648;background:#111827;color:#e5e7eb;font-size:.9rem;}
@media (max-width:720px){
  .prestador-form-modal .modal-dialog{width:96vw;padding:12px;}
  .prest-steps{grid-template-columns:repeat(2,1fr);}
  .prest-upload-body{flex-direction:column;align-items:stretch;}
  .prest-btn{width:100%;}
  .prest-wizard-actions{flex-wrap:wrap;}
}


.prest-actions { display:flex; gap:8px; justify-content:flex-end; margin-top:16px; }
.btn-primary { background:#16a34a; color:#fff; border:none; border-radius:10px; padding:10px 16px; font-weight:600; cursor:pointer; }
.btn-danger { background:#dc2626; color:#fff; border:none; border-radius:10px; padding:10px 16px; font-weight:600; cursor:pointer; }
.btn-primary:hover { filter:brightness(1.05); }
.btn-danger:hover { filter:brightness(1.05); }

@media (max-width:700px){
  .prest-modal .modal-dialog { width: min(96vw, 560px); }
  .prest-avatar { width:80px; height:80px; }
}
