:root{
  --bg:#eef2f7;
  --surface:#f7f9fc;
  --card-bg:#ffffff;
  --card-border:#e1e7f0;
  --card-shadow:0 14px 32px rgba(15,23,42,0.08),0 4px 10px rgba(15,23,42,0.04);
  --card-radius:20px;
  --card-pad:clamp(22px,3.2vw,40px);
  --card-head:#f6f8fc;
  --text:#1f2937;
  --muted:#6b7280;
  --blue:#0b3a67;
  --blue-ghost:rgba(11,58,103,0.16);
  --border:#e3e9f2;
  --shadow-sm:0 8px 20px rgba(15,23,42,0.08);
  --shadow-md:0 18px 45px rgba(15,23,42,0.12);
  --radius-lg:18px;
  --radius-md:14px;
  --radius-sm:10px;
  --font-body:"Plus Jakarta Sans","Noto Sans",sans-serif;
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;
  --space-7:32px;
  --space-8:40px;
  --control-height:42px;
  --control-radius:12px;
  --primary:var(--blue);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);font-family:var(--font-body);color:var(--text);min-height:100vh;line-height:1.4}
input, select, textarea, button{max-width:100%;font-family:inherit}
input, select, textarea{min-width:0}
button{min-width:0}
body:not(.auth-mode){
  background:
    radial-gradient(1200px 800px at 85% -10%, rgba(11,58,103,0.12), transparent 60%),
    radial-gradient(900px 520px at 0% 0%, rgba(15,23,42,0.06), transparent 55%),
    linear-gradient(180deg,#eef2f7 0%,#f7f8fb 100%);
}
.auth-mode{background:#eef2f8;min-height:100vh;padding:0;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica,Arial,sans-serif;}
.login-layout{display:flex;min-height:100vh;flex-wrap:wrap;background:#eef2f8;}
.login-hero{
  flex:1 1 55%;
  min-height:100vh;
  padding:70px 70px 80px;
  background:linear-gradient(135deg,#021129 0%,#082756 55%,#0b3f7b 100%);
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  position:relative;
}
.login-hero::after{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 20% 20%,rgba(255,255,255,0.18),transparent 50%);
  pointer-events:none;
}
.hero-copy{
  max-width:420px;
  margin-top:40px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.hero-accent{
  display:inline-block;
  width:140px;
  height:5px;
  border-radius:999px;
  background:rgba(255,255,255,0.35);
}
.hero-copy h1{
  font-size:46px;
  margin:0;
  font-weight:700;
}
.hero-copy p{
  margin:0;
  font-size:18px;
  color:rgba(255,255,255,0.85);
}
.login-card{
  flex:1 1 45%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:40px 60px;
  text-align:center;
}
.login-form{
  width:100%;
  max-width:420px;
  background:rgba(255,255,255,0.98);
  border-radius:28px;
  box-shadow:0 30px 70px rgba(15,23,42,0.22);
  padding:44px 38px 34px;
  display:flex;
  flex-direction:column;
  gap:16px;
  margin:0 auto;
  border:1px solid #f0f4fb;
}
.login-card__logo{margin-bottom:6px;}
.login-card__logo img{height:54px;width:auto;}
.login-form__title{
  font-size:20px;
  font-weight:600;
  color:#0b2545;
}
.login-field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569;}
.login-field span{font-weight:600;}
.login-form .input{
  border-radius:16px;
  border:1px solid #cfd8e3;
  padding:12px 14px;
}
.login-form .btn.primary{
  border-radius:16px;
  width:100%;
  justify-content:center;
  background:#0b3f7b;
  box-shadow:0 18px 35px rgba(11,63,123,0.28);
}
.login-form .btn.primary:hover{filter:brightness(1.05);}
.login-footer{
  font-size:13px;
  color:#6b7a88;
  text-align:center;
  margin-top:18px;
}
.auth-error{color:#ef4444;margin:8px 0 0;font-size:14px;min-height:18px;text-align:left;width:100%;max-width:420px;}
@media (max-width:960px){
  .login-layout{flex-direction:column;}
  .login-hero{min-height:320px;padding:50px 40px;}
  .login-card{padding:30px;align-items:center;}
  .login-form{max-width:100%;}
}
.app-shell{display:flex;min-height:100vh}
.sidebar{
  width:260px;
  background:var(--card-bg);
  border-right:1px solid var(--border);
  padding:22px 18px;
  display:flex;
  flex-direction:column;
  gap:8px;
  position:sticky;
  top:0;
  height:100vh;
  overflow:visible;
}
.sidebar-top{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
  position:relative;
  padding-right:32px;
}
.sidebar-logo{width:160px;max-width:100%;height:auto;object-fit:contain}
.sidebar-toggle{
  position:absolute;
  right:-16px;
  top:22px;
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid var(--card-border);
  background:#ffffff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:var(--shadow-sm);
  transition:transform .12s ease,box-shadow .12s ease;
}
.sidebar-toggle__icon{
  display:block;
  width:10px;
  height:10px;
  border-right:2px solid #475569;
  border-bottom:2px solid #475569;
  transform:rotate(135deg);
  transition:transform .18s ease;
  margin-left:2px;
}
.sidebar-toggle:hover{box-shadow:var(--shadow-md)}
.sidebar-scroll{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:8px;
  overflow-y:auto;
  padding-right:4px;
  flex:1;
}
.content{
  flex:1;
  min-width:0;
  padding:32px 40px 56px;
  overflow-x:hidden;
  max-width:1480px;
  margin:0 auto;
  width:100%;
}

body.sidebar-collapsed .sidebar{width:82px}
body.sidebar-collapsed .sidebar-top{justify-content:center;flex-direction:column;gap:12px;padding-right:0}
body.sidebar-collapsed .sidebar-logo{width:36px}
body.sidebar-collapsed .sidebar-scroll{align-items:center}
body.sidebar-collapsed .menu .item{justify-content:center}
body.sidebar-collapsed .menu .item-label{display:none}
body.sidebar-collapsed .menu .item{padding:10px}
body.sidebar-collapsed .menu .item .item-icon{margin:0}
body.sidebar-collapsed .menu-group__title{display:none}
body.sidebar-collapsed .menu .item.item-sub{padding:10px}
body.sidebar-collapsed .menu-caret{display:none}
body.sidebar-collapsed .sidebar-toggle__icon{transform:rotate(-45deg)}

.card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--card-radius);
  box-shadow:var(--card-shadow);
  overflow:hidden;
}
.card .hd{
  padding:16px var(--card-pad);
  font-weight:600;
  border-bottom:1px solid var(--card-border);
  font-size:15px;
  color:#1f2a44;
  background:linear-gradient(180deg,var(--card-head) 0%,#fff 100%);
}
.card .bd{
  padding:var(--card-pad);
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
}

#main.card{background:transparent;border:0;box-shadow:none;animation:none;transform:none;overflow:visible}
#main .bd{padding:0;display:flex;flex-direction:column;gap:var(--space-6)}

.page-title{
  font-size:24px;
  font-weight:700;
  margin:0 0 var(--space-5);
  color:#0f172a;
}
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:var(--space-5);
  margin-bottom:var(--space-6);
}
.kpi-card{
  position:relative;
  min-width:0;
  border:1px solid #dbe4f2;
  box-shadow:0 14px 28px rgba(15,23,42,0.08);
  background:#ffffff;
}
.kpi-card .bd{
  padding:22px 24px;
  min-height:116px;
}
.kpi-card__body{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.kpi-card__text{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:0;
}
.kpi-card__label{
  text-transform:uppercase;
  letter-spacing:0.08em;
  font-size:12px;
  color:#64748b;
  font-weight:600;
}
.kpi-card__value{
  font-size:clamp(26px,3.4vw,40px);
  font-weight:800;
  line-height:1.05;
  color:#0f172a;
  overflow-wrap:anywhere;
  font-variant-numeric:tabular-nums;
}
.kpi-card__icon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.kpi-card__icon svg{width:22px;height:22px}
.kpi-card--primary{
  border-top:3px solid #0b3a67;
  background:linear-gradient(135deg,#ffffff 0%,#f5f8ff 100%);
}
.kpi-card--primary .kpi-card__icon{
  background:rgba(11,58,103,0.12);
  color:#0b3a67;
}
.kpi-card--info{
  border-top:3px solid #2563eb;
  background:linear-gradient(135deg,#ffffff 0%,#f4f7ff 100%);
}
.kpi-card--info .kpi-card__icon{
  background:rgba(37,99,235,0.14);
  color:#1d4ed8;
}
.kpi-card--warning{
  border-top:3px solid #f59e0b;
  background:linear-gradient(135deg,#ffffff 0%,#fff7ed 100%);
}
.kpi-card--warning .kpi-card__icon{
  background:rgba(245,158,11,0.18);
  color:#b45309;
}

.med-cad-wrapper > * + *{
  margin-top:16px;
}

.menu .item{
  display:flex;
  align-items:center;
  gap:12px;
  width:100%;
  text-align:left;
  padding:10px 12px;
  border:1px solid transparent;
  border-radius:12px;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  font-weight:500;
  font-family:inherit;
  transition:background .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease;
}
.menu-group{
  display:flex;
  flex-direction:column;
  gap:6px;
  width:100%;
}
.menu-group + .menu-group{margin-top:4px}
.menu-group__title{
  padding:6px 12px 2px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.14em;
  color:#94a3b8;
  font-weight:600;
}
.menu-group__toggle{
  position:relative;
}
.menu-caret{
  margin-left:auto;
  width:10px;
  height:10px;
  border-right:2px solid #94a3b8;
  border-bottom:2px solid #94a3b8;
  transform:rotate(-45deg);
  transition:transform .12s ease;
}
.menu-group.is-open .menu-caret{
  transform:rotate(45deg);
}
.menu-group__items{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.menu-group__items[hidden]{display:none}
.menu .item.item-sub{
  padding-left:18px;
}
.menu .item.item-sub .item-icon{
  width:30px;
  height:30px;
  border-radius:9px;
}
.menu .item .item-icon{
  width:34px;
  height:34px;
  border-radius:10px;
  background:#edf1f7;
  color:#4b5563;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.menu .item .item-label{
  flex:1;
  min-width:0;
}
.menu .item .item-icon svg{
  width:18px;
  height:18px;
}
.menu .item:hover{
  background:#f3f6fb;
  border-color:#e1e7f0;
}
.menu .item:hover .item-icon{
  background:#e8eef7;
}
.menu .item.active{
  background:#e8f1fb;
  border-color:#d4e2f5;
  color:var(--blue);
  font-weight:600;
}
.menu .item.active .item-icon{
  background:#d7e6f7;
  color:var(--blue);
}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;padding:10px 16px;border:0;background:linear-gradient(135deg,var(--blue),#082b4c);color:#fff;font-weight:600;cursor:pointer;letter-spacing:0.2px;box-shadow:0 10px 24px rgba(11,58,103,0.25);transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}
.btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn:disabled{background:#9aa4b2;cursor:not-allowed;box-shadow:none}
.btn-outline{background:#fff;color:var(--blue);border:1px solid rgba(11,58,103,0.4);box-shadow:none}
.btn-outline:hover{background:var(--blue);color:#fff}
.btn-neutral{background:#6b7280;color:#fff;box-shadow:none}
.btn-neutral:hover{filter:brightness(1.08)}
.btn-success{background:#128a6a;color:#fff;box-shadow:0 10px 20px rgba(18,138,106,0.25)}
.btn-success:hover{background:#0f775b}
body:not(.auth-mode) .btn{padding:9px 14px;font-size:13px;border-radius:10px;letter-spacing:0;min-height:36px;line-height:1.1}
body:not(.auth-mode) .btn.btn-sm{padding:6px 10px;font-size:12px;min-height:30px}
body:not(.auth-mode) .btn.btn-xs{padding:4px 8px;font-size:11px;border-radius:8px;min-height:26px}
body:not(.auth-mode) .btn{white-space:normal;line-height:1.1}

/* --- Correção do Patch v3 --- */
.btn-danger {
  background: #ef4444; /* Vermelho */
}
.btn-danger:hover {
  background: #dc2626;
}

/* --- Botão Pequeno (Patch v3) --- */
.btn-sm {
  padding: 6px 10px;
  font-weight: 500;
  border-radius: 8px;
}

.input, select, textarea{
  display:block;
  width:100%;
  min-height:var(--control-height);
  padding:10px 14px;
  border:1px solid #d6e0ee;
  border-radius:var(--control-radius);
  background:#ffffff;
  font-family:inherit;
  font-size:14px;
  color:var(--text);
  transition:border-color .12s ease,box-shadow .12s ease,background .12s ease;
  box-shadow:inset 0 1px 1px rgba(15,23,42,0.04);
}
.input:focus, select:focus, textarea:focus{
  border-color:var(--blue);
  outline:none;
  box-shadow:0 0 0 3px rgba(11,58,103,0.18);
  background:#fff;
}
.input-sm{padding:8px 12px;font-size:13px}
label{display:block;margin-bottom:6px;font-size:13px;font-weight:600;color:#475569}
form[style*="grid-template-columns"]{
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr)) !important;
  align-items:stretch;
  gap:18px !important;
}
.card .bd [style*="grid-template-columns"]{
  gap:18px !important;
}
form[style*="grid-template-columns"] .btn,
form[style*="grid-template-columns"] button{
  justify-self:start;
  width:auto;
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:var(--space-4);
  align-items:start;
}
.form-grid--wide{
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
}
.form-grid--compact{
  gap:var(--space-3);
}
.form-grid .full{
  grid-column:1 / -1;
}
.form-stack{
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
}
.form-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--card-border);border-radius:var(--radius-md);overflow:hidden;background:var(--card-bg)}
.table th{text-align:left;font-size:12px;padding:12px 12px;color:var(--muted);border-bottom:1px solid var(--card-border);text-transform:uppercase;letter-spacing:0.08em}
.table td{padding:12px 12px;border-bottom:1px solid rgba(15,23,42,0.06);font-size:14px}
.table thead tr{background:var(--surface)}
.table thead th{color:#3a4656;font-weight:600;border-bottom:1px solid var(--card-border)}
.table tbody tr:nth-child(odd){background:#ffffff}
.table tbody tr:nth-child(even){background:var(--surface)}
.table tbody tr:hover{background:rgba(11,58,103,0.08)}
.table tr:last-child td{border-bottom:0}
.table .row-actions { display:flex; justify-content:flex-end; gap:6px; flex-wrap:wrap; }
.table .row-actions .btn{margin:0}
.table-actions{display:flex;justify-content:flex-end;gap:10px;margin-bottom:0;flex-wrap:wrap;align-items:center}
.table-actions .input{max-width:280px}
.table-actions .input[type="search"]{
  min-height:var(--control-height);
  padding:9px 16px 9px 40px;
  border-radius:999px;
  border-color:#d9e3f1;
  background-color:#f4f7fb;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:14px center;
  background-size:16px;
  box-shadow:inset 0 1px 1px rgba(15,23,42,0.05),0 10px 20px rgba(15,23,42,0.08);
}
.table-actions .input[type="search"]::placeholder{color:#94a3b8}
.table-actions .input[type="search"]:focus{
  background-color:#fff;
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(11,58,103,0.12),0 12px 22px rgba(15,23,42,0.08);
}
.page-message{margin-bottom:12px;min-height:18px;font-size:14px}
.section-divider{margin:var(--space-7) 0;height:1px;background:linear-gradient(90deg,transparent,rgba(15,23,42,0.12),transparent)}
.user-grid{
  display:flex;
  flex-direction:column;
  gap:var(--space-6);
}
.user-form-grid{
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
}
.user-table .table-container{
  max-height:480px;
}
.user-table .table td{vertical-align:middle}

/* --- Indicadores de Status (Patch v2) --- */
.card .hd.status-vencendo {
  border-left: 4px solid #f59e0b;
  padding-left: 14px;
  background:linear-gradient(90deg,rgba(245,158,11,0.12) 0%,var(--card-head) 40%,#fff 100%);
}
.card .hd.status-andamento {
  border-left: 4px solid #10b981;
  padding-left: 14px;
  background:linear-gradient(90deg,rgba(16,185,129,0.12) 0%,var(--card-head) 40%,#fff 100%);
}
.card .hd.status-encerrado {
  border-left: 4px solid #ef4444;
  padding-left: 14px;
  background:linear-gradient(90deg,rgba(239,68,68,0.12) 0%,var(--card-head) 40%,#fff 100%);
}
.card .hd.status-parcelas {
  border-left: 4px solid #2563eb;
  padding-left: 14px;
  background:linear-gradient(90deg,rgba(37,99,235,0.12) 0%,var(--card-head) 40%,#fff 100%);
}

/* --- Scroll nas Tabelas (Patch v3) --- */
.table-container {
  max-height: 300px;
  overflow-y: auto;
  overflow-x: auto;
}

/* --- Filtros de Relatório (Patch v4) --- */
.filters {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: flex-end;
  padding: 16px 18px;
  border: 1px solid var(--card-border);
  border-radius: var(--radius-md);
  background: var(--surface);
  margin-bottom: 16px;
}
.filters--rel label{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:13px;
  color:var(--muted);
}
.filter-range{
  display:flex;
  align-items:center;
  gap:6px;
}
.filter-range__sep{
  font-size:12px;
  color:var(--muted);
}
.filter-actions{
  display:flex;
  gap:10px;
  margin-left:auto;
}
.rel-indicators-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:var(--space-5);
  margin:var(--space-5) 0;
}
.rel-indicator-value{
  font-size:36px;
  font-weight:700;
  color:var(--blue);
}
.rel-chart-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:var(--space-5);
  margin-bottom:var(--space-6);
}
.report-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:8px;
  border:1px solid var(--card-border);
  border-radius:999px;
  background:var(--card-bg);
  box-shadow:var(--shadow-sm);
  width:max-content;
  max-width:100%;
  margin:var(--space-4) 0 var(--space-5);
}
.report-tab{
  border:0;
  background:transparent;
  color:var(--muted);
  font-weight:600;
  padding:6px 14px;
  border-radius:999px;
  cursor:pointer;
  font-size:13px;
  transition:background .12s ease,color .12s ease,box-shadow .12s ease;
}
.report-tab.is-active{
  background:linear-gradient(135deg,#0b3a67,#14508f);
  color:#fff;
  box-shadow:0 8px 18px rgba(11,58,103,0.25);
}
.report-panel{display:flex;flex-direction:column;gap:var(--space-5)}
.report-panel[hidden]{display:none}
.report-panels{display:flex;flex-direction:column;gap:var(--space-6)}
.chart-shell{
  position:relative;
  width:100%;
  height:340px;
}
.chart-shell--compact{height:280px}
.chart-shell--wide{height:380px}
.chart-shell canvas{
  width:100% !important;
  height:100% !important;
  display:block;
}
.chart-controls{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin-bottom:12px;
}
.chart-controls label{
  font-size:13px;
  font-weight:600;
  color:var(--muted);
}
.report-section-title{
  margin:0 0 12px 0;
  font-size:16px;
  font-weight:600;
  color:#1f2a44;
}
}
.rel-tempo-table th,
.rel-tempo-table td{
  font-size:13px;
  padding:8px 10px;
}
.contract-attachments-block{
  margin-top:16px;
  border-top:1px solid var(--border);
  padding-top:12px;
}
.contract-attachments__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:10px;
}
.contract-attachments__header h4{
  margin:0;
  font-size:16px;
}
.contract-attachments__body{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.attachment-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  border:1px solid var(--border);
  border-radius:10px;
  padding:10px 12px;
}
.attachment-item .muted{
  font-size:12px;
}

/* --- Estilos Gerenciamento O.C. (Patch v6) --- */
.oc-grid {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 20px;
  min-height: 60vh;
}
.oc-tip{margin:0 0 12px;font-size:13px;line-height:1.4}
.oc-sidebar .card {
  margin-bottom: 16px;
}
.oc-insumo-list .item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  font-weight: 500;
  border-radius: 0;
}
.oc-insumo-list .item:first-child { border-radius: 8px 8px 0 0;}
.oc-insumo-list .item:last-child { border-bottom: none; border-radius: 0 0 8px 8px;}
.oc-insumo-list .item:hover {
  background: var(--bg);
}
.oc-insumo-list .item.active {
  background: var(--blue-ghost);
  color: var(--blue);
  font-weight: 600;
}
.oc-insumo-list .btn-del-insumo {
  background: none; border: none; color: var(--muted); cursor: pointer;
  display: none;
}
.oc-insumo-list .item:hover .btn-del-insumo { display: inline-block; }
.oc-insumo-list .btn-del-insumo:hover { color: #ef4444; }

.btn-manage-insumos{width:100%;margin:12px 0 18px;display:block}
.oc-header-bar{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:16px}
.oc-filter-bar label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
.oc-filter-bar select{min-width:200px}
.oc-actions{display:flex;justify-content:flex-end;gap:10px}
.oc-placeholder{color:var(--muted);padding:28px;border:2px dashed rgba(15,23,42,0.14);border-radius:16px;text-align:center;background:rgba(15,61,62,0.04)}
.oc-empty{padding:18px;border:1px dashed rgba(15,23,42,0.14);border-radius:12px;text-align:center;background:#f8f8f6;color:var(--muted);line-height:1.6}

.oc-status {
  padding: 3px 8px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}
.oc-status.ABERTA { background: #10b98133; color: #057a55; }
.oc-status.ENCERRADA { background: #6b7a8833; color: var(--muted); }
.oc-status.CANCELADA { background: #ef444433; color: #c81e1e; }

.oc-saldo-bar {
  width: 100%;
  background: var(--border);
  height: 8px;
  border-radius: 4px;
  overflow: hidden;
  margin-top: 4px;
}
.oc-saldo-bar-inner {
  height: 100%;
  background: var(--blue);
  transition: width 0.3s ease;
}

/* --- Modal (Patch v6) --- */
.modal-backdrop {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  opacity: 0;
  transition: opacity 0.2s ease;
  visibility: hidden; /* Added for smoother transition */
  padding:20px;
}
.modal-backdrop.visible { /* Added for smoother transition */
  opacity: 1;
  visibility: visible;
}
.modal-content {
  background: white;
  border-radius: 18px;
  width: 100%;
  max-width: 800px;
  max-height: calc(100vh - 40px);
  box-shadow: var(--shadow-md);
  transform: scale(0.95);
  transition: transform 0.2s ease;
  overflow:hidden;
}
.modal-backdrop.visible .modal-content { /* Added for smoother transition */
    transform: scale(1);
}
.modal-header {
  padding: 16px 20px;
  font-weight: 600;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modal-body {
  padding: 20px;
  max-height: 70vh;
  overflow-y: auto;
}
.modal-footer {
  padding: 16px 20px;
  border-top: 1px solid var(--border);
  display:flex;
  justify-content:flex-end;
  gap:12px;
  flex-wrap:wrap;
}
.modal-footer .btn{min-width:120px}
.push-left{margin-right:auto}
.modal-close-btn {
  border: none; background: none; font-size: 20px; cursor: pointer; color: var(--muted);
}
.modal-error{color:#ef4444;margin-bottom:12px;font-size:14px}
.modal-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

/* Detalhes e Saldos no Modal */
.oc-detail-header {
  background: var(--bg);
  padding: 16px;
  border-radius: 8px;
  margin-bottom: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}
.oc-detail-header div {
  font-size: 14px;
}
.oc-detail-header strong {
  display: block;
  font-size: 20px;
  color: var(--text);
}
.oc-detail-header .saldo-positivo { color: #057a55; }
.oc-detail-header .saldo-negativo { color: #c81e1e; }

.insumo-form{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:12px}
.insumo-field{flex:1;min-width:220px;display:flex;flex-direction:column;gap:6px}
.insumo-field span{font-size:13px;font-weight:500;color:var(--muted)}

.global-modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(15,23,42,0.35);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
  z-index:999;
}
.global-modal-backdrop.visible{
  opacity:1;
  pointer-events:all;
}
.global-modal{
  background:#fff;
  border-radius:18px;
  box-shadow:var(--shadow-md);
  width:min(640px, calc(100vw - 24px));
  max-height:90vh;
  overflow:hidden;
}
.global-modal__content{display:flex;flex-direction:column;max-height:90vh}
.global-modal__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 22px;
  border-bottom:1px solid rgba(148,163,184,0.2);
  font-size:18px;
  font-weight:600;
}
.global-modal__close{
  background:none;
  border:none;
  font-size:24px;
  cursor:pointer;
  color:var(--muted);
}
.global-modal__body{
  padding:20px 22px;
  overflow-y:auto;
}
.global-modal__footer,
.global-modal__actions{
  display:flex;
  gap:12px;
  justify-content:flex-end;
  padding:16px 22px;
  border-top:1px solid rgba(148,163,184,0.15);
}
.global-modal__loading{text-align:center;color:var(--muted);padding:20px 0;}
.contract-detail__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:12px;
}
.contract-detail__grid dt{
  font-size:12px;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:4px;
}
.contract-detail__grid dd{
  margin:0;
  font-size:15px;
  color:var(--text);
}
.contract-detail__notes{grid-column:1 / -1}
.link-button{
  background:none;
  border:none;
  color:var(--primary,#0a66c2);
  text-decoration:underline;
  cursor:pointer;
  padding:0;
  font:inherit;
}
.user-permission-modal p{margin:0 0 12px 0;}
.user-permission-form fieldset{
  border:1px solid rgba(148,163,184,0.3);
  padding:12px 16px;
  border-radius:8px;
  margin:0 0 12px 0;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:8px;
}
.user-permission-form legend{
  font-size:13px;
  font-weight:600;
  padding:0 6px;
}
.user-permission-form .checkbox{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:14px;
}
.user-permission-form .form-feedback{margin-top:10px;font-size:14px}
.contract-edit-form .grid-2{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:14px;
  margin-bottom:12px;
}
.contract-edit-form{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:14px;
  color:var(--muted);
}
.contract-edit-form > span{
  font-weight:600;
  color:#475569;
}
.contract-edit-form label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--muted)}
.auditoria-form{display:flex;flex-direction:column;gap:14px;margin-bottom:12px}
.auditoria-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.auditoria-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
.auditoria-grid .auditoria-full{grid-column:1 / -1}
.auditoria-actions{display:flex;gap:10px;align-items:center}
.audit-modal{display:flex;flex-direction:column;gap:8px;font-size:14px}
.audit-json{background:#0f172a0f;border:1px solid rgba(15,23,42,0.12);border-radius:8px;padding:12px;font-family:'Fira Code',Menlo,monospace;font-size:13px;max-height:240px;overflow:auto}

.file-picker{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.file-picker__name{
  font-size:.9rem;
  color:var(--muted,#6b7280);
}

.file-input-native{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}

.btn-file{
  min-width:120px;
}

@keyframes riseIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
body:not(.auth-mode) .card{animation:riseIn .35s ease both}

@media (max-width:1100px){
  .app-shell{flex-direction:column}
  .sidebar{width:100%;height:auto;position:relative}
  .sidebar-scroll{flex-direction:row;flex-wrap:wrap;height:auto}
  .menu .item{flex:1 1 220px}
  .sidebar-toggle{right:12px;top:12px}
  body.sidebar-collapsed .sidebar{width:100%}
  body.sidebar-collapsed .menu .item-label{display:inline}
  body.sidebar-collapsed .menu .item{justify-content:flex-start}
  .medicoes-body{grid-template-columns:1fr !important}
  .oc-grid{grid-template-columns:1fr !important}
  .modal-form-grid{grid-template-columns:1fr !important}
}
@media (max-width:720px){
  .content{padding:22px}
  .menu .item{flex:1 1 100%}
  .sidebar-logo{width:140px}
}
