: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(24px,3vw,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:28px;
  --space-8:32px;
  --control-height:42px;
  --control-radius:12px;
  --primary:var(--blue);
}
*{box-sizing:border-box}
*{
  scrollbar-width:thin;
  scrollbar-color:rgba(15,23,42,0.28) transparent;
}
*::-webkit-scrollbar{
  width:8px;
  height:8px;
}
*::-webkit-scrollbar-track{
  background:transparent;
}
*::-webkit-scrollbar-thumb{
  background:rgba(15,23,42,0.28);
  border-radius:999px;
  border:2px solid transparent;
  background-clip:padding-box;
}
*::-webkit-scrollbar-thumb:hover{
  background:rgba(15,23,42,0.38);
}
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{
  min-height:100vh;
  padding:0;
  margin:0;
  font-family:var(--font-body);
  background:url('PLANODEBLOQUEIO.jpg') center/cover no-repeat fixed;
}
.login-layout{
  min-height:100vh;
  position:relative;
  padding:clamp(24px,6vw,72px);
}
.login-overlay{
  position:absolute;
  left:50%;
  top:clamp(110px,16vh,190px);
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
}
.login-enter-btn{
  border-radius:999px;
  padding:12px 30px;
  border:0;
  background:linear-gradient(135deg,#0b3a67 0%,#164e8f 55%,#1d6dbf 100%);
  color:#fff;
  font-weight:600;
  letter-spacing:0.3px;
  box-shadow:0 16px 30px rgba(11,58,103,0.28);
  transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;
}
.login-enter-btn:hover{transform:translateY(-1px);filter:brightness(1.05);}
.login-footer{
  font-size:13px;
  color:rgba(255,255,255,0.78);
  text-align:center;
  position:absolute;
  left:50%;
  bottom:24px;
  transform:translateX(-50%);
}
.login-modal-backdrop{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(5,15,30,0.45);
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
  z-index:1000;
}
.login-modal-backdrop.is-open{
  opacity:1;
  pointer-events:all;
}
.login-modal{
  background:#fff;
  border-radius:24px;
  padding:32px 30px 26px;
  width:min(420px,92vw);
  box-shadow:0 28px 70px rgba(5,15,30,0.35);
  position:relative;
}
.login-modal__close{
  position:absolute;
  top:14px;
  right:16px;
  border:0;
  background:transparent;
  font-size:22px;
  line-height:1;
  cursor:pointer;
  color:#64748b;
}
.login-form{
  width:100%;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:16px;
  margin:0;
}
.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:14px;
  border:1px solid #d7e0eb;
  padding:12px 14px;
  background:#f8fafc;
}
.login-form .btn.primary{
  border-radius:16px;
  width:100%;
  justify-content:center;
  background:linear-gradient(135deg,#0b3a67 0%,#124c89 50%,#1c63b0 100%);
  box-shadow:0 18px 35px rgba(11,63,123,0.3);
}
.login-form .btn.primary:hover{filter:brightness(1.05);}
.login-modal .auth-error{
  max-width:none;
  text-align:center;
}
.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{padding:32px 20px;}
  .login-overlay{
    top:clamp(90px,12vh,140px);
  }
  .login-footer{
    position:relative;
    left:auto;
    bottom:auto;
    transform:none;
    margin-top:calc(100vh - 160px);
  }
}
.app-shell{display:flex;min-height:100vh}
.sidebar{
  width:260px;
  background:linear-gradient(180deg,#eef2f7 0%,#7c97b6 55%,#1b4f7a 100%);
  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:0;
}
.sidebar-logo{width:160px;max-width:100%;height:auto;object-fit:contain}
.sidebar-toggle{
  position:relative;
  right:auto;
  top:auto;
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--card-bg);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:none;
  transition:transform .12s ease,box-shadow .12s ease,background .12s ease;
  margin-left:auto;
}
.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-sm);background:#fff}
.sidebar-scroll{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:8px;
  overflow-y:auto;
  padding-right:4px;
  padding-bottom:52px;
  flex:1;
  scrollbar-width:none;
}
.sidebar-scroll::-webkit-scrollbar{
  width:0;
  height:0;
}
.sidebar-scroll-indicator{
  position:absolute;
  left:50%;
  bottom:10px;
  transform:translateX(-50%);
  width:32px;
  height:32px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.6);
  background:rgba(255,255,255,0.75);
  box-shadow:0 6px 14px rgba(15,23,42,0.18);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#0b3a67;
  cursor:pointer;
  display:none;
  transition:opacity .16s ease,transform .16s ease,background .16s ease;
}
.sidebar-scroll-indicator:hover{
  background:#ffffff;
  transform:translateX(-50%) translateY(-2px);
}
.sidebar-scroll-indicator__icon{
  width:10px;
  height:10px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:rotate(45deg);
  margin-top:-2px;
}
.content{
  flex:1;
  min-width:0;
  width:100%;
  padding:32px 40px 56px;
  overflow-x:hidden;
  max-width:none;
  margin:0;
}
body[data-route="oc"] .content{
  padding:28px 32px 52px;
}
body[data-route="painel"] .panel-panel .table-container{
  --table-max-height:calc(100vh - 360px);
}
body[data-route="painel"] .panel-panel .table{
  overflow:visible;
}

body.sidebar-collapsed .sidebar{width:72px;padding:18px 10px}
body.sidebar-collapsed .sidebar-top{justify-content:center;flex-direction:column;gap:10px;padding-right:0}
body.sidebar-collapsed .sidebar-logo{width:32px}
body.sidebar-collapsed .sidebar-scroll{align-items:center;padding-right:0}
body.sidebar-collapsed .sidebar-scroll{
  overflow-y:auto;
  overflow-x:hidden;
  scrollbar-width:none;
  padding-bottom:44px;
}
body.sidebar-collapsed .sidebar-scroll::-webkit-scrollbar{
  width:0;
  height:0;
}
body.sidebar-collapsed .sidebar-scroll-indicator{width:28px;height:28px}
body.sidebar-collapsed .menu .item{justify-content:center}
body.sidebar-collapsed .menu .item-label{display:none}
body.sidebar-collapsed .menu .item{padding:8px 6px}
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)}
body.sidebar-collapsed .sidebar-toggle{margin:0;align-self:center}

.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-5);
}
.card .card{
  box-shadow:none;
  border:0;
  background:transparent;
}
.card .card .hd{
  background:transparent;
  padding-left:0;
  padding-right:0;
  border-bottom:1px solid var(--card-border);
}
.card .card .bd{
  padding-left:0;
  padding-right:0;
}

#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;
}
.panel-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:var(--space-4) 0 var(--space-5);
}
.panel-tabs .btn.is-active{
  background:var(--blue);
  color:#fff;
  border-color:transparent;
  box-shadow:var(--shadow-sm);
}
.panel-panels{display:flex;flex-direction:column;gap:var(--space-5)}
.panel-panel{display:none}
.panel-panel.is-active{display:block}
.panel-notifications__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-4);
  flex-wrap:wrap;
}
.panel-notifications__title{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:600;
  color:#0f172a;
}
.panel-notifications__icon svg{
  width:18px;
  height:18px;
}
.panel-notifications__badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  height:22px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:#fff;
  font-size:12px;
  font-weight:700;
}
.panel-notifications__grid{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(0,1fr);
  gap:var(--space-5);
}
.panel-notifications__subtitle{
  font-weight:600;
  color:#0f172a;
  margin-bottom:8px;
}
.notif-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.notif-item{
  border:1px solid #e2e8f0;
  border-radius:10px;
  padding:12px 14px;
  background:#fff;
  box-shadow:0 6px 16px rgba(15,23,42,0.06);
  display:flex;
  flex-direction:column;
  gap:6px;
  cursor:pointer;
}
.notif-item.is-unread{
  border-color:#f59e0b;
  background:#fff7ed;
}
.notif-item__title{
  font-weight:600;
  color:#0f172a;
}
.notif-item__message{
  font-size:13px;
  color:#475569;
}
.notif-item__meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-size:12px;
  color:#64748b;
  gap:10px;
}
.notif-prefs{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:14px;
  margin-top:12px;
  align-items:start;
}
.notif-pref-group{
  border:1px solid #e2e8f0;
  border-radius:12px;
  padding:12px;
  background:#f8fafc;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.notif-pref-group__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.notif-pref-group__title{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:600;
  color:#0f172a;
}
.notif-pref-group__icon{
  display:inline-flex;
  width:18px;
  height:18px;
  color:#1f2937;
}
.notif-pref-group__icon svg{
  width:18px;
  height:18px;
}
.notif-pref-group__count{
  font-size:12px;
  color:#64748b;
  background:#e2e8f0;
  padding:2px 8px;
  border-radius:999px;
  white-space:nowrap;
}
.notif-pref-group__list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:8px 12px;
  padding-top:8px;
  border-top:1px solid #e2e8f0;
}
.notif-pref-group .notif-pref-item{
  font-weight:500;
  color:#334155;
  background:#ffffff;
  border:1px solid #e2e8f0;
  border-radius:8px;
  padding:6px 8px;
}
.panel-notifications__prefs-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
}
.panel-notifications__pref-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:12px;
}
@media (max-width: 900px){
  .panel-notifications__grid{
    grid-template-columns:1fr;
  }
}
.cad-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:var(--space-5);
}
.cad-tabs .btn.is-active{
  background:var(--blue);
  color:#fff;
  border-color:transparent;
  box-shadow:var(--shadow-sm);
}
.cad-panels{display:flex;flex-direction:column;gap:var(--space-5)}
.cad-panel{display:none}
.cad-panel.is-active{display:block}
.cad-panel .table-container{
  --table-max-height:max(240px, calc(100vh - 320px));
}
.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 #dbe4f1;
  box-shadow:0 16px 32px rgba(15,23,42,0.1);
  background:linear-gradient(150deg,#ffffff 0%,#f5f8fd 100%);
  overflow:hidden;
  --kpi-accent:#0b3a67;
  --kpi-accent-soft:rgba(11,58,103,0.16);
}
.kpi-card .bd{
  padding:var(--space-4) var(--space-5) var(--space-3);
  min-height:120px;
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
  position:relative;
  z-index:1;
  align-items:center;
  text-align:center;
}
.kpi-card::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:6px;
  background:linear-gradient(180deg,var(--kpi-accent) 0%,rgba(11,58,103,0.12) 100%);
  opacity:0.85;
}
.kpi-card::after{
  content:'';
  position:absolute;
  width:200px;
  height:200px;
  right:-80px;
  top:-90px;
  background:radial-gradient(circle,var(--kpi-accent-soft) 0%,rgba(255,255,255,0) 70%);
  pointer-events:none;
}
.kpi-card__header{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:8px;
  width:100%;
}
.kpi-card__label{
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-size:12px;
  color:#64748b;
  font-weight:600;
}
.kpi-card__value{
  font-size:clamp(30px,4vw,46px);
  font-weight:800;
  line-height:1.05;
  color:#0f172a;
  overflow-wrap:anywhere;
  font-variant-numeric:tabular-nums;
}
.kpi-card__meta{
  font-size:13px;
  color:#64748b;
  line-height:1.4;
  max-width:220px;
}
.kpi-card--primary{
  --kpi-accent:#0b3a67;
  --kpi-accent-soft:rgba(11,58,103,0.12);
}
.kpi-card--info{
  --kpi-accent:#2563eb;
  --kpi-accent-soft:rgba(37,99,235,0.14);
}
.kpi-card--warning{
  --kpi-accent:#f59e0b;
  --kpi-accent-soft:rgba(245,158,11,0.18);
}
.report-layout--finance .kpi-grid{
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;
}
.report-layout--finance .kpi-card{
  border:1px solid #e2e8f0;
  border-top:3px solid var(--kpi-accent);
  box-shadow:0 6px 14px rgba(15,23,42,0.06);
  background:#ffffff;
}
.report-layout--finance .kpi-card .bd{
  min-height:96px;
  align-items:center;
  text-align:center;
  gap:8px;
}
.report-layout--finance .kpi-card::before{
  display:none;
}
.report-layout--finance .kpi-card::after{
  display:none;
}
.report-layout--finance .kpi-card__header{
  align-items:center;
  gap:6px;
}
.report-layout--finance .kpi-card__label{
  text-transform:none;
  letter-spacing:0.04em;
  font-size:10px;
  color:#64748b;
}
.report-layout--finance .kpi-card__value{
  font-size:clamp(20px,3.2vw,30px);
  font-weight:700;
  white-space:nowrap;
}
.report-layout--finance .kpi-card__meta{
  font-size:12px;
  color:#64748b;
  max-width:220px;
  margin:0 auto;
}
.report-layout--finance .report-grid{
  gap:18px;
}
.report-layout--finance .card .hd{
  font-size:14px;
  letter-spacing:0.02em;
  background:transparent;
  border-bottom:1px solid #e2e8f0;
}
.report-layout--finance .chart-shell{
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  border-radius:14px;
  padding:10px;
  border:1px solid #e2e8f0;
}
.report-layout--finance .chart-shell canvas{
  border-radius:10px;
}
.report-layout--finance .oc-chart-card .bd{
  gap:14px;
}
.report-layout--finance .oc-report-table th{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:#64748b;
}
.report-layout--finance .oc-report-table td{
  font-size:13px;
}

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

.menu .item{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  text-align:left;
  padding:7px 10px;
  border:1px solid transparent;
  border-radius:12px;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  position:relative;
  font-weight:500;
  font-family:inherit;
  font-size:12px;
  min-height:36px;
  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:10px;
  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:16px;
}
.menu .item.item-sub .item-icon{
  width:22px;
  height:22px;
  border-radius:7px;
}
.menu .item .item-icon{
  width:24px;
  height:24px;
  border-radius:8px;
  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:14px;
  height:14px;
}
.menu .item.active::before{
  content:'';
  position:absolute;
  left:6px;
  top:8px;
  bottom:8px;
  width:3px;
  border-radius:999px;
  background:var(--blue);
}
.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);
}
body.sidebar-collapsed .menu .item.active::before{left:3px}
body.sidebar-collapsed .menu .item::after{
  content:attr(data-tooltip);
  position:absolute;
  left:calc(100% + 10px);
  top:50%;
  transform:translateY(-50%) translateX(-4px);
  background:#0f172a;
  color:#fff;
  padding:6px 10px;
  border-radius:8px;
  font-size:12px;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  box-shadow:var(--shadow-sm);
  transition:opacity .12s ease,transform .12s ease;
}
body.sidebar-collapsed .menu .item:hover::after{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--control-radius);padding:10px 18px;border:1px solid transparent;background:var(--primary);color:#fff;font-weight:600;cursor:pointer;letter-spacing:0.2px;box-shadow:0 8px 16px rgba(11,58,103,0.18);transition:transform .12s ease,box-shadow .12s ease,filter .12s ease,background .12s ease,border-color .12s ease,color .12s ease}
.btn:hover{transform:translateY(-1px);filter:brightness(1.04)}
.btn:disabled{background:#9aa4b2;cursor:not-allowed;box-shadow:none;border-color:transparent}
.btn-outline,
.btn-neutral{background:#fff;color:#475569;border:1px solid #cbd5e1;box-shadow:none}
.btn-outline:hover,
.btn-neutral:hover{background:#f1f5f9;border-color:#94a3b8;color:#1f2937}
.btn-success{background:#128a6a;color:#fff;border-color:transparent;box-shadow:0 8px 16px rgba(18,138,106,0.18)}
.btn-success:hover{background:#0f775b}
body:not(.auth-mode) .btn{padding:10px 18px;font-size:13px;border-radius:var(--control-radius);letter-spacing:0;min-height:var(--control-height);line-height:1.1;white-space:normal}
body:not(.auth-mode) .btn.btn-sm{padding:6px 12px;font-size:12px;min-height:32px;border-radius:10px}
body:not(.auth-mode) .btn.btn-xs{padding:4px 8px;font-size:11px;border-radius:8px;min-height:26px}

/* --- Correção do Patch v3 --- */
.btn-danger {
  background: #ffffff;
  color: #b91c1c;
  border: 1px solid rgba(239, 68, 68, 0.6);
  box-shadow: none;
}
.btn-danger:hover {
  background: #ef4444;
  border-color: #ef4444;
  color: #ffffff;
}

/* --- 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;
  font-weight:400;
  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:flex;flex-direction:column;gap:6px;margin:0;font-size:13px;font-weight:600;color:#475569}
.checkbox{flex-direction:row;align-items:center;gap:8px}
form[style*="grid-template-columns"]{
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr)) !important;
  align-items:stretch;
  gap:var(--space-4) !important;
  padding:var(--space-4);
  border:1px solid #e6edf5;
  border-radius:var(--radius-lg);
  background:#f8fafc;
}
.card .bd [style*="grid-template-columns"]{
  gap:var(--space-4) !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));
  padding:var(--space-4);
  border:1px solid #e6edf5;
  border-radius:var(--radius-lg);
  background:#f8fafc;
}
.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;
  justify-content:flex-end;
  margin-top:var(--space-4);
  padding-top:var(--space-3);
  border-top:1px solid var(--border);
  padding-left:var(--space-3);
  padding-right:var(--space-3);
}
.filter-row{gap:var(--space-4) !important;}
.med-filters{
  gap:var(--space-4) !important;
  padding:var(--space-4);
  border:1px solid #e6edf5;
  border-radius:var(--radius-lg);
  background:#f8fafc;
}
.med-actions{gap:var(--space-3) !important;margin-top:var(--space-4) !important;}
.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 18px;color:var(--muted);border-bottom:1px solid var(--card-border);text-transform:uppercase;letter-spacing:0.08em}
.table td{padding:12px 18px;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);
  overflow:visible;
  position:relative;
}
.table thead th .th-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.table thead th .th-label{display:inline-flex;align-items:center;gap:6px}
.col-filter-btn{
  width:22px;
  height:22px;
  border:1px solid #cbd5e1;
  border-radius:6px;
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.col-filter-btn:hover{background:#f1f5f9;border-color:#94a3b8}
.col-filter-btn.is-active{
  background:#e0ecff;
  border-color:#7aa2d6;
}
.col-filter-btn.is-active .col-filter-icon{border-top-color:#1d4ed8}
.col-filter-icon{
  display:block;
  width:0;
  height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-top:6px solid #64748b;
}
.col-filter-menu{
  position:absolute;
  top:calc(100% + 6px);
  right:0;
  min-width:200px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:10px;
  box-shadow:var(--shadow-sm);
  padding:8px;
  display:none;
  z-index:40;
}
.table-container.show-filters{
  overflow:visible;
}
.card.filters-open{
  overflow:visible;
  z-index:30;
}
.col-filter-menu.is-open{display:block}
.col-filter-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:6px;
}
.col-filter-title{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
}
.col-filter-actions{
  display:flex;
  gap:6px;
}
.col-filter-list{
  max-height:180px;
  overflow:auto;
  padding-right:4px;
  border-top:1px solid #e5e7eb;
  margin-top:8px;
  padding-top:6px;
}
.col-filter-item{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  padding:6px;
  border-radius:8px;
  cursor:pointer;
  text-transform:none;
}
.col-filter-item:hover{background:#f1f5f9}
.col-filter-item input{margin:0}
.table tbody tr:nth-child(odd){background:#ffffff}
.table tbody tr:nth-child(even){background:#f2f6fb}
.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:8px; flex-wrap:wrap; align-items:center; }
.table .row-actions .btn{margin:0;box-shadow:none}
.table .row-actions .btn:hover{transform:none;filter:none}
.table td.row-actions{padding-right:var(--space-5)}
.table th:last-child,
.table td:last-child{padding-right:var(--space-5)}
.table-actions{display:flex;justify-content:flex-end;gap:10px;margin-bottom:var(--space-4);flex-wrap:wrap;align-items:center}
.doc-monthly-nav{display:flex;align-items:center;gap:8px;margin-right:auto}
.doc-monthly-nav__label{font-weight:600;color:#0f172a}
.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-card__section{
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
}
.user-card__title{
  font-size:14px;
  font-weight:600;
  color:#1f2a44;
}
.notifications-card .notifications-header{
  align-items:flex-start;
  gap:16px;
}
.notifications-card .notifications-header .notifications-header__actions{
  margin-left:auto;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.notifications-card .notifications-header > div{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.notifications-card .rule-title{
  font-weight:600;
  color:#0f172a;
}
.notifications-card .notif-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.notification-rule-form .notif-users{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.notification-rule-form .notif-users__list{
  max-height:220px;
  overflow:auto;
  border:1px solid var(--card-border);
  border-radius:10px;
  padding:10px;
  background:#f8fafc;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.notification-rule-form .notif-users__list .checkbox{
  align-items:flex-start;
}
.notification-rule-form .notif-report-fields{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.notification-rule-form .notif-report-fields__list{
  border:1px solid var(--card-border);
  border-radius:10px;
  padding:10px;
  background:#f8fafc;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:6px 10px;
}
.notification-rule-form .notif-event-settings{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.notification-rule-form .notif-event-settings__list{
  border:1px solid var(--card-border);
  border-radius:10px;
  padding:10px;
  background:#f8fafc;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:6px 10px;
}
.notification-rule-form .notif-roles{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.notification-rule-form .notif-roles__list{
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
}
.user-form-grid{
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
}
.user-table .table-container{
  max-height:none;
  overflow:visible;
}
.user-table .table td{vertical-align:middle}
.user-name{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.user-name__link{
  font-weight:600;
  color:#0f172a;
  text-decoration:none;
}
.med-panel{
  background:#f8fafc;
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:160px;
}
.med-panel__title{
  font-size:13px;
  font-weight:600;
  color:#1f2a44;
}
.med-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.med-rel-toolbar{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:flex-end;
}
.med-rel-filters{
  padding:var(--space-4);
  border:1px solid #e6edf5;
  border-radius:var(--radius-lg);
  background:#f8fafc;
}
.med-rel-charts{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:16px;
}
.med-rel-charts > div{
  min-height:260px;
}
.user-name__link:hover{
  color:var(--blue);
  text-decoration:none;
}
.user-name__meta{
  font-size:12px;
  color:var(--muted);
}
.profile-crud{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.profile-crud__table-wrap{
  border:1px solid var(--card-border);
  border-radius:12px;
  background:#f8fafc;
  overflow:hidden;
}
.profile-crud__table{
  width:100%;
  border-collapse:collapse;
  font-size:12px;
}
.profile-crud__table th,
.profile-crud__table td{
  padding:10px;
  border-bottom:1px solid rgba(15,23,42,0.08);
  text-align:center;
}
.profile-crud__table th:first-child,
.profile-crud__table td:first-child{
  text-align:left;
  font-weight:600;
  color:#1f2a44;
}
.profile-crud__table thead{
  background:#eef2f7;
}
.profile-crud__table tbody tr:last-child td{
  border-bottom:0;
}
.doc-new-items{
  border:1px solid var(--card-border);
  border-radius:12px;
  background:#f8fafc;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.doc-new-items__header{
  font-weight:600;
  color:#1f2a44;
}
.doc-new-item{
  background:#fff;
  border:1px solid rgba(15,23,42,0.08);
  border-radius:12px;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.doc-new-item__meta{
  font-size:12px;
  color:var(--muted);
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.doc-new-item__role-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:6px 12px;
  padding-left:18px;
}

/* --- 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: var(--table-max-height, max(240px, calc(100vh - 320px)));
  overflow-y: auto;
  overflow-x: auto;
  background:#f6f8fc;
  border:1px solid #e1e7f0;
  border-radius:var(--radius-lg);
  padding:var(--space-5);
}
body.actions-open .card,
body.actions-open .table,
body.actions-open .table-container{
  overflow:visible;
}
body.actions-open .table-container{
  position:relative;
  z-index:4;
}
body.actions-open .table td.row-actions{
  position:relative;
  z-index:5;
}
body.actions-open .table tbody tr.row-actions-open{
  position:relative;
  z-index:6;
}
body.actions-open .table td.row-actions,
body.actions-open .oc-table-container,
body.actions-open .oc-table-container .table,
body.actions-open .oc-table-container .table tbody,
body.actions-open .oc-table-container .table tbody tr,
body.actions-open .oc-table-container .table td{
  overflow:visible;
}
body.actions-open .global-modal,
body.actions-open .global-modal__content,
body.actions-open .global-modal__body{
  overflow:visible;
}
.card .bd.table-container{
  padding:0;
  background:transparent;
  border:0;
}
.card .bd > .table-container{
  padding:0;
  background:transparent;
  border:0;
}
.card .bd > .table-container .table{
  margin:0;
  border:0;
  border-radius:0;
}
.card .bd > .table-container .table thead tr{
  background:var(--card-head);
}

.empty-state-cell{padding:0}
.empty-state{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:var(--space-3);
  padding:var(--space-6) var(--space-5);
  margin:var(--space-3);
  border:1px dashed rgba(15,23,42,0.16);
  border-radius:var(--radius-md);
  background:#f8fafc;
  color:var(--muted);
  text-align:center;
  min-height:160px;
}
.empty-state__icon{
  width:42px;
  height:42px;
  border-radius:12px;
  background:rgba(11,58,103,0.1);
  color:var(--blue);
  display:flex;
  align-items:center;
  justify-content:center;
}
.empty-state__icon svg{width:20px;height:20px}
.empty-state__text{font-size:14px}
.empty-state__action{min-width:160px}

.actions-wrap{
  position:relative;
  display:flex;
  align-items:center;
  gap:8px;
}
.actions-wrap.is-open{
  z-index:60;
}
.btn-actions{gap:6px}
.btn-actions__icon{font-size:16px;line-height:1}
.actions-menu{
  position:absolute;
  right:0;
  top:calc(100% + 6px);
  min-width:160px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:10px;
  box-shadow:var(--shadow-sm);
  padding:6px;
  display:flex;
  flex-direction:column;
  gap:4px;
  opacity:0;
  visibility:hidden;
  transform:translateY(4px);
  pointer-events:none;
  z-index:30;
}
.actions-wrap.is-open .actions-menu{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}
.actions-menu .btn{
  width:100%;
  justify-content:flex-start;
  font-size:12px;
  padding:6px 8px;
  min-height:32px;
  border-radius:8px;
  background:transparent;
  border:0;
  box-shadow:none;
  color:var(--text);
  font-weight:500;
}
.actions-menu .btn:hover{background:#f1f5f9;color:#0f172a;transform:none;filter:none}
.actions-menu .btn-danger{color:#b91c1c}
.actions-menu .btn-danger:hover{background:rgba(239,68,68,0.1);color:#b91c1c;transform:none;filter:none}

/* --- Filtros de Relatório (Patch v4) --- */
.filters {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: flex-end;
  padding: var(--space-5);
  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:6px;
  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-3) 0 var(--space-4);
}
.report-layout{
  gap:var(--space-4);
}
.report-layout .filters{
  margin-bottom:0;
}
.report-layout .report-tabs{
  margin:0 0 var(--space-3);
}
.report-header{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.report-title{
  margin:0;
  font-size:20px;
  font-weight:700;
  color:#0f172a;
}
.report-subtitle{
  margin:4px 0 0;
  font-size:13px;
  color:var(--muted);
  max-width:560px;
}
.report-filter-summary{
  font-size:12px;
  font-weight:600;
  color:#475569;
  background:#f1f5f9;
  border:1px solid #e2e8f0;
  padding:6px 10px;
  border-radius:999px;
}
.rel-summary{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background:#eef3f9;
  border:1px solid #dbe4f1;
  font-size:12px;
  font-weight:600;
  color:#1f2a44;
  margin-bottom:8px;
}
.rel-summary span{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
  font-weight:600;
}
.rel-summary strong{
  font-size:13px;
}
.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)}
.report-grid{
  display:grid;
  gap:var(--space-5);
}
.report-grid--two{
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
}
.oc-report-table th.is-number,
.oc-report-table td.is-number{
  text-align:right;
  font-variant-numeric:tabular-nums;
}
.oc-report-table td{
  vertical-align:middle;
}

.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-shell.is-empty canvas{opacity:0}
.chart-shell .chart-empty{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:0 16px;
  color:#6b7a88;
  font-size:14px;
  font-weight:500;
  pointer-events:none;
}
.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);
}
.chart-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:6px;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#f8fafc;
}
.chart-tab{
  border:0;
  background:transparent;
  color:#475569;
  font-weight:600;
  padding:6px 12px;
  border-radius:10px;
  cursor:pointer;
  font-size:12px;
  transition:background .12s ease,color .12s ease,box-shadow .12s ease;
}
.chart-tab.is-active{
  background:#1f2a44;
  color:#fff;
  box-shadow:0 8px 16px rgba(15,23,42,0.18);
}
.chart-panel{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.chart-panel[hidden]{display:none}
.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;
  padding:0 12px;
}
.contract-attachments__header h4{
  margin:0;
  font-size:16px;
}
.contract-attachments__body{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.attachment-item{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:start;
  border:1px solid var(--border);
  border-radius:10px;
  padding:10px 12px;
}
.attachment-actions{
  align-self:start;
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.attachment-item .muted{
  font-size:12px;
}

/* --- Estilos Gerenciamento O.C. (Patch v6) --- */
.oc-grid {
  display: grid;
  grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  gap: var(--space-4);
  min-height: 60vh;
  align-items: start;
}
.oc-card .bd{
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
}
.oc-panel{
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
  min-height:100%;
  height:100%;
  padding-top:var(--space-2);
  padding-bottom:var(--space-2);
}
.oc-panel--insumos{
  padding:var(--space-4);
  border:1px solid rgba(15,23,42,0.08);
  border-radius:16px;
  background:#f8fafc;
}
.oc-panel--orders{
  padding-left:var(--space-5);
  min-width:0;
}
.oc-panel__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-3);
  padding-bottom:4px;
}
.oc-panel__title{
  margin:0;
  font-size:16px;
  font-weight:600;
  color:#1f2a44;
}
.oc-panel__body{
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
  flex:1;
}
.oc-panel__body #ocContent{
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
  flex:1;
}
.oc-panel__body #ocPlaceholder{
  margin-top:auto;
  margin-bottom:auto;
}
.oc-insumo-box{
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
  flex:1;
}
.oc-tip{margin:0;font-size:13px;line-height:1.5;color:#64748b}
.oc-insumo-list{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:6px;
  background:#ffffff;
  border:1px solid var(--border);
  border-radius:12px;
  max-height:calc(100vh - 380px);
  overflow:auto;
}
.oc-insumo-list .item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  cursor: pointer;
  font-weight: 500;
  border-radius: 10px;
  border:1px solid transparent;
}
.oc-insumo-list .item:hover {
  background: var(--bg);
}
.oc-insumo-list .item.active {
  background:#e7f0fb;
  color:#0b3a67;
  font-weight: 600;
  border-color:#b8d1f1;
}
.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:0;display:block}
.oc-header-bar{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:0}
.oc-filter-bar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px;flex:1 1 460px;min-width:440px}
.oc-filter-bar label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);flex:1 1 220px;min-width:200px}
.oc-filter-bar select,.oc-filter-bar input{min-width:200px}
.oc-actions{display:flex;justify-content:flex-end;gap:10px}
.oc-table-container{
  --table-max-height:none;
  overflow-x:hidden;
  background:transparent;
  border:0;
  padding:0;
}
.oc-table-container .table{
  width:100%;
  border:0;
  background:transparent;
}
.oc-table-container .table thead{display:none}
.oc-table-container .table tbody{
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
}
.oc-table-container .table tbody tr{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:var(--space-3) var(--space-4);
  padding:var(--space-4);
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 10px 22px rgba(15,23,42,0.06);
}
.oc-table-container .table tbody tr:nth-child(odd){
  background:#f2f6fb;
}
.oc-table-container .table tbody tr:nth-child(even){
  background:#ffffff;
}
.oc-table-container .table tbody tr:hover{background:#fff}
.oc-table-container .table td{
  border:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:13px;
  min-width:0;
  color:#1f2937;
}
.oc-table-container .table td::before{
  content:attr(data-label);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
  font-weight:600;
}
.oc-table-container .table td.oc-wide{
  grid-column:span 2;
}
.oc-table-container .table td.row-actions{
  grid-column:1 / -1;
  flex-direction:row;
  justify-content:flex-end;
  align-items:center;
  gap:8px;
}
.oc-table-container .table td.row-actions::before{display:none}
.oc-table-container .table .oc-saldo-bar{margin-top:6px}
.oc-table-container .table tbody tr.oc-empty-row{
  display:block;
  padding:var(--space-5);
  text-align:center;
  border:1px dashed var(--border);
  border-radius:16px;
  background:#fff;
  box-shadow:none;
}
.oc-table-container .table tbody tr.oc-empty-row td{
  display:block;
}
.oc-table-container .table tbody tr.oc-empty-row td::before{display:none}
.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;
}
.oc-lancamentos-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.oc-lancamentos-summary{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:12px;
  padding:12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#f8fafc;
}
.oc-lancamentos-summary span{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
  display:block;
  margin-bottom:4px;
}
.oc-lancamentos-summary strong{
  font-size:14px;
  color:#0f172a;
}
.oc-lancamentos-preview{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.oc-lancamentos-preview__item{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:8px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#ffffff;
}
.oc-lancamentos-preview__item span{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
  display:block;
  margin-bottom:4px;
}
.oc-lancamentos-preview__item strong{
  font-size:13px;
  color:#0f172a;
}
.oc-lancamentos-preview__more{
  font-size:12px;
  color:var(--muted);
  text-align:center;
}
.oc-lancamentos-table{
  --table-max-height:calc(94vh - 220px);
}
.oc-lancamentos-table .table{
  table-layout:fixed;
  width:100%;
}
.oc-lancamentos-table .table th,
.oc-lancamentos-table .table td{
  white-space:normal;
  word-break:break-word;
}

/* --- Modal (Patch v6) --- */
.modal-backdrop {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  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);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  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;
  flex:1;
  min-height:0;
}
.global-modal__body.no-scroll{
  overflow:visible;
}
.global-modal-backdrop.modal-contract .global-modal__content{
  max-height:none;
}
.global-modal-backdrop.modal-lancamentos .global-modal{
  width:min(1080px, calc(100vw - 24px));
  max-height:94vh;
}
.global-modal-backdrop.modal-lancamentos .global-modal__content{
  max-height:94vh;
}
.global-modal-backdrop.modal-doc-manager .global-modal{
  width:min(1200px, calc(100vw - 24px));
  max-height:94vh;
}
.global-modal-backdrop.modal-doc-manager .global-modal__content{
  max-height:94vh;
}
.global-modal-backdrop.modal-lancamentos{
  z-index:1200;
}
.global-modal-backdrop.modal-lancamentos .global-modal__body{
  max-height:calc(94vh - 140px);
  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(220px,1fr));
  gap:14px;
}
.contract-detail{
  background:#f8fafc;
  border:1px solid #dbe4f1;
  border-radius:18px;
  padding:18px;
  margin-bottom:18px;
}
.contract-detail__grid > div{
  background:#ffffff;
  border:1px solid #e2e8f0;
  border-radius:12px;
  padding:12px 14px;
  box-shadow:0 8px 16px rgba(15,23,42,0.05);
}
.contract-detail__grid dt{
  font-size:12px;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:4px;
  letter-spacing:0.08em;
}
.contract-detail__grid dd{
  margin:0;
  font-size:15px;
  color:var(--text);
  font-weight:600;
}
.contract-detail__notes{grid-column:1 / -1}
.contract-detail__notes dd{font-weight:400;color:#475569}
.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;
  padding:var(--space-4);
  border:1px solid #e6edf5;
  border-radius:var(--radius-lg);
  background:#f8fafc;
}
.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:12px;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}
.audit-detail-card{
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:14px;
  padding:14px;
}
.audit-detail-card__title{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
  margin-bottom:8px;
}
.audit-detail-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:10px;
}
.audit-detail-item{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.audit-detail-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
}
.audit-detail-value{
  font-size:14px;
  color:#0f172a;
  word-break:break-word;
}
.audit-detail-text{
  font-size:14px;
  color:#0f172a;
  white-space:pre-wrap;
}
.audit-detail-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.audit-detail-subcard{
  border:1px solid #e2e8f0;
  border-radius:10px;
  padding:10px;
  background:#ffffff;
}
.audit-detail-subtitle{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
  margin-bottom:6px;
}
.audit-detail-empty{
  color:var(--muted);
  font-size:13px;
}
.auditoria-summary{
  display:flex;
  justify-content:flex-end;
  font-size:12px;
  color:var(--muted);
  margin:0;
}
.auditoria-table{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.auditoria-layout{
  gap:var(--space-3);
}
.med-warning{
  margin-top:6px;
  padding:8px 10px;
  border-radius:8px;
  border:1px dashed rgba(15,23,42,0.18);
  background:#f8fafc;
  color:var(--muted);
  font-size:13px;
}
.filter-row{
  padding:var(--space-4);
  border:1px solid #e6edf5;
  border-radius:var(--radius-lg);
  background:#f8fafc;
}

.file-picker{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  flex-wrap:wrap;
  padding:var(--space-3);
  border:1px dashed rgba(15,23,42,0.18);
  border-radius:var(--control-radius);
  background:#f8fafc;
}

.file-picker__name{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid #e2e8f0;
  background:#eef2f7;
  font-size:12px;
  color:var(--muted,#6b7280);
  max-width:280px;
  min-width:120px;
  min-height:30px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.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:160px;
}

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

/* --- DOC. MANAGER --- */
.doc-manager{
  display:flex;
  flex-direction:column;
  gap:20px;
}
.doc-manager__header{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  padding:20px 22px;
  border-radius:18px;
  border:1px solid #dbe5f1;
  background:linear-gradient(135deg,#f8fafc 0%,#ffffff 55%,#eef6ff 100%);
  box-shadow:0 14px 28px rgba(15,23,42,0.08);
  position:relative;
  overflow:hidden;
}
.doc-manager__header::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at top right, rgba(59,130,246,0.12), transparent 55%);
  pointer-events:none;
}
.doc-manager__header::after{
  content:"";
  position:absolute;
  top:10px;
  bottom:10px;
  left:10px;
  width:6px;
  border-radius:999px;
  background:linear-gradient(180deg,#0b3a67 0%,#3b82f6 100%);
  opacity:0.9;
  pointer-events:none;
}
.doc-manager__header > div:first-child{
  display:flex;
  flex-direction:column;
  gap:6px;
  position:relative;
  z-index:1;
  padding-left:12px;
}
.doc-manager__title{
  font-size:22px;
  font-weight:700;
  color:#0f172a;
  letter-spacing:-0.02em;
}
.doc-manager__header .muted{
  font-size:13px;
  color:#4b5563;
  line-height:1.45;
  max-width:640px;
}
.doc-manager__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  position:relative;
  z-index:1;
}
.page-header{
  margin-bottom:var(--space-5);
}
.doc-manager__layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:16px;
  align-items:start;
}
.doc-manager__list{
  min-height:60vh;
}
.doc-manager__list .bd,
.doc-manager__detail .bd{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.doc-row-active{
  background:rgba(11,58,103,0.08);
}
.doc-detail{
  display:flex;
  flex-direction:column;
  gap:16px;
  padding:14px;
  border-radius:16px;
  border:1px solid #e5ecf4;
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.7);
}
.doc-detail--EM_ANALISE{border-color:#fcd34d;}
.doc-detail--EM_CORRECAO{border-color:#fecaca;}
.doc-detail--APROVADA{border-color:#86efac;}
.doc-detail--RASCUNHO{border-color:#e2e8f0;}
.doc-detail__header{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
}
.doc-detail__title{
  font-size:18px;
  font-weight:700;
  color:#0f172a;
}
.doc-detail__meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  font-size:13px;
  color:var(--muted);
  align-items:center;
}
.doc-detail__meta span:not(.doc-status){
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 10px;
  border-radius:999px;
  background:#f1f5f9;
  border:1px solid #e2e8f0;
}
.doc-detail__meta strong{
  color:#0f172a;
  font-weight:600;
}
.doc-detail__meta--dates{
  margin-top:6px;
}
.doc-detail__actions{
  display:flex;
  gap:8px;
}
.doc-feedback{
  padding:10px 12px;
  border-radius:10px;
  font-size:13px;
  border:1px solid transparent;
}
.doc-feedback--info{background:#f1f5f9;color:#334155;border-color:#e2e8f0;}
.doc-feedback--success{background:#dcfce7;color:#166534;border-color:#86efac;}
.doc-feedback--error{background:#fee2e2;color:#991b1b;border-color:#fecaca;}
.doc-section{
  border:1px solid var(--border);
  border-radius:14px;
  padding:14px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  display:flex;
  flex-direction:column;
  gap:12px;
}
.doc-section__title{
  font-size:14px;
  font-weight:600;
  color:#1f2a44;
}
.doc-items{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.doc-item{
  border:1px solid var(--border);
  border-left:4px solid #e2e8f0;
  border-radius:12px;
  padding:12px;
  background:#ffffff;
  box-shadow:0 10px 18px rgba(15,23,42,0.06);
  display:flex;
  flex-direction:column;
  gap:10px;
}
.doc-item--PENDENTE{border-left-color:#94a3b8;background:#f8fafc;}
.doc-item--EM_ANALISE{border-left-color:#f59e0b;background:#fff7ed;}
.doc-item--APROVADO{border-left-color:#22c55e;background:#f0fdf4;}
.doc-item--REPROVADO{border-left-color:#ef4444;background:#fef2f2;}
.doc-item--VALIDA{border-left-color:#22c55e;background:#f0fdf4;}
.doc-item--VENCIDA{border-left-color:#ef4444;background:#fef2f2;}
.doc-item__header{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}
.doc-item__summary{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.doc-item__toggle{
  width:36px;
  height:36px;
  border-radius:10px;
  border:1px solid #e2e8f0;
  background:#ffffff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  box-shadow:0 6px 14px rgba(15,23,42,0.08);
}
.doc-item__toggle:hover{
  border-color:#cbd5f5;
  box-shadow:0 10px 18px rgba(15,23,42,0.12);
}
.doc-item__toggle-icon{
  width:8px;
  height:8px;
  border-right:2px solid #2563eb;
  border-bottom:2px solid #2563eb;
  transform:rotate(45deg);
  transition:transform 0.2s ease;
}
.doc-item--open .doc-item__toggle-icon{
  transform:rotate(-135deg);
}
.doc-item__actions{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:8px;
}
.doc-item__title{
  font-weight:600;
  color:#0f172a;
}
.doc-item__meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
  font-size:12px;
  color:var(--muted);
  margin-top:4px;
}
.doc-item__statusline{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:#475569;
  margin-top:6px;
}
.doc-item__statusline strong{
  color:#0f172a;
}
.doc-indicator{
  width:16px;
  height:16px;
  border-radius:4px;
  border:2px solid #cbd5f5;
  background:#f8fafc;
  position:relative;
  flex:0 0 16px;
}
.doc-indicator::before,
.doc-indicator::after{
  content:'';
  position:absolute;
  display:none;
}
.doc-indicator--PENDENTE{border-color:#94a3b8;background:#f8fafc;}
.doc-indicator--EM_ANALISE{border-color:#f59e0b;background:#fff7ed;}
.doc-indicator--APROVADO{border-color:#22c55e;background:#dcfce7;}
.doc-indicator--APROVADO::after{
  display:block;
  left:4px;
  top:1px;
  width:6px;
  height:10px;
  border-right:2px solid #16a34a;
  border-bottom:2px solid #16a34a;
  transform:rotate(45deg);
}
.doc-indicator--REPROVADO{border-color:#ef4444;background:#fee2e2;}
.doc-indicator--REPROVADO::before,
.doc-indicator--REPROVADO::after{
  display:block;
  width:10px;
  height:2px;
  background:#b91c1c;
  top:6px;
  left:2px;
}
.doc-indicator--REPROVADO::before{transform:rotate(45deg);}
.doc-indicator--REPROVADO::after{transform:rotate(-45deg);}
.doc-item__hint{
  font-size:12px;
  color:var(--muted);
}
.doc-item__observation{
  margin-top:6px;
  padding:8px 10px;
  border-radius:8px;
  background:#fee2e2;
  color:#991b1b;
  font-size:12px;
}
.doc-note{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:12px;
  color:var(--muted);
  margin-top:6px;
}
.doc-note__field{
  min-height:64px;
}
.doc-item__body{
  display:none;
  flex-direction:column;
  gap:10px;
}
.doc-item--open .doc-item__body{
  display:flex;
}
.doc-item--focus{
  border-color:#93c5fd;
  border-left-color:#3b82f6;
  box-shadow:0 0 0 3px rgba(59,130,246,0.18), 0 10px 18px rgba(15,23,42,0.06);
  animation:doc-focus-pulse 1.6s ease;
}
@keyframes doc-focus-pulse{
  0%{box-shadow:0 0 0 0 rgba(59,130,246,0.2), 0 10px 18px rgba(15,23,42,0.06);}
  60%{box-shadow:0 0 0 6px rgba(59,130,246,0), 0 10px 18px rgba(15,23,42,0.06);}
  100%{box-shadow:0 0 0 0 rgba(59,130,246,0), 0 10px 18px rgba(15,23,42,0.06);}
}
.doc-item__body-actions{
  display:flex;
  justify-content:flex-end;
  align-items:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.doc-item__subtitle{
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:#6b7280;
  margin-top:6px;
}
.doc-tag{
  padding:2px 6px;
  border-radius:999px;
  font-size:9px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.06em;
  line-height:1.1;
}
.doc-tag--required{background:#fee2e2;color:#991b1b;}
.doc-tag--optional{background:#e2e8f0;color:#475569;}
.doc-tag--sent{background:#dcfce7;color:#166534;border:1px solid #86efac;}
.doc-tag--pending{background:#fef9c3;color:#92400e;border:1px solid #fde68a;}
.doc-tag--expired{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;}
.doc-tag--neutral{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;}
.doc-tag--deadline{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd;}
.doc-validity-field{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:150px;
}
.doc-validity-field span{
  font-size:11px;
  line-height:1;
  color:var(--muted);
}
.doc-validity-field .input{
  min-height:32px;
  padding:6px 10px;
  font-size:12px;
}
.doc-panel-summary{
  display:flex;
  align-items:center;
  gap:6px;
}
.doc-panel-summary__items{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.doc-panel-summary__item{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:3px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:600;
  border:1px solid transparent;
  background:#f1f5f9;
  color:#475569;
}
.doc-panel-summary__dot{
  width:6px;
  height:6px;
  border-radius:50%;
  background:currentColor;
}
.doc-panel-summary__item--valid{
  background:#dcfce7;
  border-color:#86efac;
  color:#166534;
}
.doc-panel-summary__item--expired{
  background:#fee2e2;
  border-color:#fecaca;
  color:#991b1b;
}
.doc-panel-summary__item--pending{
  background:#fef9c3;
  border-color:#fde68a;
  color:#92400e;
}
.doc-panel-summary--empty{
  font-size:12px;
  color:var(--muted);
}
.doc-validity-missing{
  font-size:12px;
  font-weight:600;
  color:#b91c1c;
}
.employee-panel-add{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.employee-panel-form{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.employee-panel-reuse-card{
  padding:10px;
  border:1px solid #e2e8f0;
  border-radius:10px;
  background:#f8fafc;
  margin-top:8px;
}
.doc-status{
  padding:2px 6px;
  border-radius:12px;
  font-size:9px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.06em;
  line-height:1.1;
}
.doc-status.RASCUNHO{background:#e2e8f0;color:#475569;}
.doc-status.EM_ANALISE{background:#fde68a;color:#92400e;}
.doc-status.EM_CORRECAO{background:#fecaca;color:#991b1b;}
.doc-status.APROVADA{background:#bbf7d0;color:#166534;}
.doc-status.PENDENTE{background:#e2e8f0;color:#475569;}
.doc-status.APROVADO{background:#bbf7d0;color:#166534;}
.doc-status.REPROVADO{background:#fecaca;color:#991b1b;}
.doc-files{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.doc-files .attachment-item{
  background:#ffffff;
  border-color:#e2e8f0;
  box-shadow:0 6px 14px rgba(15,23,42,0.05);
}
.doc-files .attachment-item strong{
  color:#0f172a;
}
.doc-employee__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.doc-employee-table .table{
  margin-top:8px;
}
.doc-section__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.doc-header-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:10px;
}
.doc-header-grid span{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
  display:block;
  margin-bottom:4px;
}
.doc-header-grid strong{
  font-size:13px;
  color:#0f172a;
}
.doc-employee-list{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.doc-employee-simple-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.doc-employee-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#ffffff;
  box-shadow:0 10px 18px rgba(15,23,42,0.06);
}
.doc-employee-row:hover{
  border-color:#cbd5f5;
}
.doc-employee-row__name{
  font-weight:600;
  color:#0f172a;
}
.doc-employee-card__header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.doc-employee-card__name{
  font-size:16px;
  font-weight:600;
  color:#0f172a;
}
.doc-employee-card__tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:6px;
}
.doc-employee-card__actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.doc-employee-card__docs{
  margin-top:12px;
}
.doc-employee-footer{
  border:1px dashed var(--border);
  background:#f8fafc;
}
.doc-employee-footer__actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
}
.doc-employee-footer .muted{
  font-size:12px;
}
.doc-employee-form__nrs{
  display:grid;
  gap:6px;
  margin-top:8px;
}
.doc-finance-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:10px;
}
.doc-finance-grid span{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--muted);
  display:block;
  margin-bottom:4px;
}
.doc-finance-grid strong{
  font-size:13px;
  color:#0f172a;
}
.doc-eval{
  display:grid;
  gap:10px;
  padding-top:8px;
  border-top:1px dashed var(--border);
}
.doc-eval__actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.doc-eval__selected{
  font-size:12px;
  font-weight:600;
  padding:6px 10px;
  border-radius:999px;
  width:fit-content;
  background:#f1f5f9;
  color:#475569;
  border:1px solid #e2e8f0;
}
.doc-eval__selected--APROVADO{
  background:#dcfce7;
  color:#166534;
  border-color:#86efac;
}
.doc-eval__selected--REPROVADO{
  background:#fee2e2;
  color:#991b1b;
  border-color:#fecaca;
}
.doc-eval__selected--PENDENTE{
  background:#fef9c3;
  color:#92400e;
  border-color:#fde68a;
}
.doc-eval__field{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:12px;
  color:#475569;
}
.doc-submit__content{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.doc-submit__missing{
  font-size:12px;
  color:#475569;
  background:#f8fafc;
  border:1px dashed #e2e8f0;
  padding:8px 10px;
  border-radius:10px;
  line-height:1.4;
}
.doc-eval-actions__content{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.doc-eval-bar{
  position:sticky;
  bottom:0;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid #e2e8f0;
  background:linear-gradient(90deg,#f8fafc 0%,#ffffff 70%);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  box-shadow:0 14px 22px rgba(15,23,42,0.08);
  margin-top:16px;
  z-index:2;
}
.doc-eval-bar__info{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  font-size:12px;
  color:var(--muted);
}
.doc-eval-bar__info span{
  padding:4px 10px;
  border-radius:999px;
  background:#f1f5f9;
  border:1px solid #e2e8f0;
  font-weight:600;
}
.doc-history-table{
  max-height:320px;
}
.doc-loading{
  padding:18px;
  color:var(--muted);
}
.doc-table-container{
  --table-max-height:calc(100vh - 360px);
}
.doc-manager__layout .card{
  min-height:200px;
}
.doc-guides-list{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(170px, 1fr));
  gap:16px;
  align-items:stretch;
}
.doc-guide-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  padding:12px;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#ffffff;
  box-shadow:0 8px 18px rgba(15,23,42,0.06);
  text-align:center;
  min-height:200px;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.doc-guide-item:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 22px rgba(15,23,42,0.08);
  border-color:#cbd5f5;
}
.doc-guide-item.is-open{
  border-color:#93c5fd;
  box-shadow:0 16px 28px rgba(15,23,42,0.1);
}
.doc-guide-card__icon{
  width:72px;
  height:72px;
  border-radius:14px;
  background:#f1f5f9;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:inset 0 0 0 1px rgba(148,163,184,0.4);
}
.doc-guide-card__icon img{
  width:48px;
  height:48px;
  object-fit:contain;
}
.doc-guide-card__title{
  font-size:13px;
  font-weight:600;
  color:#0f172a;
  line-height:1.35;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:32px;
}
.doc-guide-card__details{
  display:none;
  width:100%;
  flex-direction:column;
  gap:6px;
  align-items:center;
}
.doc-guide-item.is-open .doc-guide-card__details{
  display:flex;
}
.doc-guide-card__meta{
  font-size:11px;
  color:var(--muted);
  line-height:1.4;
}
.doc-guide-card__actions{
  margin-top:auto;
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  justify-content:center;
}
.doc-guide-card__actions .btn{
  box-shadow:none;
}
.doc-guide-visibility{
  margin-top:2px;
  font-size:12px;
  color:var(--muted);
  text-align:center;
}
.doc-guide-visibility__header{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.doc-guide-visibility__list{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:8px 10px;
  border:1px solid #e2e8f0;
  border-radius:10px;
  background:#f8fafc;
  max-height:220px;
  overflow-y:auto;
}
.doc-item-manager .panel-tabs{
  margin-top:4px;
  flex-wrap:wrap;
  gap:8px;
}
.doc-item-actions{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.doc-item-row--inactive{
  opacity:0.6;
}
.doc-item-title{
  font-weight:600;
}
.doc-item-visibility__header{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.doc-item-visibility__roles{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:6px 8px;
  border:1px dashed #e2e8f0;
  border-radius:10px;
  background:#f8fafc;
}
.doc-item-visibility__list{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:8px 10px;
  border:1px solid #e2e8f0;
  border-radius:10px;
  background:#f8fafc;
  max-height:220px;
  overflow-y:auto;
}
@media (max-width:1100px){
  .doc-manager__layout{grid-template-columns:1fr;}
  .doc-manager__header{flex-direction:column;align-items:flex-start;}
}

@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{margin-left:auto}
  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}
  .oc-panel--insumos{padding-right:0;border-right:0;padding-bottom:var(--space-5);border-bottom:1px solid var(--border)}
  .oc-panel--orders{padding-left:0;padding-top:var(--space-5)}
  .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}
}
