/* ══════════════════════════════════════════════════
   components.css — Componentes reutilizáveis
   ══════════════════════════════════════════════════ */

/* ══ BOTÃO PRIMÁRIO ═══════════════════════════════ */
.btn-primary {
    display:inline-flex;align-items:center;justify-content:center;gap:7px;
    padding:10px 20px;border:none;border-radius:var(--radius-md);cursor:pointer;
    font-family:var(--font-display);font-size:.82rem;font-weight:700;
    letter-spacing:.05em;text-transform:uppercase;color:white;
    background:linear-gradient(135deg,var(--c-pink-500) 0%,#c0006e 45%,var(--c-roxo-500) 100%);
    box-shadow:0 3px 14px rgba(246,3,80,.35);
    transition:transform var(--duration-fast),box-shadow var(--duration-fast);
    position:relative;overflow:hidden;text-decoration:none;
}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12),transparent 55%);opacity:0;transition:opacity var(--duration-med);pointer-events:none}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(246,3,80,.45)}
.btn-primary:hover::before{opacity:1}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}
.btn-primary.loading .btn-text{display:none}
.btn-primary.loading .btn-spinner{display:block}
.btn-full{width:100%}
.btn-sm{padding:7px 14px;font-size:.75rem}

/* ══ BOTÕES SECUNDÁRIOS ═══════════════════════════ */
.btn-outline{
    display:inline-flex;align-items:center;justify-content:center;gap:7px;
    padding:8px 16px;border:1px solid var(--borda-hover);border-radius:var(--radius-md);
    color:var(--c-text);background:transparent;font-family:var(--font-body);
    font-size:.82rem;text-decoration:none;cursor:pointer;transition:all var(--duration-fast);
}
.btn-outline:hover{background:var(--bg-surface2);border-color:var(--c-text-muted);color:var(--c-white)}

.btn-ghost{
    display:inline-flex;align-items:center;gap:6px;
    padding:7px 12px;border:none;border-radius:var(--radius-md);
    color:var(--c-text-dim);background:transparent;font-family:var(--font-body);
    font-size:.82rem;text-decoration:none;cursor:pointer;transition:all var(--duration-fast);
}
.btn-ghost:hover{color:var(--c-text);background:var(--bg-surface2)}

.btn-text{display:block}
.btn-spinner{display:none;width:15px;height:15px;border:2px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ══ ALERTAS ══════════════════════════════════════ */
.alert{border-radius:var(--radius-md);padding:10px 14px;font-size:.84rem;margin-bottom:16px;display:flex;align-items:flex-start;gap:7px;line-height:1.5}
.alert-success{background:rgba(0,201,122,.08);border:1px solid rgba(0,201,122,.2);border-left:3px solid var(--c-green);color:var(--c-green)}
.alert-error{background:rgba(232,69,69,.08);border:1px solid rgba(232,69,69,.2);border-left:3px solid var(--c-red);color:#ff9999;animation:shake .4s ease}
.alert-warning{background:rgba(240,165,0,.08);border:1px solid rgba(240,165,0,.2);border-left:3px solid var(--c-yellow);color:var(--c-yellow)}
.alert-info{background:rgba(122,12,202,.08);border:1px solid rgba(122,12,202,.2);border-left:3px solid var(--c-roxo-400);color:var(--c-roxo-300)}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-4px)}40%{transform:translateX(4px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}

/* ══ PAGE HEADER ══════════════════════════════════ */
.page-header{margin-bottom:20px}
.page-header--row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.page-title{font-family:var(--font-display);font-size:1.25rem;font-weight:800;letter-spacing:-.01em;margin-bottom:2px;color:var(--c-white)}
.page-subtitle{color:var(--c-text-muted);font-size:.8rem}

/* ══ FILTER BAR ═══════════════════════════════════ */
.filter-bar{margin-bottom:16px}
.filter-form{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.filter-search{position:relative;flex:1;min-width:180px;max-width:360px}
.filter-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:.85rem;pointer-events:none;color:var(--c-text-muted)}
.filter-input{width:100%;background:var(--bg-surface);border:1px solid var(--borda);border-radius:var(--radius-md);color:var(--c-text);font-size:.83rem;padding:8px 12px 8px 32px;outline:none;transition:border var(--duration-med)}
.filter-input:focus{border-color:var(--c-roxo-500);box-shadow:0 0 0 2px rgba(122,12,202,.12)}
.filter-input::placeholder{color:var(--c-text-muted)}
.filter-select{background:var(--bg-surface);border:1px solid var(--borda);border-radius:var(--radius-md);color:var(--c-text);font-size:.83rem;padding:8px 12px;outline:none;cursor:pointer;transition:border var(--duration-fast)}
.filter-select:focus{border-color:var(--c-roxo-500)}
.filter-select option{background:var(--bg-surface2)}

/* ══ TABELA ═══════════════════════════════════════ */
.table-card{overflow:hidden}
.table-wrap{overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;font-size:.82rem}
.data-table thead tr{border-bottom:1px solid var(--borda);background:var(--bg-surface2)}
.data-table th{padding:9px 14px;text-align:left;font-size:.67rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--c-text-muted);white-space:nowrap}
.data-table td{padding:11px 14px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle;color:var(--c-text)}
.data-table tbody tr{transition:background var(--duration-fast)}
.data-table tbody tr:hover{background:var(--bg-surface2)}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table .row-inactive{opacity:.45}
.th-actions,.td-actions{text-align:right;white-space:nowrap}
.td-dim{color:var(--c-text-muted);font-size:.78rem}

/* User cell */
.user-cell{display:flex;align-items:center;gap:10px}
.user-cell-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--c-pink-500),var(--c-roxo-500));display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:.78rem;color:white;flex-shrink:0}
.user-cell-name{font-weight:500;color:var(--c-white);font-size:.82rem}
.user-cell-email{font-size:.72rem;color:var(--c-text-muted)}

/* Badges */
.role-badge{display:inline-block;font-size:.67rem;font-weight:700;padding:2px 9px;border-radius:var(--radius-full);background:rgba(122,12,202,.15);color:var(--c-roxo-300);border:1px solid rgba(122,12,202,.25)}
.status-badge{display:inline-flex;align-items:center;font-size:.67rem;font-weight:700;padding:2px 9px;border-radius:var(--radius-full)}
.status-ativo{background:rgba(0,201,122,.1);color:var(--c-green);border:1px solid rgba(0,201,122,.18)}
.status-inativo{background:rgba(255,255,255,.04);color:var(--c-text-muted);border:1px solid var(--borda)}

/* Action buttons */
.action-btn{display:inline-flex;align-items:center;justify-content:center;width:27px;height:27px;border-radius:var(--radius-sm);background:var(--bg-surface2);border:1px solid var(--borda);font-size:.85rem;cursor:pointer;text-decoration:none;transition:all var(--duration-fast);color:inherit}
.action-btn:hover{background:var(--bg-surface3);border-color:var(--borda-hover)}
.action-btn--danger{color:var(--c-red)!important;border-color:rgba(232,69,69,.22)!important}
.action-btn--danger:hover{background:rgba(232,69,69,.1)!important}

/* ══ PAGINAÇÃO ════════════════════════════════════ */
.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--borda);gap:12px;flex-wrap:wrap}
.pagination-info{font-size:.78rem;color:var(--c-text-muted)}
.pagination-info strong{color:var(--c-text)}
.pagination-pages{display:flex;align-items:center;gap:3px}
.page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 5px;border-radius:var(--radius-sm);font-size:.78rem;text-decoration:none;color:var(--c-text-muted);background:transparent;border:1px solid transparent;transition:all var(--duration-fast);cursor:pointer}
.page-btn:hover:not(.disabled):not(.page-current):not(.page-ellipsis){background:var(--bg-surface2);border-color:var(--borda);color:var(--c-text)}
.page-current{background:linear-gradient(135deg,var(--c-pink-500),var(--c-roxo-500));color:white;font-weight:700;border-color:transparent;cursor:default}
.page-ellipsis{cursor:default;color:var(--c-text-muted)}
.disabled{opacity:.3;cursor:not-allowed}

/* ══ FORMULÁRIOS ══════════════════════════════════ */
.form-page{max-width:700px}
.form-card{padding:0}
.form-section{padding:18px 20px;border-bottom:1px solid var(--borda)}
.form-section:last-of-type{border-bottom:none}
.form-section-title{font-family:var(--font-display);font-size:.84rem;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:10px;color:var(--c-white)}
.form-section-hint{font-family:var(--font-body);font-size:.7rem;font-weight:400;color:var(--c-text-muted)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}}

.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--c-text-muted)}
.form-group.has-error input,.form-group.has-error select{border-color:var(--c-red)!important;box-shadow:0 0 0 2px rgba(232,69,69,.12)!important}
.form-group input,.form-group select,.form-group textarea{background:var(--bg-surface2);border:1px solid var(--borda);border-radius:var(--radius-md);color:var(--c-text);font-family:var(--font-body);font-size:.84rem;padding:9px 12px;outline:none;transition:border var(--duration-med),box-shadow var(--duration-med);width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--c-roxo-500);box-shadow:0 0 0 2px rgba(122,12,202,.15);background:var(--bg-surface3)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--c-text-muted)}
.form-group select option{background:var(--bg-surface2)}
.required{color:var(--c-pink-500)}
.field-error{font-size:.74rem;color:#ff9999}
.field-hint{font-size:.72rem;color:var(--c-text-muted)}
.label-inline{display:flex;align-items:center;gap:7px;cursor:pointer;font-size:.84rem;color:var(--c-text);text-transform:none;letter-spacing:0;font-weight:400}
.label-inline input[type=checkbox]{width:14px;height:14px;flex-shrink:0;accent-color:var(--c-roxo-500);cursor:pointer;padding:0}
.input-with-toggle{position:relative}
.input-with-toggle input{padding-right:38px}
.input-with-toggle .toggle-pw{position:absolute;right:9px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--c-text-muted);font-size:.95rem;cursor:pointer;padding:3px;transition:color var(--duration-fast)}
.input-with-toggle .toggle-pw:hover{color:var(--c-text)}
.form-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--borda)}
.form-actions--card{padding:12px 16px;border-top:1px solid var(--borda);display:flex;justify-content:flex-end}

/* ══ PERFIL ═══════════════════════════════════════ */
.perfil-tabs{display:flex;gap:3px;margin-bottom:16px;border-bottom:1px solid var(--borda)}
.perfil-tab{padding:9px 16px;background:none;border:none;color:var(--c-text-muted);font-family:var(--font-body);font-size:.84rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}
.perfil-tab:hover{color:var(--c-text)}
.perfil-tab.active{color:var(--c-white);border-bottom-color:var(--c-pink-500);font-weight:500}
.perfil-tab-content{display:none}
.perfil-tab-content.active{display:block}
.perfil-layout{display:grid;grid-template-columns:190px 1fr;gap:16px;align-items:start}
.perfil-avatar-card{padding:20px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
.avatar-img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid var(--borda-hover);box-shadow:0 0 16px rgba(122,12,202,.3)}
.avatar-placeholder{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--c-pink-500),var(--c-roxo-500));display:grid;place-items:center;font-family:var(--font-display);font-size:1.6rem;font-weight:800;color:white}
.avatar-name{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--c-white)}
.avatar-role{margin-bottom:4px}
.avatar-upload-form{width:100%}
.avatar-hint{font-size:.68rem;color:var(--c-text-muted)}
.perfil-content{display:flex;flex-direction:column;gap:14px}
@media(max-width:700px){.perfil-layout{grid-template-columns:1fr}}

/* ══ ML — DETALHE PEDIDO ══════════════════════════ */

/* Seção estilo ERP */
.erp-section{margin-bottom:20px}
.erp-section-title{
    font-family:var(--font-display);font-size:.78rem;font-weight:700;
    text-transform:uppercase;letter-spacing:.06em;
    color:var(--c-text-muted);
    padding:0 0 7px 0;
    border-bottom:1px solid var(--borda);
    margin-bottom:12px;
}
.erp-fields{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:10px 14px;
}
.erp-fields.cols-2{grid-template-columns:repeat(2,1fr)}
.erp-fields.cols-3{grid-template-columns:repeat(3,1fr)}
.erp-fields.cols-6{grid-template-columns:repeat(6,1fr)}
.erp-field{}
.erp-label{
    font-size:.68rem;font-weight:600;
    text-transform:uppercase;letter-spacing:.06em;
    color:var(--c-text-muted);
    margin-bottom:4px;display:block;
}
.erp-value{
    background:var(--bg-surface2);
    border:1px solid var(--borda);
    border-radius:var(--radius-sm);
    padding:7px 10px;
    font-size:.84rem;
    color:var(--c-text);
    min-height:34px;
    display:flex;align-items:center;
}
.erp-value.highlight{
    color:var(--c-white);
    font-family:var(--font-display);
    font-weight:700;
    font-size:.95rem;
}
.erp-value.value-green{color:var(--c-green);font-weight:700}
.erp-value.value-red{color:var(--c-red)}
.erp-value.value-yellow{color:var(--c-yellow)}
.erp-value.value-blue{color:var(--c-blue)}

/* Tabs ERP */
.erp-tabs{display:flex;border-bottom:1px solid var(--borda);margin-bottom:16px;gap:2px}
.erp-tab{padding:8px 18px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--c-text-muted);font-size:.84rem;cursor:pointer;transition:all .15s;font-family:var(--font-body)}
.erp-tab:hover{color:var(--c-text)}
.erp-tab.active{color:var(--c-white);border-bottom-color:var(--c-roxo-400);font-weight:600}
.erp-tab-content{display:none}
.erp-tab-content.active{display:block}

/* Tabela de itens ERP */
.erp-table{width:100%;border-collapse:collapse;font-size:.8rem}
.erp-table th{background:var(--bg-surface2);padding:8px 10px;text-align:left;font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-text-muted);border-bottom:1px solid var(--borda)}
.erp-table td{padding:9px 10px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--c-text);vertical-align:middle}
.erp-table tr:hover td{background:var(--bg-surface2)}
.erp-table tr:last-child td{border-bottom:none}
.erp-table td:first-child{color:var(--c-text-muted);font-size:.75rem;width:28px}

/* Badge novo */
.badge-novo{background:rgba(74,158,255,.15);color:var(--c-blue);border:1px solid rgba(74,158,255,.25);font-size:.62rem;font-weight:700;padding:1px 7px;border-radius:3px;vertical-align:middle;margin-left:5px}

/* ══ ML resumo grid ═══════════════════════════════ */
.ml-resumo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.ml-kpi{background:var(--bg-surface);border:1px solid var(--borda);border-radius:var(--radius-lg);padding:14px 16px}
.ml-kpi-label{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--c-text-muted);margin-bottom:5px}
.ml-kpi-valor{font-family:var(--font-display);font-size:.95rem;font-weight:700;color:var(--c-white);word-break:break-word}
.ml-detalhe-grid{display:grid;grid-template-columns:1fr 270px;gap:14px;align-items:start}

/* ══ MISC ═════════════════════════════════════════ */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}

@media(max-width:900px){.ml-resumo-grid{grid-template-columns:repeat(2,1fr)}.ml-detalhe-grid{grid-template-columns:1fr}.erp-fields{grid-template-columns:repeat(2,1fr)!important}.erp-fields.cols-6{grid-template-columns:repeat(3,1fr)!important}}
@media(max-width:500px){.ml-resumo-grid{grid-template-columns:1fr}.erp-fields{grid-template-columns:1fr!important}}
