:root{
    --bg:#eef2f7;
    --card:#ffffff;
    --text:#142033;
    --muted:#64748b;
    --blue:#003b71;
    --blue-2:#00539b;
    --blue-3:#012a4f;
    --orange:#f58220;
    --orange-2:#ff9f43;
    --green:#16a34a;
    --red:#dc2626;
    --purple:#6d28d9;
    --yellow:#ca8a04;
    --border:#dbe4ef;
    --shadow:0 10px 28px rgba(15,23,42,.08);
    --radius:18px;
}

*{
    box-sizing:border-box;
    font-family:Inter,Segoe UI,Arial,sans-serif;
}

html,body{
    margin:0;
    min-height:100%;
    background:var(--bg);
    color:var(--text);
}

button{
    border:0;
    border-radius:12px;
    padding:11px 16px;
    background:#e8eef7;
    color:#172033;
    font-weight:800;
    cursor:pointer;
    transition:.18s ease;
}

button:hover{
    transform:translateY(-1px);
    filter:brightness(.98);
}

input,select,textarea{
    width:100%;
    border:1px solid var(--border);
    border-radius:12px;
    padding:12px 13px;
    background:#fff;
    color:var(--text);
    outline:none;
    transition:.15s ease;
}

input:focus,select:focus,textarea:focus{
    border-color:var(--blue-2);
    box-shadow:0 0 0 4px rgba(0,83,155,.12);
}

textarea{min-height:96px;resize:vertical}

label{
    display:block;
    font-size:12px;
    font-weight:900;
    color:#334155;
    margin-bottom:7px;
    text-transform:uppercase;
    letter-spacing:.03em;
}

/* LOGIN */
.login-page{
    height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    background:
        radial-gradient(circle at top left, rgba(245,130,32,.38), transparent 34%),
        linear-gradient(135deg,var(--blue-3),var(--blue),#001b33);
}

.login-card{
    width:560px;
    max-width:94vw;
    background:rgba(255,255,255,.98);
    border-radius:30px;
    padding:44px 52px;
    box-shadow:0 28px 70px rgba(0,0,0,.32);
    border:1px solid rgba(255,255,255,.6);
}

.login-logo{
    width:250px;
    max-height:105px;
    object-fit:contain;
    display:block;
    margin:0 auto 28px;
}

.login-card h1{
    margin:0;
    text-align:center;
    color:#101827;
    font-size:42px;
    font-weight:900;
    line-height:1.08;
}

.login-card p{
    text-align:center;
    color:var(--blue);
    font-size:18px;
    font-weight:800;
    margin:16px 0 28px;
}

.login-card input{
    height:52px;
    margin-bottom:13px;
    background:#f8fafc;
}

.login-card button{
    width:100%;
    height:56px;
    background:linear-gradient(135deg,var(--blue),var(--blue-2));
    color:white;
    font-size:17px;
    margin-top:4px;
    box-shadow:0 10px 24px rgba(0,59,113,.28);
}

.login-card small{
    display:block;
    text-align:center;
    margin-top:18px;
    color:var(--muted);
    font-size:14px;
    font-weight:700;
}

/* LAYOUT */
.layout{
    display:flex;
    min-height:100vh;
}

.sidebar{
    width:282px;
    background:linear-gradient(180deg,#002f5c 0%,#001d38 100%);
    color:white;
    padding:22px;
    position:fixed;
    top:0;
    bottom:0;
    left:0;
    overflow-y:auto;
    padding-bottom:110px!important;
    box-shadow:8px 0 30px rgba(15,23,42,.18);
}

.brand{
    margin-bottom:24px;
    padding-bottom:18px;
    border-bottom:1px solid rgba(255,255,255,.14);
}

.brand img{
    width:172px;
    max-height:78px;
    object-fit:contain;
    display:block;
    margin-bottom:16px;
    background:white;
    border-radius:16px;
    padding:10px;
    box-shadow:0 10px 22px rgba(0,0,0,.18);
}

.brand strong{
    display:block;
    font-size:23px;
    font-weight:900;
}

.brand span{
    color:#cbd5e1;
    font-size:13px;
    font-weight:700;
}

.sidebar button{
    width:100%;
    text-align:left;
    background:transparent;
    color:#dbeafe;
    margin-bottom:8px;
    border:1px solid transparent;
}

.sidebar button:hover{
    background:rgba(255,255,255,.08);
    color:#fff;
    border-color:rgba(255,255,255,.12);
}

.btn-nova-oc{
    background:linear-gradient(135deg,var(--orange),var(--orange-2))!important;
    color:white!important;
    font-size:16px!important;
    box-shadow:0 10px 24px rgba(245,130,32,.35);
    margin:8px 0 16px!important;
    text-align:center!important;
}

.frota-panel .hint{
    margin-bottom:18px;
}

.frota-checklist-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:14px;
    margin:18px 0;
}

.checklist-item-card,
.recebimento-cego-card,
.devolucao-card{
    background:#fff;
    border:1px solid var(--border);
    border-radius:18px;
    padding:16px;
    box-shadow:var(--shadow);
}

.checklist-item-card strong{
    display:block;
    color:var(--blue);
    font-size:14px;
    margin-bottom:5px;
}

.checklist-item-card span{
    display:block;
    color:var(--muted);
    font-size:12px;
    font-weight:800;
    margin-bottom:12px;
}

.form-grid.compacto{
    grid-template-columns:1fr 1fr;
    gap:10px;
}

.alerta-divergencia{
    border-left:5px solid var(--orange);
    background:#fff7ed;
}

.status-pill{
    display:inline-flex;
    align-items:center;
    border-radius:999px;
    padding:6px 10px;
    font-weight:900;
    font-size:12px;
    background:#e2e8f0;
    color:#334155;
}

.status-pill.ok{background:#dcfce7;color:#166534}
.status-pill.alerta{background:#fef3c7;color:#92400e}
.status-pill.erro{background:#fee2e2;color:#991b1b}

.checklist-tabs{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin:16px 0 20px;
}

.checklist-tabs button{
    width:auto;
    background:#eef4fb;
    color:var(--blue);
    border:1px solid var(--border);
}

.checklist-tabs button.ativo{
    background:linear-gradient(135deg,var(--blue),var(--blue-2));
    color:#fff;
}

.checklist-subtela{display:none}
.checklist-subtela.ativa{display:block}

.checklist-original-grid{
    display:grid;
    gap:16px;
    margin:18px 0;
}

.grupo-check-card{
    border:1px solid var(--border);
    border-radius:18px;
    background:#fff;
    padding:16px;
    box-shadow:var(--shadow);
}

.grupo-check-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    margin-bottom:12px;
}

.grupo-check-header h3{margin:0;color:var(--blue)}
.grupo-check-header span{font-size:12px;font-weight:900;color:var(--muted)}

.grupo-check-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:12px;
}

.check-item{
    border:1px solid var(--border);
    border-radius:16px;
    padding:14px;
    background:#f8fafc;
}

.check-item.marcado{
    border-color:var(--orange);
    background:#fff7ed;
}

.check-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:10px;
}

.check-head h3{margin:0;font-size:15px;color:#172033}
.check-head small{color:var(--muted);font-weight:800}
.check-x input{width:auto;transform:scale(1.25)}
.check-detalhes{margin-top:12px}
.hidden{display:none!important}
.os-box.selecionado{border-color:var(--green);background:#f0fdf4}

.sidebar .logout{
    position:fixed!important;
    bottom:22px!important;
    left:22px!important;
    width:238px!important;
    background:#b91c1c!important;
    color:#fff!important;
    font-weight:900!important;
    text-align:center!important;
    box-shadow:0 8px 18px rgba(0,0,0,.25);
}

.sidebar .logout:hover{
    background:#991b1b!important;
}

/* MAIN */
main{
    margin-left:282px;
    width:calc(100% - 282px);
    padding:24px;
}

.topbar{
    background:rgba(255,255,255,.96);
    border:1px solid var(--border);
    border-radius:22px;
    padding:20px 24px;
    margin-bottom:22px;
    display:flex;
    gap:14px;
    justify-content:space-between;
    align-items:center;
    box-shadow:var(--shadow);
    position:sticky;
    top:16px;
    z-index:3;
    backdrop-filter:blur(12px);
}

.topbar h1{
    margin:0;
    font-size:27px;
    font-weight:900;
    color:#0f172a;
}

.topbar p{
    margin:5px 0 0;
    color:var(--muted);
    font-weight:700;
}

.btn-voltar-topo{
    background:#edf3fb!important;
    color:var(--blue)!important;
    white-space:nowrap;
    border:1px solid var(--border);
}

.userbox{
    text-align:right;
    background:linear-gradient(135deg,#f8fafc,#eef6ff);
    border:1px solid var(--border);
    padding:11px 15px;
    border-radius:16px;
    min-width:180px;
}

.userbox b{display:block;font-size:14px}
.userbox span{color:var(--blue);font-weight:900;font-size:12px;text-transform:uppercase}

.tela{display:none}
.tela.ativa{display:block}

.panel,.subpanel{
    background:white;
    border:1px solid var(--border);
    border-radius:22px;
    padding:24px;
    margin-bottom:20px;
    box-shadow:var(--shadow);
}

.panel h2,.subpanel h3{
    margin:0 0 18px;
    color:#0f172a;
    font-weight:900;
}

.subpanel{
    background:linear-gradient(180deg,#fff,#fbfdff);
}

/* DASHBOARD */
.grid-cards{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
    gap:16px;
    margin-bottom:20px;
}

.card{
    background:white;
    border-radius:22px;
    padding:20px;
    box-shadow:var(--shadow);
    border:1px solid var(--border);
    border-left:7px solid var(--blue);
    transition:.18s ease;
}

.card:hover{
    transform:translateY(-3px);
    box-shadow:0 16px 34px rgba(15,23,42,.12);
}

.card span{
    display:block;
    color:var(--muted);
    font-weight:900;
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.04em;
}

.card strong{
    display:block;
    font-size:30px;
    margin-top:9px;
    color:var(--blue);
}

.card.green{border-left-color:var(--green)}
.card.green strong{color:var(--green)}
.card.orange{border-left-color:var(--orange)}
.card.orange strong{color:var(--orange)}
.card.red{border-left-color:var(--red)}
.card.red strong{color:var(--red)}
.card.purple{border-left-color:var(--purple)}
.card.purple strong{color:var(--purple)}
.card.yellow{border-left-color:var(--yellow)}
.card.yellow strong{color:var(--yellow)}
.money .card strong{font-size:22px}

/* FORMS */
.form-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
    gap:16px;
    margin-bottom:16px;
}

.search-row{
    display:flex;
    gap:10px;
    align-items:center;
}

.search-row input{flex:1}
.search-row button{
    white-space:nowrap;
    background:var(--blue);
    color:white;
}

.resultados{
    display:none;
    background:#fff;
    border:1px solid var(--border);
    border-radius:16px;
    max-height:260px;
    overflow:auto;
    margin:10px 0;
    box-shadow:var(--shadow);
}

.resultados div{
    padding:12px 14px;
    border-bottom:1px solid var(--border);
    cursor:pointer;
}

.resultados div:hover{background:#fff7ed}

.selected{
    background:#fff7ed;
    border:1px dashed var(--orange);
    border-radius:14px;
    padding:13px;
    margin:12px 0;
    color:#8a4b00;
    font-weight:900;
}

.primary{
    background:linear-gradient(135deg,var(--green),#22c55e)!important;
    color:white!important;
    box-shadow:0 10px 22px rgba(22,163,74,.24);
}

.danger-btn{
    background:#dc2626!important;
    color:white!important;
    margin-left:6px;
}

/* TABLES */
table{
    width:100%;
    border-collapse:separate;
    border-spacing:0;
    background:white;
    border-radius:16px;
    overflow:hidden;
    border:1px solid var(--border);
}

th{
    background:#f1f5f9;
    color:#334155;
    text-align:left;
    font-size:12px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.03em;
}

td,th{
    padding:13px;
    border-bottom:1px solid var(--border);
    vertical-align:top;
}

tr:last-child td{border-bottom:0}
tr:hover td{background:#fafcff}

.totais{
    display:flex;
    gap:18px;
    justify-content:flex-end;
    margin-top:16px;
    font-size:16px;
    flex-wrap:wrap;
}

.totais b{color:var(--blue)}

.status{
    display:inline-block;
    padding:7px 11px;
    border-radius:999px;
    font-size:12px;
    font-weight:900;
}

.status-ok{background:#dcfce7;color:#166534}
.status-alerta{background:#fef3c7;color:#92400e}
.status-erro{background:#fee2e2;color:#991b1b}

.doc-link{
    display:inline-block;
    background:var(--blue);
    color:white;
    text-decoration:none;
    border-radius:10px;
    padding:8px 12px;
    margin:4px 4px 4px 0;
    font-weight:800;
}

.import-card{
    border:1px solid var(--border);
    border-radius:18px;
    padding:18px;
    margin-bottom:14px;
    background:#fbfdff;
}

.checks{
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    margin:10px 0 18px;
}

.checks input{width:auto}

.modal{
    display:none;
    position:fixed;
    inset:0;
    background:rgba(15,23,42,.58);
    align-items:center;
    justify-content:center;
    z-index:20;
    padding:20px;
}

.modal-box{
    width:460px;
    max-width:96%;
    background:white;
    border-radius:24px;
    padding:26px;
    box-shadow:0 28px 70px rgba(0,0,0,.32);
}

.modal-box input,.modal-box select{margin-bottom:11px}

.filtros{
    background:#f8fafc;
    border:1px solid var(--border);
    padding:16px;
    border-radius:18px;
    margin-bottom:14px;
}

.historico-box{margin-top:16px}
#valorOrcamento1,#valorOrcamento2,#valorOrcamento3{margin-top:8px}

.hint{
    color:var(--muted);
    background:#fff7ed;
    border-left:5px solid var(--orange);
    padding:11px 13px;
    border-radius:12px;
    margin-top:-4px;
    font-weight:700;
}

.download-info{
    background:#eef6ff;
    border-left:5px solid var(--blue);
    padding:11px 13px;
    border-radius:12px;
    color:#334155;
}

.linha-vencida td{
    background:#fee2e2!important;
}

.linha-vencida td:first-child{
    border-left:5px solid #dc2626;
}

/* Responsivo */
@media(max-width:980px){
    .sidebar{
        position:relative;
        width:100%;
        height:auto;
        padding-bottom:22px!important;
    }

    .sidebar .logout{
        position:relative!important;
        bottom:auto!important;
        left:auto!important;
        width:100%!important;
        margin-top:12px!important;
    }

    .layout{display:block}
    main{
        margin-left:0;
        width:100%;
        padding:16px;
    }

    .topbar{
        position:relative;
        top:0;
        display:block;
    }

    .btn-voltar-topo{
        margin:12px 0;
        width:100%;
    }

    .userbox{text-align:left}

    .search-row{display:block}
    .search-row button{margin-top:8px;width:100%}

    table{
        display:block;
        overflow:auto;
        white-space:nowrap;
    }

    .login-card{
        padding:34px 26px;
    }

    .login-card h1{
        font-size:34px;
    }
}

/* Fluxo Compras/Fiscal/Contas/Tesouraria */
.flow-badge{
    display:inline-block;
    padding:7px 11px;
    border-radius:999px;
    background:#eef6ff;
    color:var(--blue);
    font-weight:900;
    font-size:12px;
}

#recebimento .panel,
#fiscal .panel,
#tesouraria .panel{
    border-top:5px solid var(--orange);
}

/* Permissões por perfil */
.sem-permissao{
    display:none!important;
}


.perfil-ajuda{
    background:#eef6ff;
    border:1px solid #bfdbfe;
    border-left:5px solid var(--blue);
    color:#334155;
    border-radius:14px;
    padding:12px 14px;
    margin-bottom:16px;
    font-size:14px;
    font-weight:700;
}

.module-card{
    background:#f8fafc;
    border:1px solid var(--border);
    border-radius:18px;
    padding:18px;
    margin:14px 0 18px;
}

.module-card h3{
    margin:0 0 6px;
    color:var(--blue);
}

.module-card p{
    margin:0 0 14px;
    color:var(--muted);
    font-weight:700;
}

.module-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
    gap:10px;
}

.module-grid label{
    background:white;
    border:1px solid var(--border);
    border-radius:12px;
    padding:10px 12px;
    text-transform:none;
    letter-spacing:0;
    font-size:13px;
    display:flex;
    align-items:center;
    gap:8px;
}

.module-grid input{
    width:auto;
}

.module-actions{
    display:flex;
    gap:10px;
    margin-top:14px;
    flex-wrap:wrap;
}

.timeline-oc{display:flex;align-items:flex-start;gap:10px;overflow:auto;padding:12px 4px}
.timeline-step{min-width:128px;position:relative;text-align:center;color:var(--muted);font-weight:800}
.timeline-step:not(:last-child)::after{content:"";position:absolute;top:18px;left:75px;width:100px;height:3px;background:#dbe4ef;z-index:0}
.timeline-step span{width:38px;height:38px;border-radius:999px;display:flex;align-items:center;justify-content:center;margin:0 auto 8px;background:#e5e7eb;color:#475569;font-weight:900;position:relative;z-index:1}
.timeline-step small{display:block;font-size:12px;line-height:1.25}
.timeline-step.done span{background:var(--green);color:white}
.timeline-step.done:not(:last-child)::after{background:var(--green)}
.timeline-step.active span{background:var(--orange);color:white;box-shadow:0 0 0 5px rgba(245,130,32,.18)}
.flux-card{background:#fff;border:1px solid var(--border);border-radius:22px;padding:20px;margin-bottom:18px;box-shadow:var(--shadow)}
.flux-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:10px}
.flux-head h3{margin:0;color:var(--blue);font-size:20px}
.flux-head p{margin:4px 0 0;color:var(--muted);font-weight:700}
.flux-status{background:#fff7ed;color:#9a4c00;border:1px solid #fed7aa;border-radius:999px;padding:8px 13px;font-weight:900;white-space:nowrap}
.flux-info{display:flex;gap:18px;flex-wrap:wrap;color:#334155;margin:14px 0}
.flux-actions{display:flex;gap:10px;flex-wrap:wrap}
.empty-state{background:#f8fafc;border:1px dashed var(--border);border-radius:18px;padding:28px;text-align:center;color:var(--muted);font-weight:800}

#boxDiasPagamento,
#boxParcelas,
#boxVencimento{
    transition:.2s ease;
}

.fornecedor-lista{
    display:grid;
    gap:10px;
    margin:12px 0;
}

.fornecedor-chip{
    background:#f8fafc;
    border:1px solid var(--border);
    border-radius:14px;
    padding:12px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
}

.fornecedor-chip small{
    color:var(--muted);
    font-weight:700;
}

.fornecedor-grupo-oc{
    border:1px solid var(--border);
    border-radius:18px;
    padding:16px;
    margin:16px 0;
    background:#fbfdff;
}

.fornecedor-grupo-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-bottom:12px;
    flex-wrap:wrap;
}

.fornecedor-grupo-header h3{
    margin:0;
    color:var(--blue);
}

.fornecedor-grupo-header strong{
    background:#eef6ff;
    color:var(--blue);
    border:1px solid #bfdbfe;
    border-radius:999px;
    padding:8px 12px;
}

.vias-box{
    margin-top:18px;
}

.vias-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:12px;
    margin-top:12px;
}

.via-card{
    background:#f8fafc;
    border:1px solid var(--border);
    border-left:5px solid var(--orange);
    border-radius:16px;
    padding:14px;
}

.via-card b{
    display:block;
    color:var(--blue);
    margin-bottom:4px;
}

.via-card span{
    display:block;
    font-weight:900;
    color:#9a4c00;
    margin-bottom:4px;
}

.via-card small{
    display:block;
    color:var(--muted);
    font-weight:700;
    margin-bottom:10px;
}

.via-card button{
    margin:4px 4px 0 0;
}

.via-card button + button{
    background:#e8eef7!important;
    color:#172033!important;
}

.via-card button{
    width:100%;
    margin-top:10px;
}


/* =========================================================
   VISUAL ERP CORPORATIVO - CAVALHEIRO
   Layout mais sóbrio, operacional e profissional
   ========================================================= */

:root{
    --bg:#f4f6f9;
    --card:#ffffff;
    --text:#172033;
    --muted:#64748b;
    --blue:#003b71;
    --blue-2:#004b8d;
    --blue-3:#012a4f;
    --orange:#f58220;
    --green:#15803d;
    --red:#b91c1c;
    --purple:#5b21b6;
    --yellow:#a16207;
    --border:#d7dee8;
    --shadow:0 2px 8px rgba(15,23,42,.06);
    --radius:10px;
}

html,body{
    background:var(--bg)!important;
}

/* Login mais corporativo */
.login-page{
    background:#eef2f7!important;
}

.login-card{
    border-radius:14px!important;
    box-shadow:0 10px 32px rgba(15,23,42,.16)!important;
    border:1px solid #d7dee8!important;
    width:460px!important;
    padding:34px 40px!important;
}

.login-card h1{
    font-size:30px!important;
    color:var(--blue)!important;
}

.login-card p{
    font-size:15px!important;
    color:#475569!important;
}

.login-card button{
    background:var(--blue)!important;
    box-shadow:none!important;
    border-radius:8px!important;
}

.login-logo{
    width:210px!important;
    max-height:82px!important;
}

/* Sidebar ERP */
.sidebar{
    width:268px!important;
    background:#002f5c!important;
    box-shadow:none!important;
    border-right:1px solid #001d38;
    padding:18px!important;
    padding-bottom:110px!important;
}

.brand{
    border-bottom:1px solid rgba(255,255,255,.15)!important;
    margin-bottom:14px!important;
}

.brand img{
    width:160px!important;
    max-height:68px!important;
    border-radius:8px!important;
    box-shadow:none!important;
    padding:8px!important;
}

.brand strong{
    font-size:20px!important;
}

.brand span{
    font-size:12px!important;
}

.sidebar button{
    border-radius:7px!important;
    margin-bottom:4px!important;
    padding:10px 12px!important;
    font-size:14px!important;
    font-weight:700!important;
    color:#e2e8f0!important;
}

.sidebar button:hover{
    background:#004b8d!important;
    border-color:transparent!important;
}

.btn-nova-oc{
    background:var(--orange)!important;
    color:#fff!important;
    box-shadow:none!important;
    border-radius:7px!important;
    margin:10px 0 12px!important;
}

.sidebar .logout{
    width:232px!important;
    left:18px!important;
    bottom:18px!important;
    border-radius:7px!important;
    box-shadow:none!important;
}

.menu-modulos{
    display:flex;
    flex-direction:column;
    gap:9px;
}

.menu-grupo{
    border:1px solid rgba(255,255,255,.1);
    border-radius:10px;
    background:rgba(255,255,255,.045);
    overflow:hidden;
}

.menu-grupo-titulo{
    display:flex!important;
    align-items:center;
    justify-content:space-between;
    width:100%;
    margin:0!important;
    padding:11px 12px!important;
    background:rgba(0,0,0,.16)!important;
    color:#fff!important;
    border-radius:0!important;
    text-transform:uppercase;
    letter-spacing:.04em;
    font-size:12px!important;
}

.menu-grupo-titulo span{
    white-space:normal;
    line-height:1.25;
}

.menu-grupo-titulo b{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:22px;
    height:22px;
    min-width:22px;
    border-radius:50%;
    background:rgba(255,255,255,.12);
}

.menu-grupo-itens{
    padding:7px;
}

.menu-subtitulo{
    display:block;
    margin:10px 5px 6px;
    color:#93c5fd;
    font-size:10px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.menu-subtitulo:first-child{
    margin-top:2px;
}

.menu-grupo.fechado .menu-grupo-itens{
    display:none;
}

.menu-grupo .menu-item{
    display:block;
    width:100%;
    margin:0 0 5px!important;
    padding:9px 10px 9px 16px!important;
    border-radius:8px!important;
    background:transparent!important;
    border-left:3px solid transparent!important;
    color:#dbeafe!important;
}

.menu-grupo .menu-item:last-child{
    margin-bottom:0!important;
}

.menu-grupo .menu-item:hover{
    background:rgba(255,255,255,.09)!important;
    border-left-color:rgba(255,255,255,.35)!important;
}

.menu-grupo .menu-item.ativo{
    background:#004b8d!important;
    color:#fff!important;
    border-left-color:var(--orange)!important;
}

.menu-grupo .menu-item-disabled,
.menu-grupo .menu-item-disabled:hover{
    opacity:.58;
    cursor:not-allowed!important;
    transform:none!important;
    background:rgba(255,255,255,.035)!important;
    border-left-color:transparent!important;
    color:#cbd5e1!important;
}

.menu-grupo-atual{
    border-color:rgba(245,130,32,.55);
    box-shadow:0 0 0 1px rgba(245,130,32,.15);
}

.menu-grupo .btn-nova-oc{
    margin:0 0 5px!important;
    text-align:left!important;
    border-left-color:rgba(255,255,255,.45)!important;
}

.menu-grupo .btn-nova-oc.ativo{
    border-left-color:#fff!important;
    filter:none!important;
}

.rh-panel h3{
    color:var(--blue);
    margin-top:22px;
}

.rh-header{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:16px;
    margin-bottom:18px;
}

.rh-header p{
    color:var(--muted);
    margin:4px 0 0;
}

.rh-chart-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
    margin-top:20px;
}

.rh-chart-grid-3{
    grid-template-columns:repeat(3,minmax(0,1fr));
}

.rh-chart-box{
    background:#fff;
    border:1px solid var(--border);
    border-radius:14px;
    padding:16px;
    min-height:310px;
}

.rh-chart-box canvas{
    width:100%!important;
    height:240px!important;
}

.rh-info-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:16px;
}

.filter-row{
    display:grid;
    grid-template-columns:1fr auto auto;
    gap:10px;
    align-items:center;
    margin-bottom:16px;
}

.rh-feedback-filtros{
    grid-template-columns:1.5fr 220px auto;
    margin-top:14px;
}

.rh-status-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:92px;
    padding:6px 9px;
    border-radius:999px;
    font-size:12px;
    font-weight:800;
    white-space:nowrap;
}

.rh-status-badge.ok{
    background:#dcfce7;
    color:#166534;
}

.rh-status-badge.andamento{
    background:#dbeafe;
    color:#1d4ed8;
}

.rh-status-badge.pendente{
    background:#ffedd5;
    color:#c2410c;
}

.inline-check{
    display:flex;
    align-items:end;
}

.inline-check label{
    display:flex;
    align-items:center;
    gap:8px;
    text-transform:none;
    letter-spacing:0;
    font-size:13px;
}

.inline-check input{
    width:auto;
}

.rh-avaliacao-form{
    border:1px solid #1f4e79;
    background:#fff;
    padding:16px;
    border-radius:10px;
}

.rh-avaliacao-title{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    background:#0d3d75;
    color:#fff;
    padding:18px;
    border-radius:8px;
    margin-bottom:12px;
}

.rh-avaliacao-title h2{
    color:#fff;
    margin:0;
}

.rh-avaliacao-title span{
    font-size:12px;
    font-weight:800;
    text-align:right;
}

.rh-avaliacao-meta{
    display:grid;
    grid-template-columns:2fr 1fr 2fr 1fr;
    gap:8px;
    border:1px solid #cbd5e1;
    padding:10px;
    margin-bottom:12px;
}

.rh-avaliacao-meta p{
    margin:0;
}

.rh-avaliacao-form h3{
    background:#f58220;
    color:#fff;
    padding:10px;
    border-radius:6px;
    margin:14px 0 8px;
}

.rh-avaliacao-instrucao{
    white-space:pre-line;
    background:#f8fafc;
    border:1px solid #e2e8f0;
    padding:10px;
    border-radius:6px;
}

.rh-avaliacao-tabela th{
    background:#0d3d75;
    color:#fff;
}

.rh-avaliacao-tabela td:nth-child(1){
    width:210px;
    font-weight:800;
}

.rh-avaliacao-tabela td:nth-child(3),
.rh-avaliacao-tabela td:nth-child(4){
    width:90px;
    text-align:center;
}

.rh-avaliacao-media{
    text-align:right;
    font-size:18px;
    padding:10px;
    background:#eef6ff;
    border:1px solid #bfdbfe;
    border-radius:6px;
    margin-top:8px;
}

.rh-avaliacao-escala{
    display:grid;
    gap:6px;
    background:#f8fafc;
    border:1px solid #dbe4ef;
    border-radius:8px;
    padding:12px;
    margin:12px 0;
}

.rh-avaliacao-escala b{
    color:#0d3d75;
    text-transform:uppercase;
}

.rh-avaliacao-escala span{
    display:block;
    padding:6px 8px;
    border-left:4px solid #f58220;
    background:#fff;
    border-radius:5px;
}

.rh-assinatura-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
    margin:12px 0;
}

.rh-assinatura-card{
    background:#f8fafc;
    border:1px solid #dbe4ef;
    border-radius:10px;
    padding:12px;
}

.rh-assinatura-card h4{
    margin:0 0 10px;
    color:#0d3d75;
}

.rh-assinatura-card p{
    margin:5px 0;
    color:#475569;
    font-size:13px;
}

.rh-assinatura-foto{
    width:100%;
    max-height:220px;
    object-fit:cover;
    border-radius:8px;
    border:1px solid #cbd5e1;
    display:block;
    margin-bottom:8px;
}

.rh-assinatura-vazia{
    border:1px dashed #cbd5e1;
    border-radius:8px;
    padding:24px 12px;
    color:#64748b;
    text-align:center;
    background:#fff;
}

/* Área principal */
main{
    margin-left:268px!important;
    width:calc(100% - 268px)!important;
    padding:18px!important;
}

.topbar{
    border-radius:10px!important;
    box-shadow:none!important;
    border:1px solid var(--border)!important;
    padding:16px 18px!important;
    top:10px!important;
}

.topbar h1{
    font-size:24px!important;
    color:var(--blue)!important;
}

.topbar p{
    font-size:13px!important;
}

.userbox{
    border-radius:8px!important;
    background:#f8fafc!important;
    box-shadow:none!important;
}

.btn-voltar-topo{
    border-radius:7px!important;
}

/* Painéis e formulários */
.panel,.subpanel{
    border-radius:10px!important;
    box-shadow:none!important;
    border:1px solid var(--border)!important;
    padding:18px!important;
}

.panel h2,.subpanel h3{
    font-size:18px!important;
    color:var(--blue)!important;
    border-bottom:1px solid #e2e8f0;
    padding-bottom:10px;
}

.panel h2::before{
    content:none!important;
}

.subpanel{
    background:#fff!important;
}

label{
    font-size:11px!important;
    color:#334155!important;
}

input,select,textarea{
    border-radius:7px!important;
    padding:10px 11px!important;
}

button{
    border-radius:7px!important;
    box-shadow:none!important;
}

/* Cards ERP compactos */
.grid-cards{
    gap:10px!important;
    grid-template-columns:repeat(auto-fit,minmax(160px,1fr))!important;
}

.card{
    border-radius:9px!important;
    box-shadow:none!important;
    border:1px solid var(--border)!important;
    border-left:4px solid var(--blue)!important;
    padding:14px 15px!important;
    background:#fff!important;
    min-height:92px;
    position:relative;
    overflow:hidden;
}

.card::after{
    content:none!important;
    display:none!important;
}

.card span{
    font-size:11px!important;
    color:#64748b!important;
    text-transform:uppercase;
    letter-spacing:.03em;
}

.card strong{
    font-size:25px!important;
    margin-top:8px!important;
}

.money .card strong{
    font-size:18px!important;
}

.card.orange{border-left-color:var(--orange)!important}
.card.green{border-left-color:var(--green)!important}
.card.red{border-left-color:var(--red)!important}
.card.purple{border-left-color:var(--purple)!important}
.card.yellow{border-left-color:var(--yellow)!important}

/* Tabelas estilo ERP */
table{
    border-radius:8px!important;
    border:1px solid var(--border)!important;
    box-shadow:none!important;
    font-size:13px;
}

th{
    background:#eef2f7!important;
    color:#1f2937!important;
    font-size:11px!important;
    text-transform:uppercase;
    font-weight:900!important;
    border-bottom:1px solid var(--border)!important;
}

td,th{
    padding:9px 10px!important;
}

tbody tr:nth-child(even) td{
    background:#fbfdff!important;
}

tbody tr:hover td{
    background:#f1f5f9!important;
}

/* Status mais limpo */
.status{
    border-radius:999px!important;
    padding:5px 9px!important;
    font-size:11px!important;
}

/* Vias por fornecedor */
.vias-grid{
    gap:10px!important;
}

.via-card{
    border-radius:9px!important;
    border:1px solid var(--border)!important;
    border-left:4px solid var(--orange)!important;
    box-shadow:none!important;
    background:#fff!important;
}

.via-card:hover{
    transform:none!important;
    box-shadow:none!important;
}

.via-card button{
    width:100%;
    background:var(--blue)!important;
    color:#fff!important;
    text-align:center!important;
}

/* Linha do tempo mais corporativa */
.timeline-step span{
    box-shadow:none!important;
}

.timeline-step.active span{
    background:var(--orange)!important;
    box-shadow:none!important;
}

.flux-card{
    border-radius:10px!important;
    box-shadow:none!important;
    border:1px solid var(--border)!important;
}

.flux-status{
    border-radius:999px!important;
    background:#fff7ed!important;
}

/* Modal */
.modal-box{
    border-radius:12px!important;
    box-shadow:0 20px 45px rgba(15,23,42,.20)!important;
}

/* Impressão */
@media print{
    .sidebar,.topbar,.btn-voltar-topo,.userbox{
        display:none!important;
    }

    main{
        margin:0!important;
        width:100%!important;
        padding:0!important;
    }

    .panel,.subpanel{
        box-shadow:none!important;
        border:1px solid #ddd!important;
    }
}

/* Responsivo */
@media(max-width:900px){
    .rh-chart-grid,
    .rh-chart-grid-3,
    .rh-info-grid,
    .filter-row{
        grid-template-columns:1fr;
    }

    .sidebar{
        position:relative!important;
        width:100%!important;
    }

    main{
        margin-left:0!important;
        width:100%!important;
    }

    .sidebar .logout{
        position:relative!important;
        width:100%!important;
        left:auto!important;
        bottom:auto!important;
    }
}


/* Detalhe da OC em etapas */
.oc-detail-shell{
    display:block;
}

.oc-detail-header{
    background:#fff;
    border:1px solid var(--border);
    border-left:5px solid var(--blue);
    border-radius:10px;
    padding:18px;
    margin-bottom:12px;
    display:flex;
    justify-content:space-between;
    gap:16px;
    align-items:flex-start;
}

.oc-detail-header h2{
    margin:3px 0;
    color:var(--blue);
    font-size:26px;
}

.oc-detail-header p{
    margin:0;
    color:var(--muted);
    font-weight:700;
}

.oc-label{
    display:block;
    text-transform:uppercase;
    color:var(--muted);
    font-size:11px;
    font-weight:900;
    letter-spacing:.04em;
}

.oc-status-box{
    display:flex;
    flex-direction:column;
    gap:8px;
    align-items:flex-end;
}

.oc-summary-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:10px;
    margin-bottom:12px;
}

.oc-summary-card{
    background:#fff;
    border:1px solid var(--border);
    border-radius:9px;
    padding:12px;
}

.oc-summary-card span{
    display:block;
    font-size:11px;
    color:var(--muted);
    text-transform:uppercase;
    font-weight:900;
    margin-bottom:5px;
}

.oc-summary-card strong{
    font-size:16px;
    color:#111827;
}

.oc-summary-card.money strong{
    color:var(--blue);
    font-size:20px;
}

.oc-flow-line{
    display:grid;
    grid-template-columns:repeat(10, minmax(88px,1fr));
    gap:6px;
    background:#fff;
    border:1px solid var(--border);
    border-radius:10px;
    padding:10px;
    margin-bottom:12px;
    overflow:auto;
}

.oc-step-btn{
    background:#f8fafc!important;
    color:#334155!important;
    border:1px solid var(--border)!important;
    border-radius:8px!important;
    padding:9px 8px!important;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:5px;
    min-width:88px;
    text-align:center!important;
}

.oc-step-btn b{
    width:24px;
    height:24px;
    border-radius:50%;
    background:#e2e8f0;
    color:#334155;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:12px;
}

.oc-step-btn span{
    font-size:11px;
    font-weight:900;
}

.oc-step-btn.done b{
    background:var(--green);
    color:#fff;
}

.oc-step-btn.active{
    background:#fff7ed!important;
    border-color:#fed7aa!important;
    color:#9a4c00!important;
}

.oc-step-btn.active b{
    background:var(--orange);
    color:#fff;
}

.oc-step-content{
    display:none;
}

.oc-step-content.active{
    display:block;
}

.oc-actionbar{
    background:#fff;
    border:1px solid var(--border);
    border-radius:10px;
    padding:10px;
    margin-bottom:12px;
    display:flex;
    gap:8px;
    flex-wrap:wrap;
}

.oc-actionbar.compact{
    margin-top:14px;
}

.oc-field-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
    gap:10px;
}

.oc-field{
    background:#f8fafc;
    border:1px solid var(--border);
    border-radius:8px;
    padding:10px;
    min-height:62px;
}

.oc-field span{
    display:block;
    font-size:10px;
    text-transform:uppercase;
    color:var(--muted);
    font-weight:900;
    margin-bottom:5px;
}

.oc-field b{
    font-size:13px;
    color:#111827;
}

.oc-note{
    margin-top:12px;
    background:#fff;
    border:1px solid var(--border);
    border-left:4px solid var(--orange);
    border-radius:8px;
    padding:12px;
}

.oc-note b{
    color:var(--blue);
}

.oc-note p{
    margin:6px 0 0;
    color:#334155;
}

.oc-docs{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin:10px 0;
}

.empty-step{
    background:#f8fafc;
    border:1px dashed var(--border);
    border-radius:8px;
    padding:18px;
    text-align:center;
    color:var(--muted);
    font-weight:800;
}

@media(max-width:1100px){
    .oc-flow-line{
        grid-template-columns:repeat(5, minmax(88px,1fr));
    }
}

@media(max-width:700px){
    .oc-detail-header{
        display:block;
    }

    .oc-status-box{
        align-items:flex-start;
        margin-top:12px;
    }

    .oc-flow-line{
        grid-template-columns:repeat(2, minmax(88px,1fr));
    }
}

.vias-box > .primary{
    margin:8px 0 12px;
}

#boxOSInterna{
    transition:.18s ease;
}

.recebimento-itens-panel{
    border-left:5px solid var(--orange)!important;
}

.recebimento-head{
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:flex-start;
    margin-bottom:14px;
}

.recebimento-head h2{
    margin-bottom:4px!important;
}

.recebimento-head p{
    margin:0;
    color:var(--muted);
    font-weight:700;
}

.recebimento-actions{
    display:flex;
    justify-content:flex-end;
    margin-top:14px;
}

.recebimento-itens-panel input,
.recebimento-itens-panel select{
    min-width:90px;
}

.recebimento-itens-panel small{
    color:var(--muted);
    font-weight:700;
}

@media(max-width:900px){
    .recebimento-head{
        display:block;
    }
}

/* Tela planilha de recebimento */
.recebimento-modal{
    display:none;
    position:fixed;
    inset:0;
    background:rgba(15,23,42,.62);
    z-index:9999;
    align-items:center;
    justify-content:center;
    padding:18px;
}

.recebimento-modal-box{
    width:96vw;
    max-width:1500px;
    height:92vh;
    background:#f4f6f9;
    border-radius:12px;
    overflow:hidden;
    box-shadow:0 25px 70px rgba(0,0,0,.35);
}

.recebimento-planilha{
    height:100%;
    display:flex;
    flex-direction:column;
}

.recebimento-planilha-top{
    background:#003b71;
    color:white;
    padding:16px 20px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
}

.recebimento-planilha-top span{
    display:block;
    font-size:11px;
    text-transform:uppercase;
    font-weight:900;
    color:#cbd5e1;
}

.recebimento-planilha-top h2{
    margin:3px 0;
    font-size:24px;
}

.recebimento-planilha-top p{
    margin:0;
    color:#e2e8f0;
    font-weight:700;
}

.recebimento-planilha-top button{
    background:#f58220!important;
    color:white!important;
}

.recebimento-kpis{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:10px;
    padding:12px;
    background:#fff;
    border-bottom:1px solid #d7dee8;
}

.recebimento-kpis div{
    background:#f8fafc;
    border:1px solid #d7dee8;
    border-radius:8px;
    padding:10px 12px;
}

.recebimento-kpis span{
    display:block;
    font-size:10px;
    text-transform:uppercase;
    font-weight:900;
    color:#64748b;
}

.recebimento-kpis b{
    color:#003b71;
    font-size:22px;
}

.recebimento-form{
    display:grid;
    grid-template-columns:1fr 1fr 2fr;
    gap:10px;
    padding:12px;
    background:#fff;
    border-bottom:1px solid #d7dee8;
}

.recebimento-table-wrap{
    flex:1;
    overflow:auto;
    padding:12px;
}

.recebimento-spreadsheet{
    min-width:1250px;
    border-collapse:collapse;
    background:white;
}

.recebimento-spreadsheet th{
    position:sticky;
    top:0;
    z-index:2;
    background:#eef2f7!important;
    color:#1f2937!important;
    border:1px solid #d7dee8;
}

.recebimento-spreadsheet td{
    border:1px solid #d7dee8;
    background:#fff;
    vertical-align:middle;
}

.recebimento-spreadsheet .col-num,
.recebimento-spreadsheet .col-qtd{
    text-align:center;
    font-weight:800;
}

.recebimento-spreadsheet .saldo{
    color:#b91c1c;
}

.recebimento-spreadsheet input,
.recebimento-spreadsheet select{
    border-radius:4px!important;
    padding:7px!important;
    min-width:90px;
}

.recebimento-spreadsheet small{
    display:block;
    color:#64748b;
    font-weight:700;
    margin-top:2px;
}

.recebimento-spreadsheet .linha-recebida td{
    background:#f0fdf4!important;
}

.recebimento-footer{
    display:flex;
    justify-content:flex-end;
    gap:10px;
    padding:12px;
    background:#fff;
    border-top:1px solid #d7dee8;
}

.recebimento-historico{
    padding:12px;
    background:#fff;
    max-height:220px;
    overflow:auto;
    border-top:1px solid #d7dee8;
}

.recebimento-planilha-loading{
    padding:30px;
}

@media(max-width:900px){
    .recebimento-modal-box{
        width:100vw;
        height:100vh;
        border-radius:0;
    }

    .recebimento-kpis,
    .recebimento-form{
        grid-template-columns:1fr;
    }
}

.oc-actionbar .hint{
    display:inline-flex;
    align-items:center;
    background:#f8fafc;
    border:1px solid var(--border);
    border-left:4px solid var(--green);
    border-radius:8px;
    padding:9px 12px;
    color:#334155;
    font-weight:800;
}

.permission-card{
    border-left:4px solid var(--blue)!important;
}

.permissao-grid{
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr))!important;
}

.permissao-grid label{
    background:#f8fafc;
    border:1px solid var(--border);
    border-radius:8px;
    padding:12px;
    font-size:14px!important;
    text-transform:none!important;
    letter-spacing:0!important;
}

.permissao-grid input{
    width:auto!important;
    margin-right:8px;
}

.permission-module-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:16px;
    margin-top:16px;
}

.permission-module-card{
    background:#f8fafc;
    border:1px solid var(--border);
    border-radius:16px;
    padding:16px;
}

.permission-module-head{
    display:flex;
    gap:12px;
    align-items:flex-start;
    justify-content:space-between;
    margin-bottom:12px;
    cursor:pointer;
    list-style:none;
}

.permission-module-head::-webkit-details-marker{
    display:none;
}

.permission-module-head strong{
    display:block;
    color:var(--blue);
    font-size:15px;
    font-weight:900;
}

.permission-module-head span{
    display:block;
    color:var(--muted);
    font-size:12px;
    font-weight:700;
    margin-top:4px;
    line-height:1.35;
}

.permission-module-head em{
    color:var(--blue);
    font-size:12px;
    font-style:normal;
    font-weight:900;
    white-space:nowrap;
}

.permission-module-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin:10px 0 12px;
}

.permission-module-actions button{
    width:auto;
    padding:8px 10px;
    font-size:12px;
}

.permission-screen-list{
    display:grid;
    gap:8px;
}

.permission-screen-list label{
    display:flex;
    align-items:center;
    gap:8px;
    background:#fff;
    border:1px solid var(--border);
    border-radius:10px;
    padding:10px;
    margin:0;
    text-transform:none;
    letter-spacing:0;
    font-size:13px;
}

.permission-screen-list input{
    width:auto;
}

.modulo-preparacao{
    border-left:6px solid var(--blue);
    background:
        radial-gradient(circle at top right, rgba(0,83,155,.10), transparent 34%),
        #fff;
}

.modulo-status{
    display:inline-flex;
    align-items:center;
    background:#e0f2fe;
    color:#075985;
    border:1px solid #bae6fd;
    border-radius:999px;
    padding:7px 12px;
    font-size:12px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.04em;
}

.modulo-preparacao h2{
    margin-top:16px;
}

.modulo-preparacao-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:14px;
    margin-top:18px;
}

.modulo-preparacao-grid div{
    background:#f8fafc;
    border:1px solid var(--border);
    border-radius:14px;
    padding:16px;
}

.modulo-preparacao-grid b{
    display:block;
    color:var(--blue);
    margin-bottom:6px;
}

.modulo-preparacao-grid span{
    color:var(--muted);
    font-weight:700;
}

.notify-float{
    position:fixed;
    right:22px;
    bottom:22px;
    z-index:50;
    background:#003b71!important;
    color:white!important;
    border-radius:999px!important;
    box-shadow:0 12px 30px rgba(15,23,42,.25)!important;
}

.notify-float span{
    display:inline-flex;
    min-width:22px;
    height:22px;
    border-radius:50%;
    background:#f58220;
    align-items:center;
    justify-content:center;
    margin-left:6px;
}

.modal-notificacoes{
    width:620px!important;
    max-height:85vh;
    overflow:auto;
}

.notificacao-item{
    border:1px solid var(--border);
    border-left:4px solid var(--orange);
    border-radius:10px;
    padding:12px;
    margin-bottom:10px;
    background:#fff;
}

.notificacao-item.lida{
    opacity:.65;
    border-left-color:#94a3b8;
}

.notificacao-item b{
    color:var(--blue);
}

.notificacao-item p{
    margin:6px 0;
    color:#334155;
}

.notificacao-item small{
    display:block;
    color:var(--muted);
    margin-bottom:8px;
}

.email-test-card{
    margin:16px 0;
    border:1px solid var(--border);
    border-left:4px solid var(--orange);
    border-radius:10px;
    background:#fff;
    padding:16px;
}

.email-test-card h3{
    margin:0 0 6px;
    color:var(--blue);
}

.email-test-card p{
    margin:0 0 12px;
    color:var(--muted);
    font-weight:700;
}

.email-test-result{
    margin-top:10px;
    padding:10px 12px;
    border-radius:8px;
    background:#f8fafc;
    color:#334155;
    font-weight:800;
}

.email-test-result.ok{
    background:#dcfce7;
    color:#166534;
}

.email-test-result.erro{
    background:#fee2e2;
    color:#991b1b;
}

/* Módulos de recebimento cego, auditoria, devoluções e estoque */
.dashboard-bloco-titulo{
    margin:20px 0 9px;
    color:var(--blue);
    font-size:17px;
}

.acoes-tabela{
    min-width:270px;
}

.acoes-tabela button{
    margin:2px;
    padding:7px 9px;
}

.recebimento-cego-grid,
.devolucao-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(290px,1fr));
    gap:15px;
}

.recebimento-cego-card,
.devolucao-card{
    background:#fff;
    border:1px solid var(--border);
    border-left:5px solid var(--blue);
    border-radius:14px;
    padding:17px;
    box-shadow:0 8px 24px rgba(15,23,42,.07);
}

.recebimento-cego-card{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:15px;
}

.recebimento-cego-card span,
.devolucao-card > span{
    display:inline-block;
    color:var(--blue);
    font-size:11px;
    font-weight:900;
    text-transform:uppercase;
}

.recebimento-cego-card h3,
.devolucao-card h3{
    margin:5px 0;
}

.recebimento-cego-card p,
.devolucao-card p{
    margin:5px 0 12px;
    color:var(--muted);
}

.alerta-divergencia{
    border-left-color:var(--red)!important;
    background:#fffafa!important;
}

.devolucao-card{
    border-left-color:var(--orange);
}

.devolucao-card > div:last-child{
    display:flex;
    flex-wrap:wrap;
    gap:7px;
}

.auditoria-qtd{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:8px;
    margin:12px 0;
}

.auditoria-qtd b{
    background:#f8fafc;
    border:1px solid var(--border);
    border-radius:8px;
    padding:9px;
    font-size:12px;
}

.recebimento-cego-tabela{
    min-width:950px;
}

.empty-state{
    padding:22px;
    border:1px dashed var(--border);
    border-radius:10px;
    text-align:center;
    color:var(--muted);
    background:#f8fafc;
}

.estoque-submodulos{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin:0 0 14px;
}

.estoque-submodulos button{
    background:#e2e8f0;
    color:#334155;
}

.estoque-submodulos button.ativo{
    background:var(--blue);
    color:#fff;
}

.lista-anexos-nova-oc{
    display:grid;
    gap:8px;
    margin-top:12px;
}

.anexo-nova-oc{
    display:grid;
    grid-template-columns:150px 1fr auto;
    align-items:center;
    gap:10px;
    padding:10px 12px;
    border:1px solid var(--border);
    border-radius:9px;
    background:#f8fafc;
}

@media(max-width:900px){
    .recebimento-cego-card{
        display:block;
    }
    .recebimento-cego-card button{
        margin-top:10px;
    }
    .auditoria-qtd{
        grid-template-columns:1fr;
    }
    .anexo-nova-oc{
        grid-template-columns:1fr;
    }
    .rh-assinatura-grid,
    .rh-avaliacao-meta{
        grid-template-columns:1fr;
    }
}

@media(max-width:760px){
    .rh-header,
    .rh-avaliacao-title{
        display:grid;
        grid-template-columns:1fr;
        gap:10px;
    }

    .rh-header .actions-row,
    .rh-avaliacao-form .actions-row{
        display:grid;
        grid-template-columns:1fr;
        width:100%;
    }

    .rh-header button,
    .rh-avaliacao-form button{
        width:100%;
    }

    .rh-panel{
        padding:14px!important;
    }

    .rh-chart-grid,
    .rh-chart-grid-3,
    .rh-info-grid,
    .filter-row{
        grid-template-columns:1fr!important;
    }

    .rh-chart-box{
        min-height:240px;
    }

    .rh-avaliacao-form{
        padding:12px;
        border-radius:12px;
        overflow:hidden;
    }

    .rh-avaliacao-title{
        padding:14px;
        text-align:left;
    }

    .rh-avaliacao-title h2{
        font-size:20px;
    }

    .rh-avaliacao-title span{
        text-align:left;
    }

    .rh-avaliacao-form h3{
        font-size:15px;
        line-height:1.3;
    }

    .rh-avaliacao-tabela{
        display:block!important;
        width:100%;
        white-space:normal!important;
        overflow:visible!important;
    }

    .rh-avaliacao-tabela thead{
        display:none;
    }

    .rh-avaliacao-tabela tbody,
    .rh-avaliacao-tabela tr{
        display:block;
        width:100%;
    }

    .rh-avaliacao-tabela tr{
        border:1px solid #dbe4ef;
        border-radius:12px;
        overflow:hidden;
        margin-bottom:12px;
        background:#fff;
    }

    .rh-avaliacao-tabela td{
        display:grid;
        grid-template-columns:104px minmax(0,1fr);
        gap:8px;
        width:100%!important;
        border:0!important;
        border-bottom:1px solid #e2e8f0!important;
        text-align:left!important;
        white-space:normal;
        word-break:break-word;
    }

    .rh-avaliacao-tabela td:last-child{
        border-bottom:0!important;
    }

    .rh-avaliacao-tabela td::before{
        color:#0d3d75;
        font-weight:800;
    }

    .rh-avaliacao-tabela td:nth-child(1)::before{content:"Critério";}
    .rh-avaliacao-tabela td:nth-child(2)::before{content:"Descrição";}
    .rh-avaliacao-tabela td:nth-child(3)::before{content:"Peso";}
    .rh-avaliacao-tabela td:nth-child(4)::before{content:"Nota";}

    .rh-avaliacao-tabela select{
        width:100%;
        min-height:42px;
    }

    .rh-avaliacao-media{
        text-align:left;
        font-size:16px;
    }
}
.pecas-estoque-box,
.estoque-solicitacoes,
.checklist-mensal-resposta{
    border:1px solid #dbe4f0;
    border-radius:14px;
    background:#f8fafc;
    padding:14px;
    margin:14px 0;
}

.peca-solicitada{
    display:flex;
    justify-content:space-between;
    gap:12px;
    padding:8px 10px;
    margin-top:8px;
    border-radius:10px;
    background:#fff;
    border:1px solid #e5e7eb;
}

.peca-solicitada.alerta{
    border-color:#f97316;
    background:#fff7ed;
}

.link-btn{
    background:none;
    border:0;
    color:#2563eb;
    padding:0;
    font-weight:700;
    cursor:pointer;
    text-decoration:underline;
}

.modal-estoque-acao{
    max-width:980px;
    width:min(96vw,980px);
    max-height:88vh;
    overflow:auto;
}
