:root{
  --pdm-navy:#102a43;
  --pdm-blue:#1f4e79;
  --pdm-teal:#0f766e;
  --pdm-gold:#d9b76f;
  --pdm-bg:#f4f7fb;
  --pdm-card:#ffffff;
  --pdm-muted:#6b7280;
  --pdm-border:#dbe3ef;
}

*{box-sizing:border-box}
body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#152238;background:var(--pdm-bg)}
.form-control,.form-select{border-color:var(--pdm-border);border-radius:14px}.btn-primary{background:linear-gradient(135deg,var(--pdm-blue),var(--pdm-teal));border:none;border-radius:14px}.btn-outline-secondary{border-radius:12px}

/* Login Page */
.pdm-login-body{
  min-height:100vh;
  margin:0;
  overflow-x:hidden;
  color:#f7fbfc;
  background:linear-gradient(135deg,#071f31 0%,#0b4552 50%,#0d6b63 100%);
}

.pdm-login-video{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  background:#071f31;
  opacity:1;
}

.pdm-login-overlay{
  position:fixed;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg,rgba(5,22,36,.92) 0%,rgba(8,54,65,.84) 48%,rgba(8,88,82,.78) 100%),
    radial-gradient(circle at 20% 20%,rgba(217,183,111,.22),transparent 32%);
  pointer-events:none;
}

.pdm-login-page{
  position:relative;
  z-index:2;
  width:min(1160px,calc(100% - 48px));
  min-height:100vh;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(380px,.82fr);
  align-items:center;
  gap:52px;
  padding:42px 0;
}

.pdm-login-intro{max-width:660px}

.pdm-login-logo-frame{
  width:108px;
  height:108px;
  display:grid;
  place-items:center;
  margin-bottom:26px;
  border-radius:24px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(255,255,255,.65);
  box-shadow:0 18px 44px rgba(0,0,0,.24);
}

.pdm-login-logo{
  display:block;
  width:82px;
  height:82px;
  object-fit:contain;
}

.pdm-login-institution{
  margin:0 0 12px;
  color:#f3d48d;
  font-size:15px;
  font-weight:700;
}

.pdm-login-copy h1{
  max-width:640px;
  margin:0;
  font-size:clamp(34px,4.2vw,54px);
  line-height:1.08;
  font-weight:800;
  letter-spacing:0;
}

.pdm-login-subtitle{
  max-width:610px;
  margin:19px 0 0;
  color:rgba(247,251,252,.86);
  font-size:18px;
  line-height:1.62;
}

.pdm-login-indicators{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:28px;
}

.pdm-login-indicators span{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:8px 13px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.11);
  color:rgba(255,255,255,.93);
  font-size:13px;
  font-weight:650;
}

.pdm-login-card{
  width:100%;
  max-width:450px;
  justify-self:end;
  padding:32px;
  border-radius:24px;
  background:rgba(255,255,255,.98);
  color:#122a38;
  border:1px solid rgba(255,255,255,.75);
  box-shadow:0 24px 64px rgba(3,18,28,.31);
}

.pdm-login-card-header{margin-bottom:22px}

.pdm-login-card-header h2{
  margin:0;
  color:#0f2d3d;
  font-size:27px;
  line-height:1.2;
  font-weight:800;
  letter-spacing:0;
}

.pdm-login-card-header p{
  margin:8px 0 0;
  color:#667985;
  font-size:15px;
}

.pdm-login-card .alert{
  margin-bottom:17px;
  border:1px solid #f2c4c4;
  border-radius:14px;
  background:#fff1f1;
  color:#8a2525;
  font-size:14px;
  line-height:1.45;
}

.pdm-login-field{margin-bottom:17px}

.pdm-login-field label{
  display:block;
  margin-bottom:8px;
  color:#233b4a;
  font-size:14px;
  font-weight:700;
}

.pdm-login-field .form-control{
  width:100%;
  height:54px;
  border-radius:14px;
  border:1px solid #cfdce4;
  background:#fbfdfe;
  color:#102a3a;
  font-size:15px;
  box-shadow:none;
}

.pdm-login-field .form-control::placeholder{color:#8999a4}

.pdm-login-field .form-control:focus{
  border-color:#0f766e;
  background:#ffffff;
  box-shadow:0 0 0 4px rgba(217,183,111,.25);
}

.pdm-login-password-wrap{position:relative}
.pdm-login-password-wrap .form-control{padding-right:52px}

.pdm-login-password-toggle{
  position:absolute;
  top:50%;
  right:8px;
  width:40px;
  height:40px;
  transform:translateY(-50%);
  display:grid;
  place-items:center;
  border:0;
  border-radius:12px;
  background:transparent;
  color:#617481;
  cursor:pointer;
}

.pdm-login-password-toggle:hover,
.pdm-login-password-toggle:focus-visible{
  background:#edf6f5;
  color:#0f766e;
  outline:none;
}

.pdm-login-password-toggle:focus-visible{box-shadow:0 0 0 3px rgba(217,183,111,.35)}
.pdm-login-password-toggle svg{width:21px;height:21px;fill:currentColor}
.pdm-login-password-toggle.is-visible{color:#0f766e}

.pdm-login-submit{
  width:100%;
  height:56px;
  margin-top:6px;
  border:0;
  border-radius:15px;
  background:linear-gradient(135deg,#174d73 0%,#0f766e 100%);
  color:#ffffff;
  font-size:16px;
  font-weight:800;
  box-shadow:0 14px 30px rgba(15,96,105,.28);
  transition:transform .16s ease,box-shadow .16s ease,filter .16s ease;
}

.pdm-login-submit:hover:not(:disabled){
  transform:translateY(-1px);
  filter:brightness(1.04);
  box-shadow:0 18px 36px rgba(15,96,105,.34);
}

.pdm-login-submit:focus-visible{
  outline:3px solid var(--pdm-gold);
  outline-offset:3px;
}

.pdm-login-submit:disabled{
  cursor:wait;
  opacity:.78;
}

.pdm-login-note{
  margin:19px 0 0;
  padding-top:17px;
  border-top:1px solid #edf2f5;
  color:#687a86;
  font-size:13px;
  text-align:center;
}

.pdm-login-support{
  margin:10px 0 0;
  color:#7b8a94;
  font-size:12.5px;
  line-height:1.45;
  text-align:center;
}

.pdm-login-support a{
  color:#0f766e;
  font-weight:700;
  text-decoration:none;
}

.pdm-login-support a:hover{text-decoration:underline}

.app-layout{display:grid;grid-template-columns:290px 1fr;min-height:100vh}.sidebar{background:#0f2439;color:white;padding:22px;position:sticky;top:0;height:100vh;overflow:auto}.sidebar-brand{display:flex;align-items:center;gap:14px;margin-bottom:28px}.sidebar-brand img{width:52px;height:52px}.sidebar-brand strong{display:block;font-size:20px}.sidebar-brand span{display:block;color:#bfd3e4;font-size:13px}.sidebar-nav{display:grid;gap:8px}.sidebar-nav .nav-link{width:100%;text-align:left;border:0;border-radius:14px;padding:12px 14px;background:transparent;color:#dbeafe;font-weight:650}.sidebar-nav .nav-link:hover,.sidebar-nav .nav-link.active{background:rgba(255,255,255,.12);color:white}.main{padding:28px;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:24px}.topbar h1{font-weight:850;letter-spacing:0;margin:0}.topbar p{color:var(--pdm-muted);margin:4px 0 0}.topbar-actions{display:flex;align-items:center;gap:10px}.topbar-actions .form-select{width:160px;background:white}.user-pill{display:inline-flex;align-items:center;min-height:36px;border-radius:999px;background:white;border:1px solid var(--pdm-border);padding:0 14px;font-weight:650;color:var(--pdm-navy)}.view{display:none}.view.active{display:block}.panel{background:var(--pdm-card);border:1px solid var(--pdm-border);border-radius:24px;padding:20px;box-shadow:0 14px 35px rgba(16,42,67,.06)}.panel h2{font-size:18px;font-weight:800;margin-bottom:16px;color:var(--pdm-navy)}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.kpi-card{background:white;border:1px solid var(--pdm-border);border-radius:22px;padding:18px;box-shadow:0 10px 30px rgba(16,42,67,.05)}.kpi-card span{color:var(--pdm-muted);font-size:13px;font-weight:700}.kpi-card strong{display:block;font-size:28px;line-height:1.2;color:var(--pdm-navy)}.kpi-card em{font-style:normal;color:var(--pdm-teal);font-size:13px}.table{font-size:14px}.dataTables_wrapper .dt-buttons .btn{border-radius:10px;margin-right:6px}.badge-section{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;border-radius:999px;background:#e7f7f4;color:#0f766e;font-weight:800}.scenario-list{display:grid;gap:12px}.scenario-card{border:1px solid var(--pdm-border);border-radius:18px;padding:14px;background:#fbfdff}.scenario-card strong{display:block;color:var(--pdm-navy)}.scenario-card small{color:var(--pdm-muted)}.indicator-card{border:1px solid var(--pdm-border);border-radius:20px;padding:16px;margin-bottom:14px;background:white}.indicator-card header{display:flex;justify-content:space-between;gap:14px}.indicator-code{display:inline-block;padding:4px 9px;border-radius:999px;background:#eaf2ff;color:#1f4e79;font-weight:800}.param-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:12px}.save-state{font-size:12px;color:var(--pdm-muted)}

@media (prefers-reduced-motion:reduce){
  .pdm-login-video{display:none}
  .pdm-login-submit{transition:none}
}

@media (max-width:1024px){
  .app-layout{grid-template-columns:1fr}.sidebar{position:static;height:auto}.sidebar-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.param-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.topbar{flex-direction:column}
  .pdm-login-page{grid-template-columns:1fr;gap:28px;width:min(760px,calc(100% - 40px));padding:34px 0;align-items:start}
  .pdm-login-intro{max-width:none}
  .pdm-login-card{max-width:none;justify-self:stretch}
  .pdm-login-logo-frame{margin-bottom:20px}
  .pdm-login-copy h1{font-size:clamp(32px,6vw,44px)}
  .pdm-login-subtitle{font-size:16px;margin-top:15px}
  .pdm-login-indicators{margin-top:21px}
}

@media (max-width:768px){
  .pdm-login-page{width:min(100% - 32px,720px);padding:28px 0;gap:24px}
  .pdm-login-logo-frame{width:94px;height:94px;border-radius:21px}
  .pdm-login-logo{width:72px;height:72px}
  .pdm-login-card{padding:28px 24px;border-radius:22px}
  .pdm-login-copy h1{font-size:32px;line-height:1.12}
  .pdm-login-subtitle{font-size:15.5px;line-height:1.55}
}

@media (max-width:560px){
  .main{padding:16px}.kpi-grid,.param-grid{grid-template-columns:1fr}.sidebar-nav{grid-template-columns:1fr}.topbar-actions{width:100%;flex-wrap:wrap}.topbar-actions .form-select{width:100%}
  .pdm-login-page{width:min(100% - 22px,720px);padding:22px 0;gap:20px}
  .pdm-login-logo-frame{width:86px;height:86px;margin-bottom:18px}
  .pdm-login-logo{width:66px;height:66px}
  .pdm-login-copy h1{font-size:29px}
  .pdm-login-subtitle{font-size:15px}
  .pdm-login-indicators{gap:8px;margin-top:18px}
  .pdm-login-indicators span{min-height:34px;font-size:12px;padding:7px 11px}
  .pdm-login-card{padding:24px 18px}
  .pdm-login-card-header h2{font-size:24px}
  .pdm-login-field .form-control,.pdm-login-submit{height:52px}
}

.pdm-login-system-note {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid rgba(15, 37, 51, .10);
    text-align: center;
    color: #5f7280;
}

.pdm-login-system-note strong {
    display: inline-block;
    margin-bottom: 4px;
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(246, 166, 35, .14);
    color: #9a6500;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .04em;
}

.pdm-login-system-note span {
    display: block;
    color: #173447;
    font-size: 13px;
    font-weight: 800;
}

.pdm-login-system-note small {
    display: block;
    max-width: 320px;
    margin: 6px auto 0;
    color: #7a8b96;
    font-size: 11px;
    line-height: 1.45;
}
/* Phase 2.1 History BI */
.history-body{background:#f3f7fb}.history-main,.history-standalone{width:100%;max-width:1540px}.history-standalone{margin:0 auto}.sidebar-nav a.nav-link{display:flex;align-items:center;gap:9px;text-decoration:none}.sidebar-brand img{object-fit:contain;background:#fff;border-radius:12px;padding:4px}.history-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:22px}.history-header h1{margin:0;color:#102a43;font-size:32px;font-weight:850;letter-spacing:0}.history-header p{max-width:760px;margin:7px 0 0;color:#667085;font-size:15px}.history-breadcrumb{margin-bottom:8px;color:#0f766e;font-size:13px;font-weight:750}.history-kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:22px}.history-panel{border-radius:18px;padding:18px;overflow:hidden}.history-panel h2{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:18px}.history-card-title{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.history-card-title h2{margin:0 0 5px}.history-card-title p{margin:0;color:#667085;font-size:13px}.history-table-stack{display:grid;gap:22px}.history-tabs{display:flex;flex-wrap:wrap;gap:8px}.history-row-pdm>*{background:#fff7df!important;box-shadow:inset 4px 0 0 #d9b76f}.history-row-summary>*{background:#eaf6f4!important;font-weight:800;color:#0f3f45}.history-panel .dataTables_wrapper{font-size:14px}.history-panel table.dataTable thead th{white-space:normal;background:#f8fbfd;color:#14324a;border-bottom:1px solid #dbe3ef}.history-panel table.dataTable tbody td{vertical-align:middle;white-space:normal;overflow-wrap:anywhere}.history-panel .dt-buttons{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:10px}.history-panel .dt-buttons .btn{border-radius:10px}.history-panel .dataTables_filter input{border:1px solid #dbe3ef;border-radius:10px;padding:7px 10px}.history-panel .dataTables_scrollHead{position:sticky;top:0;z-index:3}.history-report-list{display:grid;gap:10px}.history-report-item{display:grid;grid-template-columns:80px 1fr auto;gap:12px;align-items:center;padding:12px 14px;border:1px solid #dbe3ef;border-radius:14px;background:#fbfdff}.history-report-item strong{color:#0f766e}.history-report-item span{font-weight:700;color:#102a43}.history-report-item small{color:#667085}.history-bulk-textarea{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.history-preview-empty{min-height:220px;border:1px dashed #c8d5df;border-radius:14px;background:#fbfdff;color:#667085;display:grid;place-items:center;padding:18px}.history-form .note-editor{border-color:#dbe3ef;border-radius:14px;overflow:hidden}.badge.bg-warning{border:1px solid rgba(217,183,111,.55)}
@media (max-width:1200px){.history-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.history-header{flex-direction:column}.history-main{padding:22px}}
@media (max-width:768px){.history-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.history-card-title{flex-direction:column}.history-header h1{font-size:28px}.history-report-item{grid-template-columns:1fr}.history-standalone{padding:18px}}
@media (max-width:560px){.history-kpi-grid{grid-template-columns:1fr}.history-panel{padding:14px}.history-header h1{font-size:24px}.history-tabs .btn{width:100%}}
.history-sidebar{background:linear-gradient(180deg,#092133 0%,#0d4652 58%,#0f665f 100%)}
.history-hero-header{padding:22px;border:1px solid rgba(15,118,110,.12);border-radius:22px;background:linear-gradient(135deg,#ffffff 0%,#f7fbfc 100%);box-shadow:0 16px 40px rgba(16,42,67,.06)}
.history-year-badges{display:flex;flex-wrap:wrap;gap:9px;margin-top:14px}.history-current-badge{background:#fff3cd;color:#7a5600;border:1px solid rgba(217,183,111,.45)}
.history-section-legend{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}.history-section-legend span{display:inline-flex;padding:6px 9px;border-radius:999px;background:#edf7f6;color:#0b5d58;font-size:12px;font-weight:700}
.history-chip-combo{display:inline-flex;padding:6px 10px;border-radius:999px;background:#eaf6f4;color:#0f665f;font-weight:800;white-space:nowrap}.history-dashboard-link{text-decoration:none;transition:transform .16s ease,box-shadow .16s ease}.history-dashboard-link:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(16,42,67,.10)}
.history-panel .buttons-copy,.history-panel .buttons-csv{display:none!important}.history-row-pdm .badge{margin-left:6px}.history-row-summary td{border-top:2px solid #0f766e!important}

/* Phase 2.1 server-side table controls */
.pdm-filter-panel{margin-bottom:18px;padding:16px;border-radius:18px;background:#fff;border:1px solid #dbe3ef;box-shadow:0 10px 28px rgba(16,42,67,.05)}
.pdm-filter-grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:12px;align-items:end}.pdm-filter-grid label{display:block;margin-bottom:5px;color:#253846;font-size:12px;font-weight:800}.pdm-filter-grid .form-control,.pdm-filter-grid .form-select{min-height:42px;border-radius:12px;background:#fbfdff}.pdm-check-filter{display:flex!important;align-items:center;gap:8px;min-height:42px;padding:8px 10px;border:1px solid #dbe3ef;border-radius:12px;background:#fbfdff;margin:0!important;color:#253846}.pdm-check-filter input{width:16px;height:16px}
.history-panel .dt-buttons{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 12px}.history-panel .dt-buttons .dt-button,.history-panel .dt-buttons .btn,.pdm-export-btn{display:inline-flex!important;align-items:center;justify-content:center;gap:6px;min-width:86px;height:38px;padding:0 13px!important;border:1px solid #c9d8e3!important;border-radius:12px!important;background:#fff!important;color:#123047!important;font-size:13px!important;font-weight:800!important;box-shadow:none!important}.history-panel .dt-buttons .dt-button:hover,.pdm-export-btn:hover{background:#eaf6f4!important;border-color:#0f766e!important;color:#0f665f!important}.pdm-export-btn i{font-size:17px}.dt-button-collection{border:1px solid #dbe3ef!important;border-radius:14px!important;box-shadow:0 18px 50px rgba(16,42,67,.18)!important;padding:10px!important;background:#fff!important}.dt-button-collection .dt-button{display:flex!important;align-items:center;gap:8px;width:100%;border:0!important;border-radius:10px!important;background:#fff!important;color:#203849!important;text-align:left!important}.dt-button-collection .dt-button.active:before{content:'✓';display:inline-flex;width:18px;height:18px;align-items:center;justify-content:center;border-radius:50%;background:#0f766e;color:#fff;font-size:12px}.dt-button-collection .dt-button:not(.active):before{content:'';display:inline-flex;width:18px;height:18px;border:1px solid #c9d8e3;border-radius:50%}.history-panel .dataTables_processing{border-radius:14px;border:1px solid #dbe3ef;background:#fff;color:#102a43;font-weight:800;box-shadow:0 12px 30px rgba(16,42,67,.12)}.history-panel .dataTables_scrollBody{scrollbar-color:#0f766e #edf3f7;scrollbar-width:thin}.history-panel table.dataTable tbody tr:hover>*{background:#f5fbfa!important}.pdm-average-row>*{background:#eaf6f4!important;font-weight:800}.pdm-highlight-row>*{background:#fff7df!important;box-shadow:inset 4px 0 0 #d9b76f}.pdm-session-box{margin-top:auto;padding:14px;border:1px solid rgba(255,255,255,.16);border-radius:16px;background:rgba(255,255,255,.08);color:#e7f6f4}.pdm-session-box span{display:block;color:#b9d8d6;font-size:12px;font-weight:800}.pdm-session-box strong{display:block;margin:4px 0 8px;color:#fff;font-size:18px}.pdm-session-progress{height:7px;border-radius:999px;background:rgba(255,255,255,.18);overflow:hidden}.pdm-session-progress i{display:block;height:100%;width:100%;border-radius:inherit;background:#d9b76f}.pdm-session-box.is-ending .pdm-session-progress i{background:#ef4444}.pdm-session-box.is-ending strong{color:#fecaca}
@media (max-width:1100px){.pdm-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pdm-session-box{margin-top:18px}}
@media (max-width:640px){.pdm-filter-grid{grid-template-columns:1fr}.history-panel .dt-buttons .dt-button,.pdm-export-btn{min-width:74px}}

/* Phase 2.1 DataTables 2 refinement */
.history-panel .dt-container{font-size:14px;color:#203849}
.history-panel .dt-layout-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:10px 0;flex-wrap:wrap}
.history-panel .dt-layout-cell{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.history-panel .dt-search label,.history-panel .dt-length label{font-size:13px;font-weight:800;color:#34495a}
.history-panel .dt-search input,.history-panel .dt-length select{min-height:38px;border:1px solid #ccd9e4;border-radius:12px;background:#fff;padding:6px 10px;color:#14324a;box-shadow:none}
.history-panel .dt-search input:focus,.history-panel .dt-length select:focus,.pdm-column-filter input:focus{border-color:#0f766e;outline:0;box-shadow:0 0 0 3px rgba(15,118,110,.13)}
.history-panel .dt-buttons{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0!important}
.btn-primary-theme-table,.pdm-table-action-btn,.history-panel .dt-buttons .dt-button{display:inline-flex!important;align-items:center;justify-content:center;gap:7px;min-width:82px;height:38px;padding:0 13px!important;border:1px solid #bfd1dd!important;border-radius:12px!important;background:#fff!important;color:#133047!important;font-size:13px!important;font-weight:850!important;line-height:1!important;box-shadow:0 4px 12px rgba(16,42,67,.05)!important;text-decoration:none!important}
.btn-primary-theme-table:hover,.pdm-table-action-btn:hover,.history-panel .dt-buttons .dt-button:hover{background:#eaf6f4!important;border-color:#0f766e!important;color:#0f665f!important;box-shadow:0 8px 18px rgba(15,118,110,.12)!important}
.pdm-export-excel i{color:#13795b}.pdm-export-pdf i{color:#b42318}.pdm-column-toggle i{color:#174d73}.pdm-table-action-btn i{font-size:17px}
.pdm-inline-filters{display:flex;align-items:end;gap:10px;flex-wrap:wrap;margin:8px 0 14px;padding:12px;border:1px solid #e0e8ef;border-radius:14px;background:#fbfdff}
.pdm-inline-filter-title{display:inline-flex;align-items:center;gap:6px;min-height:36px;padding:0 8px;color:#0f665f;font-size:12px;font-weight:900;white-space:nowrap}
.pdm-column-filter{display:grid;gap:4px;min-width:150px;margin:0}.pdm-column-filter span{color:#415467;font-size:11px;font-weight:850}.pdm-column-filter input{height:36px;border:1px solid #ccd9e4;border-radius:11px;background:#fff;padding:6px 9px;color:#14324a;font-size:13px}
.dt-button-collection.pdm-column-menu,.dt-button-collection{min-width:260px!important;border:1px solid #d7e2ea!important;border-radius:16px!important;background:#fff!important;box-shadow:0 18px 50px rgba(16,42,67,.18)!important;padding:10px!important;color:#14324a!important}
.dt-button-collection .dt-button{display:flex!important;align-items:center!important;justify-content:flex-start!important;gap:9px!important;width:100%!important;min-width:0!important;height:36px!important;margin:0 0 3px!important;padding:0 10px!important;border:0!important;border-radius:10px!important;background:#fff!important;color:#203849!important;text-align:left!important;box-shadow:none!important}
.dt-button-collection .dt-button:hover{background:#edf7f6!important;color:#0f665f!important}.dt-button-collection .dt-button.active:before{content:'✓';display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:6px;background:#0f766e;color:#fff;font-size:12px;font-weight:900}.dt-button-collection .dt-button:not(.active):before{content:'';display:inline-flex;width:18px;height:18px;border:1px solid #c9d8e3;border-radius:6px;background:#fff}.dt-button-collection-title{padding:7px 10px 10px!important;color:#102a43!important;font-size:13px!important;font-weight:900!important;border-bottom:1px solid #edf2f7!important;margin-bottom:7px!important}
.history-panel table.dataTable{border-collapse:separate!important;border-spacing:0!important;width:100%!important}.history-panel table.dataTable thead th{position:sticky;top:0;z-index:2;background:#f8fbfd!important;color:#14324a!important;border-bottom:1px solid #dbe3ef!important;font-size:12px;font-weight:900;white-space:normal;overflow-wrap:anywhere}.history-panel table.dataTable tbody td{vertical-align:middle;white-space:normal;overflow-wrap:anywhere;padding:10px 12px}.history-panel table.dataTable tbody tr:hover>*{background:#f5fbfa!important}.history-panel .dt-scroll-body{scrollbar-color:#0f766e #edf3f7;scrollbar-width:thin}.history-row-pdm>*,.pdm-highlight-row>*{background:#fff7df!important;box-shadow:inset 4px 0 0 #d9b76f}.history-row-summary>*,.pdm-average-row>*{background:#eaf6f4!important;font-weight:850;color:#0f3f45}.history-row-pdm .badge{margin-left:6px;vertical-align:middle}.history-panel .badge{border-radius:999px;font-size:11px;padding:.35rem .55rem}.history-panel .dt-processing{border:1px solid #dbe3ef!important;border-radius:14px!important;background:#fff!important;color:#102a43!important;font-weight:850!important;box-shadow:0 12px 30px rgba(16,42,67,.12)!important}
.pdm-filter-panel{display:none!important}
@media (max-width:768px){.pdm-inline-filters{display:grid;grid-template-columns:1fr}.pdm-column-filter{min-width:0}.history-panel .dt-layout-row{align-items:stretch}.history-panel .dt-layout-cell{width:100%}.history-panel .dt-search,.history-panel .dt-search input,.history-panel .dt-length{width:100%}}

/* App Shell */
.app-shell-body{background:#eef5f8;color:#172b3a;min-height:100vh}.app-shell{display:flex;min-height:100vh;background:linear-gradient(180deg,#f4f9fb 0%,#edf4f8 100%)}.app-main{flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}.app-content{width:100%;max-width:1540px;margin:0 auto;padding:24px 28px 28px;flex:1}.app-sidebar-backdrop{display:none}

/* Sidebar */
.app-sidebar{width:292px;min-width:292px;height:100vh;position:sticky;top:0;display:flex;flex-direction:column;padding:22px;background:linear-gradient(180deg,#092133 0%,#0d4652 58%,#0f665f 100%);color:#fff;overflow:auto;z-index:50}.app-sidebar-brand{display:flex;align-items:center;gap:14px;margin-bottom:26px}.app-sidebar-brand img{width:54px;height:54px;object-fit:contain;background:#fff;border-radius:14px;padding:5px;box-shadow:0 10px 24px rgba(0,0,0,.14)}.app-sidebar-brand strong{display:block;font-size:22px;line-height:1;color:#fff}.app-sidebar-brand span{display:block;margin-top:5px;color:#bdd8d9;font-size:13px;font-weight:700}.app-sidebar-nav{display:grid;gap:7px}.app-nav-link{display:flex;align-items:center;gap:10px;min-height:44px;padding:10px 12px;border-radius:14px;color:#dceff0;text-decoration:none;font-weight:750;transition:background .15s ease,color .15s ease,transform .15s ease}.app-nav-link i{font-size:19px}.app-nav-link:hover,.app-nav-link.active{background:rgba(255,255,255,.13);color:#fff}.app-nav-link.active{box-shadow:inset 3px 0 0 #d9b76f}.app-nav-link.is-disabled{opacity:.48;cursor:not-allowed}.app-session-card{margin-top:auto;padding:14px;border:1px solid rgba(255,255,255,.16);border-radius:16px;background:rgba(255,255,255,.08);color:#e7f6f4}.app-session-card span{display:block;color:#b9d8d6;font-size:12px;font-weight:850}.app-session-card strong{display:block;margin:4px 0 8px;color:#fff;font-size:18px}.app-session-progress{height:7px;border-radius:999px;background:rgba(255,255,255,.18);overflow:hidden}.app-session-progress i{display:block;height:100%;width:100%;border-radius:inherit;background:#d9b76f}.app-session-card.is-ending .app-session-progress i{background:#ef4444}.app-session-card.is-ending strong{color:#fecaca}

/* Topbar */
.app-topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:72px;padding:14px 28px;background:rgba(255,255,255,.92);border-bottom:1px solid #dce7ee;backdrop-filter:blur(12px)}.app-topbar-left,.app-topbar-right{display:flex;align-items:center;gap:12px;min-width:0}.app-menu-toggle{display:none;width:42px;height:42px;border:1px solid #d4e1ea;border-radius:13px;background:#fff;color:#123047}.app-menu-toggle i{font-size:21px}.app-route-label{color:#0f665f;font-size:13px;font-weight:850;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-phase-badge{display:inline-flex;align-items:center;min-height:32px;padding:0 11px;border-radius:999px;background:#fff3cd;color:#7a5600;border:1px solid rgba(217,183,111,.45);font-size:12px;font-weight:900}.app-user-pill{display:inline-flex;align-items:center;gap:7px;min-height:36px;border-radius:999px;background:#f7fbfc;border:1px solid #dce7ee;padding:0 13px;color:#14324a;font-weight:800}.app-logout-btn{display:inline-flex;align-items:center;gap:6px;border-radius:11px;font-weight:800}

/* Page Headers */
.app-page-header{margin-bottom:22px;padding:22px;border:1px solid rgba(15,118,110,.12);border-radius:22px;background:#fff;box-shadow:0 16px 40px rgba(16,42,67,.06)}.app-page-header nav{margin-bottom:8px;color:#0f766e;font-size:13px;font-weight:850}.app-page-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.app-page-header h1{margin:0;color:#102a43;font-size:32px;font-weight:900;letter-spacing:0}.app-page-header p{max-width:820px;margin:7px 0 0;color:#667085;font-size:15px;line-height:1.55}.app-page-badges{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.app-page-badges span{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;background:#edf7f6;color:#0f665f;border:1px solid #cfe6e3;font-size:12px;font-weight:850}

/* Cards */
.app-card{background:#fff;border:1px solid #dce7ee;border-radius:20px;padding:18px;box-shadow:0 14px 35px rgba(16,42,67,.06)}.app-card h2{margin:0 0 12px;color:#102a43;font-size:18px;font-weight:900}.app-card-grid{display:grid;gap:16px;margin-bottom:22px}.app-card-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.app-action-card{display:block;min-height:178px;padding:18px;border:1px solid #dce7ee;border-radius:20px;background:#fff;color:#102a43;text-decoration:none;box-shadow:0 12px 30px rgba(16,42,67,.05);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.app-action-card:hover{transform:translateY(-2px);border-color:#0f766e;box-shadow:0 18px 36px rgba(16,42,67,.10)}.app-action-card i{display:grid;place-items:center;width:42px;height:42px;margin-bottom:14px;border-radius:14px;background:#eaf6f4;color:#0f665f;font-size:22px}.app-action-card span{display:block;color:#667085;font-size:13px;font-weight:850}.app-action-card strong{display:block;margin-top:4px;font-size:22px;line-height:1.2;color:#102a43}.app-action-card em{display:block;margin-top:8px;color:#0f766e;font-size:13px;font-style:normal;font-weight:750}.app-quick-actions{display:flex;gap:10px;flex-wrap:wrap}.app-status-list{display:grid;gap:10px}.app-status-list>div{display:grid;grid-template-columns:88px 1fr auto;gap:10px;align-items:center;padding:12px;border:1px solid #dce7ee;border-radius:14px;background:#fbfdff}.app-status-list strong{color:#0f766e}.app-status-list span{font-weight:800;color:#102a43}.app-status-list small{color:#667085}

/* Footer */
.app-footer{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:auto;padding:16px 28px;border-top:1px solid #dce7ee;background:#fff;color:#5f7280;font-size:12px;font-weight:700}.app-footer span:last-child{white-space:nowrap;color:#0f665f}

/* Shell compatibility */
.history-main,.history-standalone{max-width:none}.panel.history-panel{border-radius:20px}.history-panel.app-card{overflow:hidden}.history-kpi-grid{margin-bottom:22px}.history-dashboard-link{color:inherit}.topbar-actions{display:flex;align-items:center;gap:10px}

@media (max-width:1180px){.app-card-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.app-page-header-row{flex-direction:column}.app-page-badges{justify-content:flex-start}.app-status-list>div{grid-template-columns:1fr}}
@media (max-width:1024px){.app-shell{display:block}.app-sidebar{position:fixed;left:0;top:0;bottom:0;transform:none;transition:transform .2s ease;box-shadow:20px 0 60px rgba(16,42,67,.24)}.app-shell.sidebar-open .app-sidebar{transform:translateX(0)}.app-sidebar-backdrop{position:fixed;inset:0;background:rgba(9,33,51,.48);z-index:45}.app-shell.sidebar-open .app-sidebar-backdrop{display:block}.app-menu-toggle{display:grid;place-items:center}.app-content{padding:20px}.app-topbar{padding:12px 20px}.app-topbar-right{margin-left:auto}.app-route-label{max-width:42vw}.app-footer{padding:15px 20px;flex-direction:column;align-items:flex-start}.app-sidebar-locked{overflow:hidden}}
@media (max-width:640px){.app-card-grid-4{grid-template-columns:1fr}.app-topbar{align-items:flex-start}.app-topbar-right{flex-wrap:wrap;justify-content:flex-end}.app-phase-badge{display:none}.app-user-pill{max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-page-header{padding:18px}.app-page-header h1{font-size:25px}.app-content{padding:16px}.app-action-card{min-height:auto}.app-status-list>div{grid-template-columns:1fr}.app-footer span:last-child{white-space:normal}}

/* Phase 2.1 table behavior fixes */
.history-panel .dt-scroll,.history-panel .dataTables_scroll{width:100%;overflow:visible}.history-panel .dt-scroll-body,.history-panel .dataTables_scrollBody{overflow-x:auto!important;overflow-y:auto;scrollbar-width:auto;scrollbar-color:#0f766e #dfeaf0;border-bottom:1px solid #dce7ee}.history-panel .dt-scroll-body::-webkit-scrollbar,.history-panel .dataTables_scrollBody::-webkit-scrollbar{height:13px}.history-panel .dt-scroll-body::-webkit-scrollbar-track,.history-panel .dataTables_scrollBody::-webkit-scrollbar-track{background:#dfeaf0;border-radius:999px}.history-panel .dt-scroll-body::-webkit-scrollbar-thumb,.history-panel .dataTables_scrollBody::-webkit-scrollbar-thumb{background:#0f766e;border-radius:999px;border:3px solid #dfeaf0}.history-panel table.dataTable tbody td,.history-panel table.dataTable thead th{white-space:normal!important;overflow-wrap:anywhere!important}.pdm-column-panel{position:fixed;top:44px;left:0;z-index:80;display:none;width:min(420px,calc(100vw - 40px));max-height:460px;padding:14px;border:1px solid #d6e2ea;border-radius:16px;background:#fff;box-shadow:0 24px 70px rgba(16,42,67,.22);overflow:hidden}.pdm-column-panel.is-open{display:block}.pdm-column-panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #edf2f7}.pdm-column-panel-head strong{color:#102a43;font-size:15px}.pdm-column-panel-head button{width:30px;height:30px;border:0;border-radius:9px;background:#eef6f6;color:#0f665f;font-size:20px;line-height:1}.pdm-column-panel-actions{display:flex;gap:8px;margin-bottom:10px}.pdm-column-panel-actions button{height:34px;border:1px solid #c9d8e3;border-radius:10px;background:#fff;color:#14324a;font-size:12px;font-weight:850;padding:0 10px}.pdm-column-panel-actions button:hover{border-color:#0f766e;background:#eaf6f4;color:#0f665f}.pdm-column-panel-list{display:grid;gap:5px;max-height:330px;overflow:auto;padding-right:4px}.pdm-column-choice{display:flex;align-items:center;gap:9px;min-height:36px;margin:0;padding:7px 9px;border-radius:10px;color:#203849;font-size:13px;font-weight:800;cursor:pointer}.pdm-column-choice:hover{background:#f3faf9}.pdm-column-choice input{width:17px;height:17px;accent-color:#0f766e}.pdm-column-choice:has(input:checked){background:#eaf6f4;color:#0f665f}.dt-layout-cell:has(.pdm-column-panel){position:relative}.pdm-table-action-btn{position:relative}.history-panel .dt-layout-row:first-child{position:relative}.history-panel .dt-container{overflow:visible}.history-panel .badge{display:inline-flex;align-items:center;white-space:nowrap}.history-panel .dt-scroll-head{overflow:hidden!important}

/* Profile And Appendix Enhancements */
.pdm-profile-hero{display:flex;align-items:center;gap:18px;padding:22px!important;background:linear-gradient(135deg,#ffffff 0%,#eef8f7 100%)}
.pdm-profile-hero img{width:82px;height:82px;object-fit:contain;border-radius:18px;background:#fff;padding:8px;box-shadow:0 12px 26px rgba(16,42,67,.12)}
.pdm-profile-hero span{display:block;color:#0f766e;font-size:13px;font-weight:900;margin-bottom:4px}
.pdm-profile-hero h2{margin:0 0 6px!important;font-size:27px!important;color:#102a43}
.pdm-profile-hero p{margin:0 0 10px;color:#526779;max-width:760px}
.pdm-profile-table th{white-space:nowrap;color:#14324a;background:#f8fbfd}.pdm-profile-table td{vertical-align:middle}.pdm-profile-table .badge{margin-left:5px}
.history-empty-chart{min-height:170px;display:grid;place-items:center;margin:0;border:1px dashed #c8d5df;border-radius:14px;background:#fbfdff;color:#667085;font-weight:800;text-align:center;padding:18px}
@media (max-width:640px){.pdm-profile-hero{align-items:flex-start;flex-direction:column}.pdm-profile-hero img{width:70px;height:70px}.pdm-profile-hero h2{font-size:23px!important}}


.history-context-note{margin:-8px 0 18px;color:#526779;font-size:13px;font-weight:750}
.history-mini-chart{height:100%;min-height:260px;padding:14px;border:1px solid #dce7ee;border-radius:16px;background:#fbfdff}
.history-mini-chart h3{margin:0 0 10px;color:#102a43;font-size:15px;font-weight:900}


.pdm-inline-select{display:grid;gap:5px;min-width:260px;margin:0;color:#14324a;font-size:12px;font-weight:900}
.pdm-inline-select select{min-height:38px;border-radius:12px;border-color:#cbd8e3;background:#fff;color:#14324a;font-weight:750}
#appendixIndicatorAnalysis canvas{max-height:360px}

/* Loading States */
.history-panel,
.app-card {
  position: relative;
}

.history-panel.is-loading canvas {
  opacity: .35;
}

.pdm-loader-overlay {
  position: absolute;
  inset: 0;
  z-index: 8;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 10px;
  padding: 18px;
  border-radius: inherit;
  background: rgba(255, 255, 255, .72);
  color: #0f665f;
  font-size: 13px;
  font-weight: 900;
  text-align: center;
  backdrop-filter: blur(2px);
}

.pdm-loader-overlay span {
  display: block;
}

.pdm-spinner {
  width: 34px;
  height: 34px;
  border: 3px solid #dbe9e8;
  border-top-color: #0f766e;
  border-radius: 50%;
  animation: pdm-spin .8s linear infinite;
}

.pdm-table-skeleton {
  display: grid;
  gap: 10px;
  margin: 8px 0 14px;
  padding: 10px 0;
}

.pdm-table-skeleton i,
.pdm-skeleton-card span,
.pdm-skeleton-card strong,
.pdm-skeleton-card em,
.pdm-mini-skeleton span,
.pdm-mini-skeleton strong,
.pdm-mini-skeleton em {
  display: block;
  border-radius: 999px;
  background: linear-gradient(90deg, #eef4f7 0%, #fbfdff 45%, #e5eef3 90%);
  background-size: 220% 100%;
  animation: pdm-shimmer 1.25s ease-in-out infinite;
}

.pdm-table-skeleton i {
  height: 18px;
}

.pdm-table-skeleton i:nth-child(1) {
  width: 70%;
  height: 28px;
}

.pdm-table-skeleton i:nth-child(2n) {
  width: 92%;
}

.pdm-table-skeleton i:nth-child(3n) {
  width: 84%;
}

.pdm-skeleton-card span,
.pdm-mini-skeleton span {
  width: 58%;
  height: 13px;
}

.pdm-skeleton-card strong {
  width: 48%;
  height: 31px;
  margin: 12px 0;
}

.pdm-skeleton-card em {
  width: 70%;
  height: 12px;
}

.pdm-mini-skeleton {
  min-height: 260px;
}

.pdm-mini-skeleton strong {
  width: 88%;
  height: 150px;
  margin: 18px 0;
  border-radius: 18px;
}

.pdm-mini-skeleton em {
  width: 42%;
  height: 12px;
}

@keyframes pdm-spin {
  to { transform: rotate(360deg); }
}

@keyframes pdm-shimmer {
  0% { background-position: 160% 0; }
  100% { background-position: -160% 0; }
}

@media (prefers-reduced-motion: reduce) {
  .pdm-spinner,
  .pdm-table-skeleton i,
  .pdm-skeleton-card span,
  .pdm-skeleton-card strong,
  .pdm-skeleton-card em,
  .pdm-mini-skeleton span,
  .pdm-mini-skeleton strong,
  .pdm-mini-skeleton em {
    animation: none;
  }
}


.history-radar-panel canvas {
  max-height: 320px;
}

@media (max-width: 991.98px) {
  .history-radar-panel canvas {
    max-height: 360px;
  }
}



/* Historical Data Administration */
.admin-history-shell {
  overflow: hidden;
}

.app-admin-alert {
  display: flex;
  align-items: center;
  gap: 9px;
  border-radius: 16px;
  font-weight: 750;
}

.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 4px 4px 14px;
  border-bottom: 1px solid #dce7ee;
}

.admin-tabs .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 40px;
  border-radius: 13px;
  color: #14324a;
  font-size: 13px;
  font-weight: 900;
}

.admin-tabs .nav-link.active {
  background: linear-gradient(135deg, #174d73, #0f766e);
  color: #fff;
}

.admin-tab-content {
  padding-top: 18px;
}

.admin-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.admin-section-head h2 {
  margin: 0 0 5px;
  color: #102a43;
  font-size: 20px;
  font-weight: 900;
}

.admin-section-head p {
  margin: 0;
  max-width: 820px;
  color: #5f7280;
  font-size: 13px;
}

.admin-section-head .admin-source-note {
  margin-top: 6px;
  color: #0f766e;
  font-weight: 800;
}

.admin-section-head .admin-source-note code {
  background: #e6f4f1;
  border: 1px solid #b7dfd8;
  border-radius: 999px;
  color: #075e59;
  padding: 2px 8px;
}

.admin-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
  padding: 12px;
  border: 1px solid #dce7ee;
  border-radius: 16px;
  background: #fbfdff;
}

.admin-filter-row label {
  display: grid;
  gap: 5px;
  min-width: 180px;
  flex: 1 1 180px;
  color: #14324a;
  font-size: 12px;
  font-weight: 900;
}

.admin-filter-row .form-control,
.admin-filter-row .form-select {
  min-height: 40px;
  border-radius: 12px;
  background: #fff;
}

.admin-history-shell .dt-container {
  color: #203849;
  font-size: 13px;
}

.admin-history-shell table.dataTable thead th {
  white-space: nowrap;
  background: #f8fbfd !important;
  color: #14324a;
  font-size: 12px;
  font-weight: 900;
}

.admin-history-shell table.dataTable tbody td {
  vertical-align: middle;
  white-space: nowrap;
}

.admin-history-shell .dt-scroll-body {
  scrollbar-color: #0f766e #dfeaf0;
}

.admin-history-shell .dt-search input,
.admin-history-shell .dt-length select {
  border: 1px solid #ccd9e4;
  border-radius: 12px;
  min-height: 38px;
  padding: 6px 10px;
}

.admin-history-shell .btn-sm {
  border-radius: 10px;
  font-weight: 800;
}

.admin-check-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.admin-check-card {
  min-height: 140px;
  padding: 16px;
  border: 1px solid #dce7ee;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,42,67,.05);
}

.admin-check-card span {
  display: block;
  color: #5f7280;
  font-size: 12px;
  font-weight: 900;
}

.admin-check-card strong {
  display: block;
  margin-top: 8px;
  color: #102a43;
  font-size: 30px;
  line-height: 1.1;
  font-weight: 900;
}

.admin-check-card em {
  display: block;
  margin-top: 8px;
  color: #0f665f;
  font-size: 12px;
  font-style: normal;
  font-weight: 750;
  line-height: 1.35;
}

.admin-check-card.is-loading span,
.admin-check-card.is-loading strong,
.admin-check-card.is-loading em {
  display: block;
  border-radius: 999px;
  color: transparent;
  background: linear-gradient(90deg, #eef4f7 0%, #fbfdff 45%, #e5eef3 90%);
  background-size: 220% 100%;
  animation: pdm-shimmer 1.25s ease-in-out infinite;
}

.admin-check-card.is-loading span { width: 64%; height: 13px; }
.admin-check-card.is-loading strong { width: 42%; height: 34px; }
.admin-check-card.is-loading em { width: 82%; height: 12px; }

.admin-modal-subtitle {
  margin: 4px 0 0;
  color: #667085;
  font-size: 13px;
  font-weight: 700;
}

.admin-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 13px;
}

.admin-field {
  display: grid;
  gap: 6px;
  color: #14324a;
  font-size: 12px;
  font-weight: 900;
}

.admin-field-wide {
  grid-column: 1 / -1;
}

.admin-field .form-control,
.admin-field .form-select {
  min-height: 42px;
  border-radius: 12px;
}

.admin-section-toggle {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.admin-section-toggle label {
  cursor: pointer;
}

.admin-section-toggle input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.admin-section-toggle span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 48px;
  height: 38px;
  border: 1px solid #c9d8e3;
  border-radius: 999px;
  background: #fff;
  color: #14324a;
  font-weight: 900;
}

.admin-section-toggle input:checked + span {
  border-color: #0f766e;
  background: #eaf6f4;
  color: #0f665f;
}

.admin-section-toggle input:disabled + span {
  opacity: .75;
  cursor: not-allowed;
}

@media (max-width: 1180px) {
  .admin-check-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 768px) {
  .admin-section-head { flex-direction: column; }
  .admin-filter-row { display: grid; grid-template-columns: 1fr; }
  .admin-filter-row label { min-width: 0; }
  .admin-edit-grid { grid-template-columns: 1fr; }
  .admin-check-grid { grid-template-columns: 1fr; }
}


/* Historical Data Administration Refinements */
.admin-management-overview {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.admin-management-overview article {
  display: grid;
  grid-template-columns: 42px 1fr;
  grid-template-areas: "icon label" "icon title";
  align-items: center;
  column-gap: 12px;
  min-height: 92px;
  padding: 16px;
  border: 1px solid #dce7ee;
  border-radius: 20px;
  background: linear-gradient(135deg, #fff 0%, #f7fbfc 100%);
  box-shadow: 0 12px 28px rgba(16,42,67,.05);
}

.admin-management-overview i {
  grid-area: icon;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: #eaf6f4;
  color: #0f665f;
  font-size: 21px;
}

.admin-management-overview span {
  grid-area: label;
  color: #667085;
  font-size: 12px;
  font-weight: 900;
}

.admin-management-overview strong {
  grid-area: title;
  color: #102a43;
  font-size: 16px;
  font-weight: 900;
}

.admin-history-shell {
  padding: 20px;
}

.admin-tabs {
  gap: 10px;
  padding: 0 0 16px;
  margin-bottom: 16px;
}

.admin-tabs .nav-link {
  border: 1px solid #d6e2ea;
  background: #fff;
  box-shadow: 0 6px 16px rgba(16,42,67,.04);
}

.admin-tabs .nav-link:not(.active):hover {
  border-color: #0f766e;
  background: #edf8f6;
  color: #0f665f;
}

.admin-tab-content {
  min-height: 520px;
}

.admin-section-head {
  margin-bottom: 18px;
  padding: 14px 16px;
  border: 1px solid #e2ebf1;
  border-radius: 18px;
  background: #fbfdff;
}

.admin-section-head h2 {
  font-size: 21px;
}

.admin-filter-row {
  align-items: end;
  margin-bottom: 18px;
  padding: 14px;
  border-radius: 18px;
}

.admin-filter-row label {
  max-width: 360px;
}

.admin-history-shell .dt-layout-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 12px 0;
  flex-wrap: wrap;
}

.admin-history-shell .dt-layout-cell {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.admin-history-shell table.dataTable {
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

.admin-history-shell table.dataTable thead th {
  padding: 12px 14px;
  border-bottom: 1px solid #dce7ee !important;
}

.admin-history-shell table.dataTable tbody td {
  padding: 11px 14px;
}

.admin-history-shell table.dataTable tbody tr:hover > * {
  background: #f6fbfa !important;
}

.admin-history-shell .dt-scroll-body,
.admin-history-shell .dataTables_scrollBody {
  scrollbar-color: #0f766e #dfeaf0;
  scrollbar-width: thin;
  border-bottom: 1px solid #dce7ee;
}

.admin-history-shell .dt-info {
  color: #526779;
  font-size: 13px;
  font-weight: 750;
}

.admin-row-actions {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
}

.admin-row-actions .btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 32px;
}

.admin-appendix-ii-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.admin-segmented {
  display: inline-flex;
  gap: 8px;
  padding: 5px;
  border: 1px solid #d6e7eb;
  border-radius: 16px;
  background: #f8fcfd;
}

.admin-segmented button {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 38px;
  padding: 8px 12px;
  border: 0;
  border-radius: 12px;
  color: #0b2e4a;
  background: transparent;
  font-weight: 850;
}

.admin-segmented button:hover,
.admin-segmented button.active {
  color: #fff;
  background: #0f766e;
  box-shadow: 0 10px 24px rgba(15,118,110,.18);
}

.admin-calculate-points-btn {
  min-height: 42px;
}

.admin-history-shell .admin-long-cell {
  min-width: 260px;
  max-width: 420px;
}

.admin-history-shell .admin-medium-cell {
  min-width: 160px;
  max-width: 240px;
}

.admin-history-shell .admin-nowrap,
.admin-history-shell .admin-actions-cell {
  white-space: nowrap !important;
}

.admin-long-text {
  display: block;
  max-width: 420px;
  white-space: normal;
  overflow-wrap: break-word;
  line-height: 1.35;
}

.admin-table-skeleton {
  display: grid;
  gap: 10px;
  margin: 8px 0 16px;
  padding: 8px 0;
}

.admin-table-skeleton i {
  display: block;
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, #eef4f7 0%, #fbfdff 45%, #e5eef3 90%);
  background-size: 220% 100%;
  animation: pdm-shimmer 1.25s ease-in-out infinite;
}

.admin-table-skeleton i:nth-child(1) { width: 72%; height: 30px; }
.admin-table-skeleton i:nth-child(2n) { width: 94%; }
.admin-table-skeleton i:nth-child(3n) { width: 86%; }

.admin-section-toggle {
  align-items: center;
}

.admin-section-toggle label {
  position: relative;
  display: inline-flex !important;
  margin: 0;
}

.admin-section-toggle input[type="checkbox"] {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
}

.admin-section-toggle label > span {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-width: 46px;
  height: 38px;
  padding: 0 14px;
  border: 1px solid #c9d8e3;
  border-radius: 999px;
  background: #fff;
  color: #14324a;
  font-size: 14px;
  font-weight: 900;
}

.admin-section-toggle input[type="checkbox"]:checked + span {
  border-color: #0f766e;
  background: #eaf6f4;
  color: #0f665f;
  box-shadow: inset 0 0 0 1px rgba(15,118,110,.12);
}

.admin-section-toggle input[type="checkbox"]:focus-visible + span {
  outline: 3px solid rgba(217,183,111,.42);
  outline-offset: 2px;
}

.admin-edit-grid small {
  display: block;
  margin-top: 8px;
  color: #667085;
  font-size: 12px;
  font-weight: 700;
}

@media (max-width: 1180px) {
  .admin-management-overview { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .admin-table-skeleton i { animation: none; }
}


/* Submission 2026 */
.submission-page {
  display: grid;
  gap: 22px;
}

.submission-context-grid,
.submission-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.submission-kpi-grid {
  grid-template-columns: repeat(7, minmax(160px, 1fr));
}

.submission-context-card {
  min-height: 112px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
}

.submission-context-card span,
.submission-context-card em,
.submission-live-counts span,
.submission-param-card small,
.submission-baseline-editor small {
  color: #667085;
  font-size: 13px;
  font-style: normal;
  font-weight: 750;
}

.submission-context-card strong {
  color: #102a43;
  font-size: 26px;
  font-weight: 950;
  line-height: 1.05;
}

.submission-context-card.is-warning {
  border-color: #e8d6a9;
  background: linear-gradient(135deg, #fff 0%, #fff8e7 100%);
}

.submission-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.submission-card-head h2 {
  margin: 0 0 7px;
  color: #102a43;
  font-size: 20px;
  font-weight: 950;
}

.submission-card-head p {
  margin: 0;
  color: #526779;
  font-size: 14px;
  line-height: 1.5;
}

.submission-section-picker {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.submission-section-option {
  position: relative;
  display: block;
  cursor: pointer;
}

.submission-section-option input {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.submission-section-option span {
  min-height: 102px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  padding: 14px;
  border: 1px solid #d6e4ec;
  border-radius: 18px;
  background: #fff;
  color: #102a43;
  box-shadow: 0 8px 22px rgba(16, 42, 67, .04);
  transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.submission-section-option strong {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 13px;
  background: #edf7f6;
  color: #0f665f;
  font-size: 18px;
  font-weight: 950;
}

.submission-section-option em {
  color: #526779;
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.3;
}

.submission-section-option input:checked + span {
  border-color: #0f766e;
  background: linear-gradient(135deg, #ffffff 0%, #edf8f6 100%);
  box-shadow: 0 12px 28px rgba(15, 118, 110, .12);
}

.submission-section-option input:checked + span strong {
  background: #0f766e;
  color: #fff;
}

.submission-section-option.is-required span {
  border-color: #d9b76f;
  background: #fffaf0;
}

.submission-section-warning {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  padding: 11px 13px;
  border-radius: 14px;
  font-size: 13px;
  font-weight: 850;
}

.submission-section-warning.is-ok {
  background: #e7f6f1;
  color: #047857;
}

.submission-section-warning.is-warn {
  background: #fff5db;
  color: #8a5a00;
}

.submission-a4-pair {
  display: grid;
  gap: 7px;
  max-width: 460px;
  margin-top: 18px;
}

.submission-a4-pair span,
.submission-param-card label span,
.submission-evidence-grid label span,
.submission-baseline-editor label span {
  color: #34495e;
  font-size: 13px;
  font-weight: 850;
}

.submission-live-summary {
  display: grid;
  gap: 16px;
}

.submission-live-total {
  padding: 15px;
  border-radius: 18px;
  background: linear-gradient(135deg, #073447 0%, #0f766e 100%);
  color: #fff;
}

.submission-live-total span {
  display: block;
  font-size: 13px;
  font-weight: 800;
  opacity: .86;
}

.submission-live-total strong {
  display: block;
  margin-top: 5px;
  font-size: 34px;
  font-weight: 950;
}

.submission-section-bars {
  display: grid;
  gap: 10px;
}

.submission-section-bar {
  display: grid;
  grid-template-columns: 26px 1fr 86px;
  align-items: center;
  gap: 10px;
}

.submission-section-bar span,
.submission-section-bar strong {
  color: #102a43;
  font-size: 13px;
  font-weight: 900;
}

.submission-section-bar div {
  height: 9px;
  overflow: hidden;
  border-radius: 999px;
  background: #edf3f7;
}

.submission-section-bar i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: #9bb3c8;
}

.submission-section-bar.is-selected i {
  background: linear-gradient(90deg, #0f766e, #d9b76f);
}

.submission-live-counts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}

.submission-live-counts span {
  padding: 9px 10px;
  border: 1px solid #dce7ee;
  border-radius: 12px;
  background: #fbfdff;
}

.submission-live-counts b {
  color: #0f665f;
}

.submission-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.submission-tabs button,
.submission-modal-tabs button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 12px;
  border: 1px solid #c9d8e3;
  border-radius: 999px;
  background: #fff;
  color: #14324a;
  font-size: 13px;
  font-weight: 850;
}

.submission-tabs button.active,
.submission-modal-tabs button.active {
  border-color: #0f766e;
  background: #0f766e;
  color: #fff;
  box-shadow: 0 10px 22px rgba(15, 118, 110, .16);
}

.submission-table-card .dt-layout-row,
.submission-runs-card .dt-layout-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin: 13px 0;
}

.submission-table-card .dt-layout-cell,
.submission-runs-card .dt-layout-cell {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.submission-table-card table.dataTable thead th,
.submission-runs-card table.dataTable thead th {
  padding: 12px 14px;
  border-bottom: 1px solid #dce7ee !important;
  background: #f7fbfc;
  color: #102a43;
  font-size: 13px;
  font-weight: 950;
}

.submission-table-card table.dataTable tbody td,
.submission-runs-card table.dataTable tbody td {
  padding: 11px 14px;
  vertical-align: middle;
  font-size: 13px;
}

.submission-section-pill,
.submission-status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 26px;
  padding: 0 9px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.submission-section-pill {
  background: #eaf6f4;
  color: #0f665f;
}

.submission-status-badge.is-ok {
  background: #dff7ec;
  color: #047857;
}

.submission-status-badge.is-warn {
  background: #fff1c7;
  color: #8a5a00;
}

.submission-status-badge.is-danger {
  background: #fee4e9;
  color: #c61f45;
}

.submission-row-actions {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
}

.submission-row-actions .btn {
  min-height: 32px;
  font-size: 12px !important;
}


.submission-table-card .dt-buttons {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
}

.submission-export-toolbar {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin: 12px 0 8px;
}

.submission-export-toolbar .pdm-table-action-btn {
  min-width: 86px;
}

.submission-table-card .dt-buttons .dt-button.submission-column-toggle,
.submission-column-toggle {
  width: 40px;
  min-width: 40px !important;
  height: 40px;
  padding: 0 !important;
  border-radius: 12px !important;
}

.submission-column-toggle i {
  margin: 0;
  font-size: 18px;
}

.submission-table-card table.dataTable thead th {
  white-space: normal;
  line-height: 1.25;
}

.submission-table-card table.dataTable tbody td {
  white-space: nowrap;
}

.submission-table-card table.dataTable tbody tr {
  cursor: pointer;
}

.submission-table-card table.dataTable tbody td.submission-wrap-cell {
  min-width: 150px;
  max-width: 300px;
  white-space: normal;
  line-height: 1.35;
}

.submission-table-card table.dataTable tbody td.submission-indicator-title-cell,
.submission-table-card table.dataTable tbody td.submission-description-cell {
  min-width: 220px;
  max-width: 340px;
}

.submission-table-card table.dataTable tbody td.submission-actions-cell {
  white-space: nowrap;
}

.submission-row-actions .submission-icon-action {
  width: 38px;
  min-width: 38px;
  height: 38px;
  min-height: 38px;
  padding: 0 !important;
  border-radius: 12px !important;
}

.submission-row-actions .submission-icon-action i {
  margin: 0;
  font-size: 17px;
}

.submission-row-actions .submission-icon-action:hover {
  transform: translateY(-1px);
}

.submission-modal .modal-header,
.submission-modal .modal-footer {
  border-color: #dce7ee;
}

.submission-modal .modal-title {
  color: #102a43;
  font-size: 22px;
  font-weight: 950;
}

.submission-modal-subtitle {
  margin: 4px 0 0;
  color: #526779;
  font-size: 13px;
  font-weight: 750;
}

.submission-modal-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
}

.submission-modal-content {
  min-height: 420px;
}

/* Submission indicator modal navigation */
.submission-modal-footer {
  justify-content: space-between;
  gap: 12px;
}
.submission-footer-actions,
.submission-indicator-nav {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.submission-footer-actions {
  justify-content: flex-end;
}
.submission-indicator-nav-top {
  justify-content: space-between;
  margin: -4px 0 18px;
  padding: 10px 12px;
  border: 1px solid #d7e7ea;
  border-radius: 14px;
  background: #f8fcfd;
}
.submission-indicator-nav-status {
  display: grid;
  gap: 2px;
  min-width: 170px;
  text-align: center;
}
.submission-indicator-nav-status strong {
  color: #102a43;
  font-size: 13px;
  font-weight: 950;
}
.submission-indicator-nav-status span {
  color: #667085;
  font-size: 12px;
  font-weight: 700;
}
.submission-nav-btn {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 38px;
  padding: 0 13px !important;
  border: 1px solid #0f766e !important;
  border-radius: 12px !important;
  background: #fff !important;
  color: #0f665f !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  box-shadow: 0 4px 12px rgba(16,42,67,.05) !important;
}
.submission-nav-btn:hover:not(:disabled) {
  background: #eaf6f4 !important;
  box-shadow: 0 8px 18px rgba(15,118,110,.12) !important;
}
.submission-nav-btn:disabled {
  cursor: not-allowed;
  border-color: #cbdced !important;
  background: #f3f7fa !important;
  color: #8a9aaa !important;
  opacity: .72;
  box-shadow: none !important;
}
.submission-nav-btn i {
  font-size: 16px;
  line-height: 1;
}
@media (max-width: 760px) {
  .submission-modal-footer,
  .submission-footer-actions,
  .submission-indicator-nav-top {
    align-items: stretch;
    flex-direction: column;
  }
  .submission-footer-actions > *,
  .submission-indicator-nav-top > * {
    width: 100%;
  }
}

.submission-modal-grid,
.submission-evidence-grid,
.submission-param-grid {
  display: grid;
  gap: 14px;
}

.submission-modal-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.submission-modal-grid article {
  padding: 14px;
  border: 1px solid #dce7ee;
  border-radius: 16px;
  background: #fbfdff;
}

.submission-modal-grid span {
  display: block;
  color: #667085;
  font-size: 12px;
  font-weight: 850;
}

.submission-modal-grid strong {
  display: block;
  margin-top: 5px;
  color: #102a43;
  font-size: 17px;
  font-weight: 950;
}

.submission-rich-text,
.submission-formula-box,
.submission-baseline-editor,
.submission-inline-info,
.submission-note-list {
  margin-top: 16px;
  padding: 16px;
  border: 1px solid #dce7ee;
  border-radius: 18px;
  background: #fff;
}

.submission-rich-text h3,
.submission-formula-box h3,
.submission-note-list h3 {
  margin: 0 0 8px;
  color: #102a43;
  font-size: 16px;
  font-weight: 950;
}

.submission-rich-text p,
.submission-formula-box p,
.submission-note-list li {
  color: #34495e;
  line-height: 1.62;
}

.submission-param-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.submission-param-card {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid #dce7ee;
  border-radius: 18px;
  background: #fbfdff;
}

.submission-param-card label,
.submission-baseline-editor label,
.submission-evidence-grid label {
  display: grid;
  gap: 7px;
}

.submission-param-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.submission-calc-result {
  padding: 18px;
  border: 1px solid #bfe1dc;
  border-radius: 20px;
  background: linear-gradient(135deg, #f7fffd 0%, #eaf6f4 100%);
}

.submission-calc-result.has-warning {
  border-color: #ebd3a0;
  background: #fff8e7;
}

.submission-calc-result span,
.submission-calc-result em {
  display: block;
  color: #526779;
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
}

.submission-calc-result strong {
  display: block;
  margin: 5px 0;
  color: #102a43;
  font-size: 34px;
  font-weight: 950;
}

.submission-inline-warning,
.submission-inline-info {
  color: #8a5a00;
  background: #fff8e7;
  font-weight: 850;
}

.submission-inline-warning {
  display: flex;
  gap: 8px;
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 12px;
}

.submission-baseline-editor {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.submission-baseline-editor label:nth-child(3),
.submission-baseline-editor small {
  grid-column: 1 / -1;
}

.submission-evidence-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.submission-evidence-wide {
  grid-column: 1 / -1;
}

.submission-history-list {
  display: grid;
  gap: 11px;
}

.submission-history-list article {
  padding: 13px;
  border: 1px solid #dce7ee;
  border-radius: 15px;
  background: #fbfdff;
}

.submission-history-list span,
.submission-history-list em {
  color: #667085;
  font-size: 12px;
  font-style: normal;
  font-weight: 750;
}

.submission-history-list strong {
  display: block;
  margin-top: 4px;
  color: #102a43;
  font-weight: 950;
}

.submission-save-state {
  margin-right: auto;
  color: #0f665f;
  font-size: 13px;
  font-weight: 900;
}

.submission-empty-state {
  padding: 18px;
  border-radius: 18px;
  background: #f7fbfc;
  color: #526779;
  font-weight: 800;
}

.submission-table-skeleton,
.submission-summary-skeleton,
.submission-modal-skeleton {
  display: grid;
  gap: 10px;
  padding: 8px 0 16px;
}

.submission-table-skeleton i,
.submission-summary-skeleton i,
.submission-modal-skeleton i {
  display: block;
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, #edf4f8 0%, #ffffff 45%, #e4eef4 90%);
  background-size: 220% 100%;
  animation: pdm-shimmer 1.25s ease-in-out infinite;
}

.submission-table-skeleton i:nth-child(1),
.submission-modal-skeleton i:nth-child(1) { width: 68%; height: 30px; }
.submission-table-skeleton i:nth-child(2n),
.submission-summary-skeleton i:nth-child(2n),
.submission-modal-skeleton i:nth-child(2n) { width: 92%; }
.submission-table-skeleton i:nth-child(3n),
.submission-summary-skeleton i:nth-child(3n),
.submission-modal-skeleton i:nth-child(3n) { width: 78%; }

@media (max-width: 1320px) {
  .submission-kpi-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .submission-section-picker { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 992px) {
  .submission-context-grid,
  .submission-modal-grid,
  .submission-param-grid,
  .submission-evidence-grid,
  .submission-baseline-editor { grid-template-columns: 1fr; }
  .submission-kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .submission-card-head { flex-direction: column; }
  .submission-baseline-editor label:nth-child(3),
  .submission-baseline-editor small { grid-column: auto; }
}

@media (max-width: 640px) {
  .submission-kpi-grid,
  .submission-section-picker,
  .submission-live-counts,
  .submission-param-row { grid-template-columns: 1fr; }
  .submission-row-actions { flex-direction: row; align-items: center; justify-content: flex-start; }
}


.submission-live-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
  max-width: 560px;
}

.submission-live-actions .btn {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.submission-demo-btn {
  background: linear-gradient(135deg, #0f766e 0%, #d9a441 100%) !important;
  border-color: transparent !important;
  color: #fff !important;
  box-shadow: 0 12px 26px rgba(15, 118, 110, .18);
}

.submission-clear-btn {
  border-color: #f3b6c1 !important;
  color: #b42342 !important;
  background: #fff !important;
}

.submission-clear-btn:hover {
  background: #fff1f4 !important;
}

.submission-source-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  margin-left: 6px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 950;
  white-space: nowrap;
}

.submission-source-badge.is-demo {
  background: #fff1c7;
  color: #8a5a00;
}

.submission-source-badge.is-known {
  background: #dff7ec;
  color: #047857;
}

.submission-source-badge.is-manual {
  background: #eaf2ff;
  color: #155eef;
}

.submission-metric-with-diff,
.submission-previous-metric {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  max-width: 100%;
}
.submission-previous-metric small {
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
}
.submission-diff-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 950;
  white-space: nowrap;
}
.submission-diff-badge.is-positive {
  background: #dff7ec;
  color: #047857;
}
.submission-diff-badge.is-neutral {
  background: #edf3f7;
  color: #475467;
}
.submission-diff-badge.is-negative {
  background: #fee8dc;
  color: #b54708;
}

.submission-live-source {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 12px;
  border: 1px solid #dce7ee;
  border-radius: 16px;
  background: #fbfdff;
}

.submission-live-source > span {
  grid-column: 1 / -1;
  color: #102a43;
  font-size: 13px;
  font-weight: 950;
}

.submission-live-source div {
  color: #526779;
  font-size: 12px;
  font-weight: 850;
}

.submission-live-source b {
  color: #0f665f;
}

.submission-demo-warning {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  padding: 12px 14px;
  border: 1px solid #f0d18a;
  border-radius: 15px;
  background: #fff8e7;
  color: #8a5a00;
  font-size: 13px;
  font-weight: 900;
}

.submission-btn-spinner {
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255,255,255,.45);
  border-top-color: #fff;
  border-radius: 50%;
  animation: pdm-spin .7s linear infinite;
}

.submission-clear-btn .submission-btn-spinner,
.pdm-table-action-btn .submission-btn-spinner {
  border-color: rgba(15, 102, 95, .22);
  border-top-color: #0f665f;
}

.submission-swal-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  color: #102a43;
  font-size: 14px;
  font-weight: 800;
}

.submission-swal-check input {
  width: 17px;
  height: 17px;
  accent-color: #0f766e;
}

@keyframes pdm-spin {
  to { transform: rotate(360deg); }
}

@media (max-width: 992px) {
  .submission-live-actions { justify-content: flex-start; max-width: none; }
}

@media (max-width: 640px) {
  .submission-live-actions .btn { width: 100%; }
  .submission-live-source { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .submission-table-skeleton i,
  .submission-summary-skeleton i,
  .submission-modal-skeleton i { animation: none; }
}


.submission-param-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.submission-param-meta span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: #eaf6f4;
  color: #0f665f;
  font-size: 12px;
  font-weight: 900;
}

.submission-formula-visual {
  display: flex;
  align-items: stretch;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 16px;
  padding: 14px;
  border: 1px solid #bfe1dc;
  border-radius: 18px;
  background: linear-gradient(135deg, #f7fffd 0%, #edf8f6 100%);
}

.submission-formula-visual span {
  min-width: 142px;
  display: grid;
  gap: 4px;
  padding: 12px;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(16, 42, 67, .05);
}

.submission-formula-visual em {
  color: #667085;
  font-size: 12px;
  font-style: normal;
  font-weight: 850;
}

.submission-formula-visual strong {
  color: #102a43;
  font-size: 18px;
  font-weight: 950;
}

.submission-formula-visual b {
  display: grid;
  place-items: center;
  color: #0f665f;
  font-size: 18px;
  font-weight: 950;
}

@media (max-width: 640px) {
  .submission-formula-visual { display: grid; }
  .submission-formula-visual b { transform: rotate(90deg); }
}

.submission-mini-cap {
  display: inline-flex;
  align-items: center;
  min-height: 23px;
  margin-left: 6px;
  padding: 0 8px;
  border-radius: 999px;
  background: #edf8f6;
  color: #0f665f;
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
}

/* Dashboard Overview */
.dashboard-overview,
.scenarios-page {
  display: grid;
  gap: 22px;
}
.dashboard-hero {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  background: linear-gradient(135deg, #ffffff 0%, #eef9f7 100%);
}
.dashboard-hero span {
  display: block;
  color: #0f766e;
  font-weight: 900;
  margin-bottom: 8px;
}
.dashboard-hero h2 {
  font-size: 30px;
  margin: 0 0 8px;
}
.dashboard-hero p {
  margin: 0;
  color: #52677a;
  max-width: 760px;
}
.dashboard-hero-actions,
.scenario-export-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.dashboard-kpi-grid,
.scenarios-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.dashboard-chart-grid,
.scenarios-chart-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.dashboard-chart-card {
  min-height: 360px;
  position: relative;
}
.dashboard-chart-card canvas {
  width: 100% !important;
  height: 280px !important;
}
.dashboard-chart-card.is-empty canvas {
  display: none !important;
}
.dashboard-empty-state,
.dashboard-empty-line {
  margin: 0;
  color: #667085;
  font-weight: 750;
}
.dashboard-chart-card .dashboard-empty-state:empty {
  display: none;
}
.chart-skeleton,
.table-skeleton,
.app-card-skeleton {
  display: grid;
  gap: 12px;
  padding: 8px 0;
}
.chart-skeleton::before,
.chart-skeleton::after,
.table-skeleton i,
.app-card-skeleton i {
  content: "";
  display: block;
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, #eef4f7 0%, #dfeaf0 46%, #eef4f7 100%);
  background-size: 220% 100%;
  animation: pdm-shimmer 1.25s linear infinite;
}
.chart-skeleton::before { height: 210px; border-radius: 18px; }
.chart-skeleton::after { width: 62%; }
.table-skeleton i:nth-child(1) { width: 80%; height: 24px; }
.table-skeleton i:nth-child(2) { width: 94%; }
.table-skeleton i:nth-child(3) { width: 68%; }
.dashboard-info-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.dashboard-list {
  display: grid;
  gap: 10px;
}
.dashboard-list article,
.scenarios-checklist article {
  padding: 12px;
  border: 1px solid #dce7ee;
  border-radius: 14px;
  background: #fbfdff;
}
.dashboard-list strong,
.scenarios-checklist strong {
  display: block;
  color: #102a43;
  font-weight: 900;
}
.dashboard-list span,
.scenarios-checklist span {
  display: block;
  color: #667085;
  font-size: 13px;
  margin-top: 3px;
}
.dashboard-action-list {
  display: grid;
  gap: 10px;
}
.dashboard-action-list a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px;
  border: 1px solid #dce7ee;
  border-radius: 14px;
  background: #fbfdff;
  color: #102a43;
  text-decoration: none;
  font-weight: 850;
}
.dashboard-action-list i {
  color: #0f766e;
  font-size: 20px;
}
.scenario-recommendation-box {
  display: grid;
  gap: 8px;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid #bfe4dc;
  background: #f0faf8;
}
.scenario-recommendation-box strong {
  color: #0f665f;
  font-size: 22px;
}
.scenarios-table-card .dt-layout-row {
  align-items: center;
  margin: 12px 0;
}
.scenario-detail-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.scenario-detail-grid article {
  padding: 14px;
  border: 1px solid #dce7ee;
  border-radius: 16px;
  background: #fbfdff;
}
.scenario-detail-grid span {
  display: block;
  color: #667085;
  font-weight: 800;
}
.scenario-detail-grid strong {
  display: block;
  color: #102a43;
  font-size: 22px;
}
#scenarioDetailBody section {
  margin-top: 18px;
}
#scenarioDetailBody h3 {
  font-size: 17px;
  font-weight: 900;
  color: #102a43;
}
#scenarioDetailBody section article {
  padding: 11px 12px;
  border: 1px solid #dce7ee;
  border-radius: 12px;
  margin-bottom: 8px;
  background: #fff;
}
@media (max-width: 1280px) {
  .dashboard-kpi-grid,
  .scenarios-kpis,
  .dashboard-info-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 920px) {
  .dashboard-hero { flex-direction: column; align-items: flex-start; }
  .dashboard-chart-grid,
  .scenarios-chart-grid { grid-template-columns: 1fr; }
  .scenario-detail-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .dashboard-kpi-grid,
  .scenarios-kpis,
  .dashboard-info-grid,
  .scenario-detail-grid { grid-template-columns: 1fr; }
}


/* Scenario Decision Refinements */
.scenario-score-info {
  display: grid;
  gap: 14px;
}
.scenario-score-accordion .accordion-item {
  border: 1px solid #dce7ee;
  border-radius: 14px !important;
  overflow: hidden;
  margin-bottom: 10px;
  background: #fff;
}
.scenario-score-accordion .accordion-button {
  color: #102a43;
  font-weight: 950;
  background: #fbfdff;
  box-shadow: none;
}
.scenario-score-accordion .accordion-button:not(.collapsed) {
  color: #0f665f;
  background: #edf8f6;
}
.scenario-score-accordion .accordion-body {
  color: #3c5265;
  font-weight: 650;
  line-height: 1.55;
}
.scenario-name {
  display: grid;
  gap: 6px;
  min-width: 170px;
}
.scenario-row-flags,
.scenario-section-badges,
.scenario-count-pills {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}
.scenario-mini-badge,
.scenario-diff-badge,
.scenario-count-pill {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 950;
  white-space: nowrap;
}
.scenario-mini-badge.is-current {
  background: #eaf2ff;
  color: #1f4e79;
}
.scenario-mini-badge.is-points {
  background: #fff4d8;
  color: #8a5a00;
}
.scenario-mini-badge.is-history {
  background: #e2f7f1;
  color: #047857;
}
.scenario-diff-badge.is-positive {
  background: #dff7ec;
  color: #047857;
}
.scenario-diff-badge.is-neutral {
  background: #edf3f7;
  color: #475467;
}
.scenario-diff-badge.is-negative {
  background: #fee8dc;
  color: #b54708;
}
.scenario-count-pill {
  border: 1px solid #dce7ee;
  background: #fbfdff;
  color: #475467;
}
.scenario-count-pill b {
  margin-right: 4px;
  color: #102a43;
}
.scenario-count-pill.is-demo {
  background: #fff8e7;
  border-color: #f0d28a;
  color: #8a5a00;
}
.scenario-count-pill.is-known {
  background: #edf8f6;
  border-color: #bfe4dc;
  color: #0f665f;
}
.scenario-count-pill.is-manual {
  background: #eef4ff;
  border-color: #c9d7ff;
  color: #1f4e79;
}
.scenario-progress {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-width: 118px;
  height: 26px;
  overflow: hidden;
  border-radius: 999px;
  background: #edf3f7;
  border: 1px solid #dce7ee;
}
.scenario-progress i {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0;
  background: linear-gradient(90deg, #0f766e, #9bd7d5);
}
.scenario-progress b {
  position: relative;
  z-index: 1;
  width: 100%;
  text-align: center;
  color: #102a43;
  font-size: 12px;
  font-weight: 950;
}
.scenario-status-badge {
  cursor: help;
  max-width: 230px;
  white-space: normal;
  text-align: center;
}
.scenarios-table-card table.dataTable tbody td {
  vertical-align: middle;
}
.scenarios-table-card .dt-scroll-body {
  scrollbar-width: thin;
  scrollbar-color: #0f766e #e3eef3;
}
.scenarios-table-card .dt-scroll-body::-webkit-scrollbar {
  height: 10px;
}
.scenarios-table-card .dt-scroll-body::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: #0f766e;
}
.scenario-issue-group {
  display: grid;
  gap: 8px;
  margin-top: 18px;
}
.scenario-issue-group article {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.scenario-issue-group article div {
  min-width: 0;
}
.scenario-issue-group article .btn {
  flex: 0 0 auto;
}
@media (max-width: 760px) {
  .scenario-issue-group article { align-items: flex-start; flex-direction: column; }
  .scenario-progress { min-width: 100px; }
}

/* Scenario Score Controls */
.scenario-score-controls {
  border: 1px solid #dce7ee;
  border-radius: 16px;
  background: #fbfdff;
  padding: 14px;
}
.scenario-score-controls-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}
.scenario-score-controls-head strong {
  display: block;
  color: #102a43;
  font-size: 16px;
  font-weight: 950;
}
.scenario-score-controls-head span {
  display: block;
  color: #5f7285;
  font-size: 13px;
  font-weight: 650;
}
.scenario-weight-total {
  display: inline-flex !important;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: #e2f7f1;
  color: #047857 !important;
  border: 1px solid #bfe4dc;
  font-weight: 950 !important;
  white-space: nowrap;
}
.scenario-weight-total.is-invalid {
  background: #fff4d8;
  border-color: #f0d28a;
  color: #8a5a00 !important;
}
.scenario-weight-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.scenario-weight-grid label {
  display: grid;
  grid-template-columns: 1fr 86px auto;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid #dce7ee;
  border-radius: 14px;
  background: #fff;
}
.scenario-weight-grid label span {
  color: #102a43;
  font-weight: 850;
  font-size: 13px;
}
.scenario-weight-grid input {
  text-align: right;
  font-weight: 850;
}
.scenario-weight-grid em {
  font-style: normal;
  color: #0f766e;
  font-weight: 950;
}
.scenario-score-control-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  flex-wrap: wrap;
}
.scenario-score-example {
  margin-top: 10px;
  padding: 12px;
  border-radius: 14px;
  background: #f7fbfc;
  border: 1px solid #dce7ee;
}
.scenario-score-example h3 {
  margin: 0 0 8px;
  color: #102a43;
  font-size: 15px;
  font-weight: 950;
}
.scenario-score-example code,
.scenario-score-accordion code {
  color: #0f665f;
  background: #edf8f6;
  border-radius: 8px;
  padding: 2px 6px;
  font-weight: 850;
  white-space: normal;
}
.scenario-score-example-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
.scenario-score-example-grid span {
  display: inline-flex;
  gap: 5px;
  align-items: center;
  border: 1px solid #dce7ee;
  border-radius: 999px;
  padding: 5px 10px;
  background: #fff;
  color: #3c5265;
  font-size: 12px;
  font-weight: 750;
}
.scenario-score-example-grid b {
  color: #102a43;
}
@media (max-width: 1180px) {
  .scenario-weight-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 680px) {
  .scenario-score-controls-head { align-items: flex-start; flex-direction: column; }
  .scenario-weight-grid { grid-template-columns: 1fr; }
}


/* User Management */
.user-admin-page{display:grid;gap:22px}.user-kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px}.user-admin-card{background:#fff;border:1px solid #d8e5ed;border-radius:18px;box-shadow:0 16px 34px rgba(16,42,67,.06)}.user-kpi-card{min-height:118px;padding:18px}.user-kpi-card span{display:block;color:#65758b;font-size:13px;font-weight:850}.user-kpi-card strong{display:block;margin-top:7px;color:#052b46;font-size:30px;line-height:1.1;font-weight:900}.user-kpi-card em{display:block;margin-top:7px;color:#00796b;font-size:12px;font-style:normal;font-weight:750}.user-kpi-card.is-loading span,.user-kpi-card.is-loading strong,.user-kpi-card.is-loading em{display:block;min-height:14px;border-radius:999px;background:linear-gradient(90deg,#edf4f8 25%,#f7fbfd 37%,#edf4f8 63%);background-size:400% 100%;animation:pdmShimmer 1.2s ease-in-out infinite;color:transparent}.user-kpi-card.is-loading strong{height:28px;width:55%;margin-top:12px}.user-chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.user-chart-card{position:relative;min-height:330px;padding:18px}.user-chart-card h2{font-size:19px;margin:0 0 14px;color:#082946;font-weight:900}.user-chart-card canvas{width:100%!important;height:250px!important}.user-empty-state{color:#667085;font-size:14px;margin:14px 0 0}.user-admin-shell{padding:18px;overflow:hidden}.user-admin-tabs{gap:8px;margin-bottom:14px}.user-admin-tabs .nav-link{border:1px solid transparent;border-radius:12px;font-weight:850;color:#0f5f63}.user-admin-tabs .nav-link.active{background:#0f766e;color:#fff;box-shadow:0 12px 24px rgba(15,118,110,.18)}.user-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin:4px 0 16px}.user-section-head h2{margin:0;color:#082946;font-size:21px;font-weight:900}.user-section-head p{margin:6px 0 0;color:#667085;font-size:14px}.user-admin-table,.user-audit-table{font-size:14px}.user-admin-table th,.user-audit-table th{white-space:nowrap;background:#f8fbfd!important;color:#082946}.user-admin-table td,.user-audit-table td{vertical-align:middle;white-space:nowrap}.user-actions{display:flex;align-items:center;gap:6px;flex-wrap:nowrap}.user-actions .btn{white-space:nowrap}.user-role-badge,.user-status-badge{border-radius:999px;padding:.42rem .62rem;font-weight:850}.user-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.user-form-stack{display:grid;gap:16px}.user-form-grid label,.user-form-stack label{display:grid;gap:7px;color:#344054;font-weight:800}.user-form-grid label span,.user-form-stack label span{font-size:13px}.user-form-grid b,.user-form-stack b{color:#b42318}.user-toggle-field{display:flex!important;align-items:center;gap:10px;border:1px solid #d8e5ed;border-radius:14px;padding:11px 13px;background:#f8fbfd;align-self:end}.user-toggle-field input{width:18px;height:18px}.user-modal-subtitle{margin:4px 0 0;color:#667085;font-size:13px}.user-forbidden-card{display:flex;gap:18px;align-items:flex-start;padding:24px}.user-forbidden-card>i{display:grid;place-items:center;width:54px;height:54px;border-radius:16px;background:#e7f7f4;color:#0f766e;font-size:28px}.user-forbidden-card h2{margin:0 0 8px;color:#082946;font-weight:900}.user-history-list{display:grid;gap:10px}.user-history-item{border:1px solid #d8e5ed;border-radius:14px;background:#fbfdff;padding:12px 14px}.user-history-item strong{display:block;color:#082946}.user-history-item span{display:block;margin-top:2px;color:#667085;font-size:12px;font-weight:750}.user-history-item p{margin:7px 0 0;color:#344054}.user-table-skeleton{display:grid;gap:10px;margin:12px 0}.user-table-skeleton i{height:34px;border-radius:10px;background:linear-gradient(90deg,#edf4f8 25%,#f7fbfd 37%,#edf4f8 63%);background-size:400% 100%;animation:pdmShimmer 1.2s ease-in-out infinite}.user-admin-shell .dataTables_wrapper,.user-admin-shell .dt-container{font-size:14px}.user-admin-shell .dataTables_filter input,.user-admin-shell .dt-search input{border:1px solid #cbdced;border-radius:12px;padding:8px 11px}.user-admin-shell .dataTables_length select,.user-admin-shell .dt-length select{border:1px solid #cbdced;border-radius:12px;padding:7px 30px 7px 10px}.user-admin-shell .dt-scroll-body{scrollbar-color:#0f766e #e5eff4;scrollbar-width:thin}.user-admin-shell .dt-scroll-body::-webkit-scrollbar{height:10px}.user-admin-shell .dt-scroll-body::-webkit-scrollbar-track{background:#e5eff4;border-radius:999px}.user-admin-shell .dt-scroll-body::-webkit-scrollbar-thumb{background:#0f766e;border-radius:999px}
@media (max-width:1280px){.user-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.user-chart-grid{grid-template-columns:1fr 1fr}}@media (max-width:768px){.user-kpi-grid,.user-chart-grid,.user-form-grid{grid-template-columns:1fr}.user-section-head{display:grid}.user-actions{flex-wrap:wrap}.user-chart-card canvas{height:230px!important}}



.user-actions .user-icon-action {
  width: 38px;
  min-width: 38px;
  height: 38px;
  min-height: 38px;
  padding: 0 !important;
  border-radius: 12px !important;
}
.user-actions .user-icon-action i {
  margin: 0;
  font-size: 17px;
}

/* Current Indicator Comparison */
.current-indicator-comparison .current-indicator-chart-card,
.current-indicator-comparison .current-indicator-table-wrap {
  min-height: 620px;
}
.current-indicator-comparison .current-indicator-chart-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.current-indicator-comparison .current-indicator-chart-card canvas {
  flex: 1 1 auto;
  height: 540px !important;
  min-height: 0;
}
.current-indicator-comparison .current-indicator-table-wrap {
  display: flex;
  flex-direction: column;
  overflow: visible;
  border: 1px solid #d8e5ed;
  border-radius: 18px;
  background: #fff;
  padding: 14px;
}
.current-indicator-comparison .dataTables_wrapper,
.current-indicator-comparison .dt-container {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
  flex-direction: column;
  font-size: 13px;
  overflow: visible;
}
.current-indicator-comparison table.dataTable {
  width: 100% !important;
  table-layout: fixed;
}
.current-indicator-comparison table.dataTable thead th,
.current-indicator-comparison table.dataTable tbody td {
  white-space: normal !important;
  overflow-wrap: anywhere;
  word-break: normal;
  vertical-align: middle;
}
.current-indicator-comparison .current-indicator-name-cell {
  width: 30%;
}
.current-indicator-comparison .current-indicator-name-cell strong,
.current-indicator-comparison .current-indicator-name-cell .text-muted {
  display: block;
}
.current-indicator-comparison .current-indicator-name-cell .text-muted {
  line-height: 1.35;
  white-space: normal;
}
.current-indicator-comparison .current-indicator-wrap-cell {
  line-height: 1.35;
}
.current-indicator-comparison .dt-scroll-body,
.current-indicator-comparison .dataTables_scrollBody {
  overflow-x: hidden !important;
}
.current-indicator-comparison .dt-buttons,
.current-indicator-comparison .dt-layout-cell.dt-layout-start {
  gap: 8px;
  flex-wrap: wrap;
}
.current-indicator-comparison .dt-layout-row:last-child,
.current-indicator-comparison .dataTables_info,
.current-indicator-comparison .dataTables_paginate {
  flex-shrink: 0;
  margin-top: 10px;
}
@media (max-width: 1199px) {
  .current-indicator-comparison .current-indicator-chart-card,
  .current-indicator-comparison .current-indicator-table-wrap {
    min-height: 440px;
  }
  .current-indicator-comparison .current-indicator-chart-card canvas {
    height: 380px !important;
  }
}

/* Global DataTable Wrapping + Fullscreen */
.app-card table.table,
.history-panel table.table,
.user-admin-shell table.table,
.admin-history-shell table.table,
.current-indicator-table-wrap table.table {
  table-layout: auto;
}
.pdm-wrap-table.dataTable,
table.dataTable.pdm-wrap-table {
  width: 100% !important;
}
.pdm-wrap-table.dataTable thead th,
.pdm-wrap-table.dataTable tbody td,
.pdm-wrap-table.dataTable tfoot th,
.pdm-wrap-table.dataTable tfoot td {
  min-width: 82px;
  max-width: 360px;
  white-space: normal !important;
  overflow-wrap: anywhere;
  word-break: normal;
  vertical-align: middle;
  line-height: 1.35;
}
.pdm-wrap-table.dataTable .text-end,
.pdm-wrap-table.dataTable .text-center,
.pdm-wrap-table.dataTable td.dt-type-numeric,
.pdm-wrap-table.dataTable th.dt-type-numeric,
.pdm-wrap-table.dataTable .submission-actions-cell,
.pdm-wrap-table.dataTable .user-actions,
.pdm-wrap-table.dataTable .scenario-actions,
.pdm-wrap-table.dataTable td:has(.btn),
.pdm-wrap-table.dataTable td:has(.badge) {
  overflow-wrap: normal;
}
.pdm-wrap-table.dataTable td:has(.btn) {
  white-space: nowrap !important;
}
.pdm-wrap-table.dataTable .submission-wrap-cell,
.pdm-wrap-table.dataTable .submission-description-cell,
.pdm-wrap-table.dataTable .submission-indicator-title-cell,
.pdm-wrap-table.dataTable .current-indicator-name-cell,
.pdm-wrap-table.dataTable td:first-child,
.pdm-wrap-table.dataTable th:first-child {
  min-width: 120px;
  max-width: 360px;
}
.pdm-wrap-table.dataTable .text-muted,
.pdm-wrap-table.dataTable small {
  white-space: normal;
}
.pdm-fullscreen-host {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-bottom: 10px;
}
.pdm-fullscreen-toggle {
  min-width: auto;
}
.pdm-fullscreen-toggle i,
.pdm-fullscreen-close i {
  font-size: 18px;
  line-height: 1;
}
.pdm-table-fullscreen-target {
  position: relative;
}
.pdm-table-fullscreen-open {
  overflow: hidden;
}
.pdm-table-fullscreen-target.is-table-fullscreen {
  position: fixed !important;
  inset: 14px !important;
  z-index: 2055 !important;
  display: flex !important;
  flex-direction: column !important;
  width: auto !important;
  max-width: none !important;
  height: auto !important;
  max-height: none !important;
  margin: 0 !important;
  padding: 20px !important;
  overflow: auto !important;
  border-radius: 18px !important;
  background: #fff !important;
  box-shadow: 0 26px 90px rgba(6, 37, 57, .32) !important;
}
.pdm-table-fullscreen-target.is-table-fullscreen .modal.pdm-modal-in-table-fullscreen {
  z-index: 2075 !important;
}
.pdm-table-fullscreen-target.is-table-fullscreen .modal-backdrop.pdm-backdrop-in-table-fullscreen {
  position: fixed !important;
  z-index: 2070 !important;
}
.pdm-table-fullscreen-target.is-table-fullscreen::before {
  content: attr(data-fullscreen-title);
  display: block;
  margin: 0 56px 14px 0;
  color: #082946;
  font-size: 20px;
  font-weight: 900;
}
.pdm-table-fullscreen-target.is-table-fullscreen .dt-container,
.pdm-table-fullscreen-target.is-table-fullscreen .dataTables_wrapper {
  flex: 1 1 auto;
  min-height: 0;
}
.pdm-table-fullscreen-target.is-table-fullscreen .dt-scroll-body,
.pdm-table-fullscreen-target.is-table-fullscreen .dataTables_scrollBody {
  max-height: calc(100vh - 250px) !important;
}
.pdm-table-fullscreen-target.is-table-fullscreen .table-responsive,
.pdm-table-fullscreen-target.is-table-fullscreen .dt-scroll,
.pdm-table-fullscreen-target.is-table-fullscreen .dataTables_scroll {
  max-width: 100%;
}
.pdm-fullscreen-close {
  display: none;
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 3;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border: 1px solid #cbdced;
  border-radius: 999px;
  color: #082946;
  background: #fff;
  box-shadow: 0 12px 28px rgba(16,42,67,.14);
}
.pdm-table-fullscreen-target.is-table-fullscreen > .pdm-fullscreen-close {
  display: inline-flex;
}
.pdm-fullscreen-close:hover {
  color: #fff;
  border-color: #0f766e;
  background: #0f766e;
}
@media (max-width: 768px) {
  .pdm-table-fullscreen-target.is-table-fullscreen {
    inset: 8px !important;
    padding: 14px !important;
    border-radius: 14px !important;
  }
  .pdm-table-fullscreen-target.is-table-fullscreen .modal.pdm-modal-in-table-fullscreen {
  z-index: 2075 !important;
}
.pdm-table-fullscreen-target.is-table-fullscreen .modal-backdrop.pdm-backdrop-in-table-fullscreen {
  position: fixed !important;
  z-index: 2070 !important;
}
.pdm-table-fullscreen-target.is-table-fullscreen::before {
    font-size: 17px;
  }
}



.admin-history-shell table.dataTable th.admin-long-cell,
.admin-history-shell table.dataTable td.admin-long-cell {
  min-width: 300px !important;
  max-width: 460px !important;
  white-space: normal !important;
}

.admin-history-shell table.dataTable th.admin-medium-cell,
.admin-history-shell table.dataTable td.admin-medium-cell {
  min-width: 190px !important;
  max-width: 260px !important;
  white-space: normal !important;
}

.admin-history-shell table.dataTable th.admin-actions-cell,
.admin-history-shell table.dataTable td.admin-actions-cell {
  min-width: 190px !important;
  white-space: nowrap !important;
}

.admin-history-shell table.dataTable th.admin-nowrap,
.admin-history-shell table.dataTable td.admin-nowrap {
  min-width: 82px !important;
  white-space: nowrap !important;
}

.admin-segmented button.active {
  pointer-events: auto;
}

/* Submission Scale Controls */
.submission-scale-select {
  font-weight: 800;
}
.submission-scale-hint {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  padding: 10px 12px;
  border: 1px solid #bee8df;
  border-radius: 13px;
  color: #0f6f67;
  background: #eefbf8;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.45;
}
.submission-scale-hint i {
  margin-top: 2px;
  font-size: 16px;
}
.submission-scale-quick {
  border-color: #bee8df;
  background: #f6fffc;
}
.submission-scale-current {
  display: inline-flex;
  width: fit-content;
  margin: 4px 0 12px;
  padding: 7px 11px;
  border-radius: 999px;
  color: #0b6b62;
  background: #dff7ef;
  font-size: 13px;
  font-weight: 900;
}
.submission-scale-current.is-missing {
  color: #9f1239;
  background: #ffe4ec;
}
.submission-scale-choice-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 8px;
}
.submission-scale-choice {
  display: grid;
  gap: 4px;
  padding: 13px 14px;
  border: 1px solid #cbdced;
  border-radius: 15px;
  color: #102a43;
  background: #fff;
  text-align: left;
  box-shadow: 0 8px 18px rgba(16, 42, 67, .06);
}
.submission-scale-choice:hover,
.submission-scale-choice.is-active {
  border-color: #0f766e;
  background: #e7f6f3;
}
.submission-scale-choice strong {
  font-size: 15px;
  font-weight: 950;
}
.submission-scale-choice span {
  color: #0f766e;
  font-size: 12px;
  font-weight: 900;
}
.submission-scale-quick small {
  display: block;
  margin-top: 11px;
  color: #667085;
  font-weight: 800;
}
@media (max-width: 760px) {
  .submission-scale-choice-grid {
    grid-template-columns: 1fr;
  }
}



/* Submission Evidence Files */
.submission-evidence-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px;
  margin-bottom: 16px;
  border: 1px solid rgba(15, 118, 110, .18);
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(240, 253, 250, .92), rgba(255, 255, 255, .96));
}

.submission-evidence-hero span,
.submission-evidence-note span,
.submission-evidence-files-head h3 {
  display: block;
  color: var(--pdm-muted, #64748b);
  font-size: .82rem;
  font-weight: 800;
}

.submission-evidence-hero strong {
  display: block;
  color: var(--pdm-navy, #0f2d44);
  font-size: 1rem;
  margin-top: 3px;
}

.submission-evidence-hero em {
  display: block;
  color: var(--pdm-muted, #64748b);
  font-style: normal;
  margin-top: 4px;
}

.submission-evidence-upload {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(220px, .75fr) auto;
  gap: 14px;
  align-items: end;
  padding: 16px;
  margin: 16px 0;
  border: 1px solid rgba(15, 118, 110, .16);
  border-radius: 16px;
  background: #f8fbfd;
}

.submission-evidence-dropzone {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  min-height: 84px;
  padding: 14px 16px;
  border: 1.5px dashed rgba(15, 118, 110, .36);
  border-radius: 14px;
  background: #fff;
  color: var(--pdm-navy, #0f2d44);
  text-align: left;
  transition: border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

.submission-evidence-dropzone:hover,
.submission-evidence-dropzone.is-dragging,
.submission-evidence-dropzone.has-file {
  border-color: var(--pdm-teal, #0f766e);
  background: rgba(240, 253, 250, .82);
  box-shadow: 0 12px 30px rgba(15, 118, 110, .12);
}

.submission-evidence-dropzone i {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 13px;
  background: rgba(15, 118, 110, .1);
  color: var(--pdm-teal, #0f766e);
  font-size: 1.45rem;
  flex: 0 0 auto;
}

.submission-evidence-dropzone strong,
.submission-evidence-dropzone em {
  display: block;
}

.submission-evidence-dropzone em {
  color: var(--pdm-muted, #64748b);
  font-style: normal;
  margin-top: 3px;
  overflow-wrap: anywhere;
}

.submission-evidence-note .form-control {
  min-height: 44px;
}

.submission-evidence-files-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 18px 0 10px;
}

.submission-evidence-files {
  display: grid;
  gap: 10px;
}

.submission-evidence-file-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 14px;
  border: 1px solid rgba(148, 163, 184, .28);
  border-radius: 14px;
  background: #fff;
}

.submission-evidence-file-icon {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 13px;
  background: rgba(15, 118, 110, .1);
  color: var(--pdm-teal, #0f766e);
  font-size: 1.45rem;
}

.submission-evidence-file-main {
  min-width: 0;
}

.submission-evidence-file-main > div {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.submission-evidence-file-main p {
  margin: 4px 0 2px;
  font-weight: 800;
  color: var(--pdm-navy, #0f2d44);
  overflow-wrap: anywhere;
}

.submission-evidence-file-main small,
.submission-evidence-file-main em {
  display: block;
  color: var(--pdm-muted, #64748b);
  font-style: normal;
}

.submission-evidence-file-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

@media (max-width: 900px) {
  .submission-evidence-upload,
  .submission-evidence-file-card {
    grid-template-columns: 1fr;
  }

  .submission-evidence-file-actions {
    justify-content: flex-start;
  }
}


/* Appendix II mean recalculation */
.admin-state-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 950;
  line-height: 1.2;
  white-space: normal;
}

.admin-state-badge.is-ok {
  background: #dff7ec;
  color: #047857;
}

.admin-state-badge.is-warn {
  background: #fff1c7;
  color: #8a5a00;
}

.admin-state-badge.is-muted {
  background: #eef4f7;
  color: #526779;
}

.admin-mean-preview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 10px 0 14px;
  text-align: left;
}

.admin-mean-preview > div,
.admin-preview-block {
  border: 1px solid #dce7ee;
  border-radius: 14px;
  background: #fbfdff;
  padding: 12px;
}

.admin-mean-preview span,
.admin-preview-field span {
  display: block;
  color: #667085;
  font-size: 12px;
  font-weight: 900;
}

.admin-mean-preview strong {
  display: block;
  margin-top: 4px;
  color: #102a43;
  font-size: 20px;
  font-weight: 950;
}

.admin-preview-block {
  margin-bottom: 12px;
  text-align: left;
}

.admin-preview-block h4 {
  margin: 0 0 8px;
  color: #102a43;
  font-size: 15px;
  font-weight: 900;
}

.admin-preview-list {
  max-height: 150px;
  overflow: auto;
  margin: 0;
  padding-left: 18px;
  color: #344054;
}

.admin-preview-muted {
  margin: 0;
  color: #667085;
  font-weight: 750;
}

.admin-preview-field {
  display: grid;
  gap: 6px;
  margin-top: 10px;
  text-align: left;
}

.submission-source-badge.is-warn {
  background: #fff1c7;
  color: #8a5a00;
}

.submission-baseline-cell {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  max-width: 100%;
}

@media (max-width: 900px) {
  .admin-mean-preview {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Official indicator metadata */
.submission-ellipsis-cell, .admin-long-text {
  display: inline-block;
  max-width: 34rem;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
  white-space: nowrap;
}
.submission-rich-head {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .75rem;
}
.submission-rich-text h4 {
  color: var(--pdm-navy, #082744);
  font-size: 1rem;
  margin: .35rem 0 .5rem;
}
.submission-fek-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin: .25rem 0 .75rem;
}
.submission-fek-meta span, .admin-official-panel small {
  background: rgba(0, 121, 107, .09);
  border-radius: 999px;
  color: #00695c;
  font-weight: 700;
  padding: .25rem .65rem;
}
.admin-official-panel {
  background: linear-gradient(180deg, rgba(236, 250, 247, .96), rgba(255, 255, 255, .98));
  border: 1px solid rgba(0, 121, 107, .18);
  border-radius: 16px;
  margin-bottom: 1rem;
  padding: 1rem;
}
.admin-official-panel strong {
  color: #00695c;
  display: block;
  margin-bottom: .75rem;
}
.admin-official-panel dl {
  display: grid;
  gap: .45rem .8rem;
  grid-template-columns: minmax(140px, .25fr) 1fr;
  margin: 0 0 .75rem;
}
.admin-official-panel dt {
  color: #52627a;
  font-weight: 800;
}
.admin-official-panel dd {
  margin: 0;
  white-space: pre-wrap;
}

/* Global DataTable Column Visibility Wrap Repair */
.dataTables_wrapper table.dataTable.pdm-wrap-table,
.dt-container table.dataTable.pdm-wrap-table,
.history-panel table.dataTable.pdm-wrap-table,
.submission-table-card table.dataTable.pdm-wrap-table,
.submission-runs-card table.dataTable.pdm-wrap-table,
.admin-history-shell table.dataTable.pdm-wrap-table,
.user-admin-shell table.dataTable.pdm-wrap-table,
.scenarios-table-card table.dataTable.pdm-wrap-table,
.current-indicator-table-wrap table.dataTable.pdm-wrap-table {
  table-layout: auto !important;
  width: 100% !important;
}

.dataTables_wrapper table.dataTable.pdm-wrap-table thead th,
.dataTables_wrapper table.dataTable.pdm-wrap-table tbody td,
.dataTables_wrapper table.dataTable.pdm-wrap-table tfoot th,
.dataTables_wrapper table.dataTable.pdm-wrap-table tfoot td,
.dt-container table.dataTable.pdm-wrap-table thead th,
.dt-container table.dataTable.pdm-wrap-table tbody td,
.dt-container table.dataTable.pdm-wrap-table tfoot th,
.dt-container table.dataTable.pdm-wrap-table tfoot td {
  min-width: 76px;
  max-width: 320px;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: break-word;
  line-height: 1.38;
  vertical-align: middle;
}

.dataTables_wrapper table.dataTable.pdm-wrap-table td:has(.badge):not(.submission-actions-cell):not(.admin-actions-cell):not(:has(.btn)),
.dt-container table.dataTable.pdm-wrap-table td:has(.badge):not(.submission-actions-cell):not(.admin-actions-cell):not(:has(.btn)) {
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}

.dataTables_wrapper table.dataTable.pdm-wrap-table .badge,
.dt-container table.dataTable.pdm-wrap-table .badge,
.dataTables_wrapper table.dataTable.pdm-wrap-table .submission-status-badge,
.dt-container table.dataTable.pdm-wrap-table .submission-status-badge,
.dataTables_wrapper table.dataTable.pdm-wrap-table .submission-section-pill,
.dt-container table.dataTable.pdm-wrap-table .submission-section-pill,
.dataTables_wrapper table.dataTable.pdm-wrap-table .submission-source-badge,
.dt-container table.dataTable.pdm-wrap-table .submission-source-badge {
  max-width: 100%;
  white-space: nowrap !important;
}

.dataTables_wrapper table.dataTable.pdm-wrap-table .submission-wrap-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .submission-description-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .submission-indicator-title-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .admin-long-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .admin-medium-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .current-indicator-name-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .current-indicator-wrap-cell,
.dt-container table.dataTable.pdm-wrap-table .submission-wrap-cell,
.dt-container table.dataTable.pdm-wrap-table .submission-description-cell,
.dt-container table.dataTable.pdm-wrap-table .submission-indicator-title-cell,
.dt-container table.dataTable.pdm-wrap-table .admin-long-cell,
.dt-container table.dataTable.pdm-wrap-table .admin-medium-cell,
.dt-container table.dataTable.pdm-wrap-table .current-indicator-name-cell,
.dt-container table.dataTable.pdm-wrap-table .current-indicator-wrap-cell {
  min-width: 180px !important;
  max-width: 420px !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}

.dataTables_wrapper table.dataTable.pdm-wrap-table .submission-description-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .admin-long-cell,
.dt-container table.dataTable.pdm-wrap-table .submission-description-cell,
.dt-container table.dataTable.pdm-wrap-table .admin-long-cell {
  min-width: 260px !important;
  max-width: 520px !important;
}

.dataTables_wrapper table.dataTable.pdm-wrap-table .submission-ellipsis-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .admin-long-text,
.dt-container table.dataTable.pdm-wrap-table .submission-ellipsis-cell,
.dt-container table.dataTable.pdm-wrap-table .admin-long-text {
  display: -webkit-box;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.dataTables_wrapper table.dataTable.pdm-wrap-table .text-end,
.dataTables_wrapper table.dataTable.pdm-wrap-table .text-center,
.dataTables_wrapper table.dataTable.pdm-wrap-table td.dt-type-numeric,
.dataTables_wrapper table.dataTable.pdm-wrap-table th.dt-type-numeric,
.dt-container table.dataTable.pdm-wrap-table .text-end,
.dt-container table.dataTable.pdm-wrap-table .text-center,
.dt-container table.dataTable.pdm-wrap-table td.dt-type-numeric,
.dt-container table.dataTable.pdm-wrap-table th.dt-type-numeric {
  max-width: 190px;
  overflow-wrap: normal !important;
  word-break: normal;
}

.dataTables_wrapper table.dataTable.pdm-wrap-table .submission-actions-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .admin-actions-cell,
.dataTables_wrapper table.dataTable.pdm-wrap-table .user-actions,
.dataTables_wrapper table.dataTable.pdm-wrap-table .scenario-actions,
.dataTables_wrapper table.dataTable.pdm-wrap-table td:has(.btn),
.dt-container table.dataTable.pdm-wrap-table .submission-actions-cell,
.dt-container table.dataTable.pdm-wrap-table .admin-actions-cell,
.dt-container table.dataTable.pdm-wrap-table .user-actions,
.dt-container table.dataTable.pdm-wrap-table .scenario-actions,
.dt-container table.dataTable.pdm-wrap-table td:has(.btn) {
  min-width: 92px !important;
  max-width: none !important;
  white-space: nowrap !important;
  overflow-wrap: normal !important;
  word-break: normal;
}

.dataTables_wrapper table.dataTable.pdm-wrap-table td > *,
.dt-container table.dataTable.pdm-wrap-table td > * {
  max-width: 100%;
}

.pdm-table-fullscreen-target.is-table-fullscreen table.dataTable.pdm-wrap-table thead th,
.pdm-table-fullscreen-target.is-table-fullscreen table.dataTable.pdm-wrap-table tbody td {
  max-width: 460px;
}

.submission-ellipsis-cell[data-bs-toggle="tooltip"] {
  cursor: help;
}

.pdm-table-tooltip {
  --bs-tooltip-max-width: min(720px, calc(100vw - 48px));
}

.pdm-table-tooltip .tooltip-inner {
  display: block;
  max-height: 60vh;
  max-width: min(720px, calc(100vw - 48px));
  overflow-x: hidden;
  overflow-y: auto;
  padding: .75rem .9rem;
  text-align: left;
  text-overflow: clip;
  white-space: pre-line;
  word-break: normal;
  overflow-wrap: anywhere;
  line-height: 1.45;
  -webkit-box-orient: initial;
  -webkit-line-clamp: unset;
}

/* Responsive system pass */
html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

.app-shell,
.app-main,
.app-content,
.app-card,
.history-panel,
.submission-page,
.dashboard-overview,
.scenarios-page,
.modal-content {
  min-width: 0;
}

.app-content {
  max-width: min(1540px, 100%);
}

.app-card,
.panel,
.history-panel,
.submission-table-card,
.submission-runs-card,
.user-admin-shell,
.admin-history-shell,
.scenarios-table-card {
  max-width: 100%;
}

.row,
.row > * {
  min-width: 0;
}

.table-responsive,
.dt-scroll,
.dataTables_scroll,
.dt-scroll-body,
.dataTables_scrollBody {
  max-width: 100%;
}

.dt-layout-row,
.dataTables_wrapper .row,
.submission-table-card .dt-layout-row,
.submission-runs-card .dt-layout-row,
.history-panel .dt-layout-row,
.admin-history-shell .dt-layout-row,
.user-admin-shell .dt-layout-row,
.scenarios-table-card .dt-layout-row {
  min-width: 0;
}

.dt-layout-cell,
.submission-table-card .dt-layout-cell,
.submission-runs-card .dt-layout-cell,
.history-panel .dt-layout-cell,
.admin-history-shell .dt-layout-cell,
.user-admin-shell .dt-layout-cell,
.scenarios-table-card .dt-layout-cell {
  min-width: 0;
}

@media (min-width: 1800px) {
  .app-content {
    max-width: min(1780px, calc(100vw - 72px));
    padding-left: 36px;
    padding-right: 36px;
  }

  .dashboard-kpi-grid,
  .scenarios-kpis,
  .dashboard-info-grid,
  .submission-context-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .submission-kpi-grid {
    grid-template-columns: repeat(7, minmax(0, 1fr));
  }
}

@media (min-width: 2400px) {
  .app-content {
    max-width: min(2140px, calc(100vw - 96px));
    padding-left: 44px;
    padding-right: 44px;
  }

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

  .dashboard-chart-card {
    min-height: 400px;
  }

  .dashboard-chart-card canvas {
    height: 315px !important;
  }
}

@media (min-width: 3200px) {
  .app-content {
    max-width: min(3200px, calc(100vw - 128px));
  }

  .dashboard-chart-grid,
  .scenarios-chart-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 1399.98px) and (min-width: 1200px) {
  .app-sidebar {
    width: 264px;
    min-width: 264px;
    padding: 18px;
  }

  .app-sidebar-brand {
    gap: 11px;
  }

  .app-sidebar-brand img {
    width: 48px;
    height: 48px;
  }

  .app-nav-link {
    gap: 8px;
    padding: 10px;
    font-size: 14px;
  }

  .app-content {
    padding-left: 22px;
    padding-right: 22px;
  }
}

@media (max-width: 1199.98px) {
  .app-shell {
    display: block;
  }

  .app-sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    width: min(312px, calc(100vw - 36px));
    min-width: 0;
    max-width: calc(100vw - 36px);
    transform: none;
    transition: transform .2s ease;
    box-shadow: 20px 0 60px rgba(16,42,67,.24);
  }

  .app-shell.sidebar-open .app-sidebar {
    transform: translateX(0);
  }

  .app-sidebar-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(9,33,51,.48);
    z-index: 45;
  }

  .app-shell.sidebar-open .app-sidebar-backdrop {
    display: block;
  }

  .app-menu-toggle {
    display: grid;
    place-items: center;
    flex: 0 0 auto;
  }

  .app-topbar {
    padding: 12px 20px;
  }

  .app-topbar-left {
    flex: 1 1 auto;
  }

  .app-topbar-right {
    margin-left: auto;
  }

  .app-route-label {
    max-width: 54vw;
  }

  .app-content {
    max-width: 100%;
    padding: 20px;
  }

  .app-footer {
    padding: 15px 20px;
    flex-direction: column;
    align-items: flex-start;
  }

  body.app-sidebar-locked {
    overflow: hidden;
  }

  .history-kpi-grid,
  .user-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {
  .app-page-header-row,
  .submission-card-head,
  .history-card-title,
  .admin-section-head,
  .user-section-head,
  .submission-evidence-hero {
    flex-direction: column;
    align-items: stretch;
  }

  .app-page-badges,
  .dashboard-hero-actions,
  .scenario-export-actions,
  .submission-live-actions,
  .submission-evidence-file-actions {
    justify-content: flex-start;
  }

  .dashboard-hero,
  .pdm-profile-hero,
  .user-forbidden-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .dashboard-kpi-grid,
  .scenarios-kpis,
  .dashboard-info-grid,
  .submission-context-grid,
  .history-kpi-grid,
  .user-kpi-grid,
  .admin-mean-preview {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-chart-grid,
  .scenarios-chart-grid,
  .user-chart-grid {
    grid-template-columns: 1fr;
  }

  .modal-dialog.modal-xl,
  .modal-dialog.modal-lg {
    width: calc(100vw - 28px);
    max-width: calc(100vw - 28px);
    margin-right: auto;
    margin-left: auto;
  }

  .submission-modal-content {
    min-height: 0;
  }
}

@media (max-width: 767.98px) {
  .app-topbar {
    min-height: 0;
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px 14px;
  }

  .app-topbar-left,
  .app-topbar-right {
    width: 100%;
  }

  .app-topbar-right {
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-left: 0;
  }

  .app-route-label {
    max-width: calc(100vw - 92px);
  }

  .app-user-pill {
    max-width: calc(100vw - 160px);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .app-content {
    padding: 14px;
  }

  .app-card,
  .panel,
  .history-panel,
  .app-page-header,
  .history-hero-header,
  .admin-history-shell {
    border-radius: 16px;
    padding: 14px;
  }

  .app-page-header h1,
  .history-header h1,
  .dashboard-hero h2 {
    font-size: 24px;
    line-height: 1.18;
  }

  .dashboard-kpi-grid,
  .scenarios-kpis,
  .dashboard-info-grid,
  .submission-context-grid,
  .submission-kpi-grid,
  .submission-section-picker,
  .submission-live-counts,
  .history-kpi-grid,
  .user-kpi-grid,
  .admin-mean-preview,
  .scenario-detail-grid,
  .admin-management-overview {
    grid-template-columns: 1fr;
  }

  .submission-tabs,
  .submission-modal-tabs,
  .history-tabs,
  .admin-tabs {
    display: flex;
    flex-wrap: nowrap;
    max-width: 100%;
    overflow-x: auto;
    padding-bottom: 6px;
    scrollbar-width: thin;
  }

  .submission-tabs button,
  .submission-modal-tabs button,
  .history-tabs .btn,
  .admin-tabs .nav-link {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  .submission-export-toolbar,
  .pdm-fullscreen-host,
  .submission-live-actions,
  .dashboard-hero-actions,
  .scenario-export-actions {
    width: 100%;
  }

  .submission-live-actions .btn,
  .submission-export-toolbar .pdm-table-action-btn,
  .dashboard-hero-actions .btn,
  .scenario-export-actions .btn {
    flex: 1 1 180px;
  }

  .history-panel .dt-layout-row,
  .submission-table-card .dt-layout-row,
  .submission-runs-card .dt-layout-row,
  .admin-history-shell .dt-layout-row,
  .user-admin-shell .dt-layout-row,
  .scenarios-table-card .dt-layout-row {
    align-items: stretch;
  }

  .history-panel .dt-layout-cell,
  .submission-table-card .dt-layout-cell,
  .submission-runs-card .dt-layout-cell,
  .admin-history-shell .dt-layout-cell,
  .user-admin-shell .dt-layout-cell,
  .scenarios-table-card .dt-layout-cell,
  .dt-search,
  .dt-search input,
  .dt-length,
  .dt-length select {
    width: 100%;
  }

  .dt-buttons,
  .history-panel .dt-buttons,
  .submission-table-card .dt-buttons {
    width: 100%;
  }

  .dt-buttons .dt-button,
  .history-panel .dt-buttons .dt-button,
  .history-panel .dt-buttons .btn,
  .pdm-export-btn {
    flex: 1 1 86px;
  }

  .pdm-column-panel {
    width: calc(100vw - 24px);
    max-height: min(72vh, 520px);
  }

  .modal-dialog,
  .modal-dialog.modal-xl,
  .modal-dialog.modal-lg,
  .modal-dialog.modal-md {
    width: calc(100vw - 16px);
    max-width: calc(100vw - 16px);
    margin: 8px auto;
  }

  .modal-dialog-scrollable .modal-content {
    max-height: calc(100vh - 16px);
  }

  .modal-header,
  .modal-body,
  .modal-footer {
    padding: 14px;
  }

  .submission-modal .modal-title {
    font-size: 19px;
    line-height: 1.2;
  }
}

@media (max-width: 479.98px) {
  .app-topbar {
    padding: 9px 10px;
  }

  .app-menu-toggle {
    width: 38px;
    height: 38px;
  }

  .app-route-label {
    max-width: calc(100vw - 70px);
    font-size: 12px;
  }

  .app-user-pill {
    max-width: calc(100vw - 112px);
    min-height: 34px;
    padding: 0 10px;
  }

  .app-logout-btn {
    min-height: 34px;
    padding-right: 10px;
    padding-left: 10px;
  }

  .app-sidebar {
    width: calc(100vw - 20px);
    max-width: calc(100vw - 20px);
    padding: 16px;
  }

  .app-content {
    padding: 10px;
  }

  .app-card,
  .panel,
  .history-panel,
  .app-page-header,
  .history-hero-header,
  .admin-history-shell {
    border-radius: 14px;
    padding: 12px;
  }

  .kpi-card,
  .submission-context-card,
  .submission-section-option span,
  .dashboard-list article,
  .scenarios-checklist article {
    border-radius: 14px;
  }

  .kpi-card strong,
  .submission-context-card strong,
  .submission-live-total strong {
    font-size: 27px;
  }

  .submission-row-actions,
  .user-actions,
  .admin-row-actions,
  .scenario-actions {
    flex-wrap: wrap;
    white-space: normal;
  }

  .submission-footer-actions > *,
  .submission-indicator-nav-top > *,
  .submission-evidence-dropzone,
  .submission-evidence-file-actions .btn {
    width: 100%;
  }

  .submission-evidence-dropzone {
    align-items: flex-start;
  }
}

@media (hover: none) and (pointer: coarse) {
  .app-nav-link,
  .btn,
  .submission-tabs button,
  .submission-modal-tabs button,
  .admin-tabs .nav-link,
  .history-tabs .btn,
  .pdm-table-action-btn {
    min-height: 42px;
  }
}

/* Responsive shell correction: no page-level horizontal scroll */
.app-shell-body,
.app-shell,
.app-main {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

.app-topbar,
.app-content,
.app-footer {
  width: 100%;
  max-width: 100%;
}

.submission-live-card .submission-card-head {
  flex-direction: column;
  align-items: stretch;
}

.submission-live-card .submission-live-actions,
.dashboard-hero-actions,
.scenario-export-actions,
.submission-footer-actions {
  max-width: 100%;
  min-width: 0;
}

.submission-live-card .submission-live-actions .btn,
.dashboard-hero-actions .btn,
.scenario-export-actions .btn {
  min-width: 0;
  white-space: normal;
}

.submission-section-card,
.submission-live-card {
  overflow: hidden;
}

.submission-section-picker {
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

@media (max-width: 1499.98px) {
  .app-shell {
    display: block;
  }

  .app-sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    width: min(312px, calc(100vw - 36px));
    min-width: 0;
    max-width: calc(100vw - 36px);
    transform: none;
    transition: transform .2s ease;
    box-shadow: 20px 0 60px rgba(16,42,67,.24);
  }

  .app-shell.sidebar-open .app-sidebar {
    transform: translateX(0);
  }

  .app-sidebar-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(9,33,51,.48);
    z-index: 45;
  }

  .app-shell.sidebar-open .app-sidebar-backdrop {
    display: block;
  }

  .app-menu-toggle {
    display: grid;
    place-items: center;
    flex: 0 0 auto;
  }

  .app-content {
    max-width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }

  .app-route-label {
    max-width: 60vw;
  }

  body.app-sidebar-locked {
    overflow: hidden;
  }

  .submission-page > .row > [class*="col-xl-"] {
    flex: 0 0 100%;
    max-width: 100%;
  }
}

@media (max-width: 1199.98px) {
  .app-content {
    max-width: 100%;
  }
}

@media (max-width: 575.98px) {
  .app-topbar-right {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .app-user-pill {
    max-width: 100%;
  }

  .submission-live-actions,
  .dashboard-hero-actions,
  .scenario-export-actions,
  .submission-footer-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .submission-live-actions .btn,
  .dashboard-hero-actions .btn,
  .scenario-export-actions .btn,
  .submission-footer-actions .btn {
    width: 100%;
  }
}

/* Final shell layout guard */
.app-shell-body,
.app-shell,
.app-main {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

.app-shell {
  display: block;
  min-height: 100vh;
  min-height: 100dvh;
}

.app-main {
  min-height: 100vh;
  min-height: 100dvh;
}

.app-sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  height: 100vh;
  height: 100dvh;
  min-height: 100vh;
  min-height: 100dvh;
  z-index: 50;
}

.app-content {
  width: 100%;
  max-width: 100%;
}

@media (min-width: 1920px) {
  .app-sidebar {
    width: 292px;
    min-width: 292px;
    max-width: 292px;
    transform: none !important;
  }

  .app-main {
    width: calc(100% - 292px);
    max-width: calc(100% - 292px);
    margin-left: 292px;
  }

  .app-menu-toggle {
    display: none !important;
  }

  .app-sidebar-backdrop,
  .app-shell.sidebar-open .app-sidebar-backdrop {
    display: none !important;
  }

  .app-content {
    max-width: min(3200px, calc(100vw - 360px));
  }
}

@media (max-width: 1919.98px) {
  .app-main {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
  }

  .app-sidebar {
    width: min(312px, calc(100vw - 32px));
    min-width: 0;
    max-width: calc(100vw - 32px);
    transform: none;
    transition: transform .2s ease;
    box-shadow: 20px 0 60px rgba(16,42,67,.24);
  }

  .app-shell.sidebar-open .app-sidebar {
    transform: translateX(0);
  }

  .app-sidebar-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(9,33,51,.48);
    z-index: 45;
  }

  .app-shell.sidebar-open .app-sidebar-backdrop {
    display: block;
  }

  .app-menu-toggle {
    display: grid !important;
    place-items: center;
    flex: 0 0 auto;
  }

  .app-content {
    max-width: 100%;
  }
}

@media (max-width: 991.98px) {
  .app-content {
    padding-right: 14px;
    padding-left: 14px;
  }
}

@media (max-width: 479.98px) {
  .app-content {
    padding-right: 10px;
    padding-left: 10px;
  }
}

/* Persistent Sidebar Layout */
:root {
  --pdm-sidebar-expanded: 250px;
  --pdm-sidebar-compact: 72px;
  --pdm-sidebar-mobile: 64px;
  --pdm-sidebar-current: var(--pdm-sidebar-expanded);
}

.app-shell-body {
  overflow-x: hidden;
}

.app-shell {
  display: block !important;
  min-height: 100vh;
  min-height: 100dvh;
}

.app-sidebar {
  position: fixed !important;
  inset: 0 auto 0 0 !important;
  display: flex !important;
  width: var(--pdm-sidebar-current) !important;
  min-width: var(--pdm-sidebar-current) !important;
  max-width: var(--pdm-sidebar-current) !important;
  height: 100vh !important;
  height: 100dvh !important;
  min-height: 100vh !important;
  min-height: 100dvh !important;
  padding: 18px 14px !important;
  transform: none !important;
  transition: width .22s ease, min-width .22s ease, max-width .22s ease, box-shadow .22s ease !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  z-index: 60 !important;
  box-shadow: 12px 0 32px rgba(16, 42, 67, .12) !important;
}

.app-main {
  width: calc(100% - var(--pdm-sidebar-current)) !important;
  max-width: calc(100% - var(--pdm-sidebar-current)) !important;
  margin-left: var(--pdm-sidebar-current) !important;
  transition: margin-left .22s ease, width .22s ease, max-width .22s ease !important;
}

.app-sidebar-backdrop,
.app-shell.sidebar-open .app-sidebar-backdrop {
  display: none !important;
  pointer-events: none !important;
  background: transparent !important;
}

.app-menu-toggle {
  display: grid !important;
  place-items: center !important;
  flex: 0 0 auto;
}

.app-sidebar-brand {
  min-width: 0;
  white-space: nowrap;
}

.app-sidebar-brand img {
  flex: 0 0 auto;
}

.app-sidebar-brand > div,
.app-nav-link span,
.app-session-card span,
.app-session-card strong,
.app-session-progress {
  transition: opacity .16s ease, max-width .2s ease, transform .18s ease;
}

.app-nav-link {
  min-width: 0;
  white-space: nowrap;
}

.app-nav-link i {
  flex: 0 0 24px;
  width: 24px;
  text-align: center;
}

body.sidebar-compact {
  --pdm-sidebar-current: var(--pdm-sidebar-compact);
}

body.sidebar-compact .app-sidebar.is-compact .app-sidebar-brand {
  justify-content: center;
  gap: 0;
}

body.sidebar-compact .app-sidebar.is-compact .app-sidebar-brand > div,
body.sidebar-compact .app-sidebar.is-compact .app-nav-link span,
body.sidebar-compact .app-sidebar.is-compact .app-session-card span,
body.sidebar-compact .app-sidebar.is-compact .app-session-card strong,
body.sidebar-compact .app-sidebar.is-compact .app-session-progress {
  max-width: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateX(-6px);
  pointer-events: none;
}

body.sidebar-compact .app-sidebar.is-compact .app-nav-link {
  
  padding-right: 10px !important;
  padding-left: 10px !important;
}

body.sidebar-compact .app-sidebar.is-compact .app-session-card {
  padding: 10px !important;
}

body.sidebar-compact .app-sidebar.is-compact:hover,
body.sidebar-compact .app-sidebar.is-compact:focus-within {
  width: var(--pdm-sidebar-expanded) !important;
  min-width: var(--pdm-sidebar-expanded) !important;
  max-width: var(--pdm-sidebar-expanded) !important;
  box-shadow: 18px 0 46px rgba(16, 42, 67, .2) !important;
}

body.sidebar-compact .app-sidebar.is-compact:hover .app-sidebar-brand,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-sidebar-brand {
  justify-content: flex-start;
  gap: 14px;
}

body.sidebar-compact .app-sidebar.is-compact:hover .app-sidebar-brand > div,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-sidebar-brand > div,
body.sidebar-compact .app-sidebar.is-compact:hover .app-nav-link span,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-nav-link span,
body.sidebar-compact .app-sidebar.is-compact:hover .app-session-card span,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-session-card span,
body.sidebar-compact .app-sidebar.is-compact:hover .app-session-card strong,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-session-card strong,
body.sidebar-compact .app-sidebar.is-compact:hover .app-session-progress,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-session-progress {
  max-width: 190px;
  opacity: 1;
  transform: none;
  pointer-events: auto;
}

body.sidebar-compact .app-sidebar.is-compact:hover .app-nav-link,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-nav-link {
  justify-content: flex-start;
  padding-right: 12px !important;
  padding-left: 12px !important;
}

@media (min-width: 1200px) {
  body:not(.sidebar-compact) {
    --pdm-sidebar-current: var(--pdm-sidebar-expanded);
  }

  body:not(.sidebar-compact) .app-sidebar {
    width: var(--pdm-sidebar-expanded) !important;
    min-width: var(--pdm-sidebar-expanded) !important;
    max-width: var(--pdm-sidebar-expanded) !important;
  }
}

@media (max-width: 1199.98px) {
  body,
  body.sidebar-expanded,
  body.sidebar-compact {
    --pdm-sidebar-current: var(--pdm-sidebar-compact);
  }

  .app-sidebar,
  body.sidebar-expanded .app-sidebar,
  body.sidebar-compact .app-sidebar {
    width: var(--pdm-sidebar-compact) !important;
    min-width: var(--pdm-sidebar-compact) !important;
    max-width: var(--pdm-sidebar-compact) !important;
  }

  body.sidebar-expanded .app-sidebar,
  .app-sidebar:hover,
  .app-sidebar:focus-within {
    width: var(--pdm-sidebar-expanded) !important;
    min-width: var(--pdm-sidebar-expanded) !important;
    max-width: var(--pdm-sidebar-expanded) !important;
    box-shadow: 18px 0 46px rgba(16, 42, 67, .22) !important;
  }

  .app-sidebar .app-sidebar-brand {
    justify-content: center;
    gap: 0;
  }

  .app-sidebar .app-sidebar-brand > div,
  .app-sidebar .app-nav-link span,
  .app-sidebar .app-session-card span,
  .app-sidebar .app-session-card strong,
  .app-sidebar .app-session-progress {
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    transform: translateX(-6px);
    pointer-events: none;
  }

  .app-sidebar .app-nav-link {
    padding-right: 10px !important;
    padding-left: 10px !important;
  }

  body.sidebar-expanded .app-sidebar .app-sidebar-brand,
  .app-sidebar:hover .app-sidebar-brand,
  .app-sidebar:focus-within .app-sidebar-brand {
    justify-content: flex-start;
    gap: 14px;
  }

  body.sidebar-expanded .app-sidebar .app-sidebar-brand > div,
  body.sidebar-expanded .app-sidebar .app-nav-link span,
  body.sidebar-expanded .app-sidebar .app-session-card span,
  body.sidebar-expanded .app-sidebar .app-session-card strong,
  body.sidebar-expanded .app-sidebar .app-session-progress,
  .app-sidebar:hover .app-sidebar-brand > div,
  .app-sidebar:focus-within .app-sidebar-brand > div,
  .app-sidebar:hover .app-nav-link span,
  .app-sidebar:focus-within .app-nav-link span,
  .app-sidebar:hover .app-session-card span,
  .app-sidebar:focus-within .app-session-card span,
  .app-sidebar:hover .app-session-card strong,
  .app-sidebar:focus-within .app-session-card strong,
  .app-sidebar:hover .app-session-progress,
  .app-sidebar:focus-within .app-session-progress {
    max-width: 190px;
    opacity: 1;
    transform: none;
    pointer-events: auto;
  }

  body.sidebar-expanded .app-sidebar .app-nav-link,
  .app-sidebar:hover .app-nav-link,
  .app-sidebar:focus-within .app-nav-link {
    justify-content: flex-start;
    padding-right: 12px !important;
    padding-left: 12px !important;
  }

  body.app-sidebar-locked {
    overflow: auto !important;
  }
}

@media (max-width: 767.98px) {
  body,
  body.sidebar-expanded,
  body.sidebar-compact {
    --pdm-sidebar-current: var(--pdm-sidebar-mobile);
  }

  .app-sidebar,
  body.sidebar-expanded .app-sidebar,
  body.sidebar-compact .app-sidebar {
    width: var(--pdm-sidebar-mobile) !important;
    min-width: var(--pdm-sidebar-mobile) !important;
    max-width: var(--pdm-sidebar-mobile) !important;
    padding: 14px 10px !important;
  }

  body.sidebar-expanded .app-sidebar,
  .app-sidebar:hover,
  .app-sidebar:focus-within {
    width: min(var(--pdm-sidebar-expanded), calc(100vw - 8px)) !important;
    min-width: min(var(--pdm-sidebar-expanded), calc(100vw - 8px)) !important;
    max-width: min(var(--pdm-sidebar-expanded), calc(100vw - 8px)) !important;
  }

  .app-sidebar-brand img {
    width: 44px !important;
    height: 44px !important;
    border-radius: 12px !important;
  }

  .app-content {
    padding: 12px !important;
  }

  .app-topbar {
    padding: 10px 12px !important;
  }
}

/* Persistent sidebar compact refinements */
.app-nav-link {
  position: relative;
}

body.sidebar-compact .app-sidebar.is-compact .app-nav-link.active,
.app-sidebar .app-nav-link.active {
  box-shadow: none;
}

body:not(.sidebar-compact) .app-sidebar.is-expanded .app-nav-link.active,
body:not(.sidebar-compact) .app-sidebar:not(.is-compact) .app-nav-link.active {
  box-shadow: inset 3px 0 0 #d9b76f;
}

body.sidebar-compact .app-sidebar.is-compact .app-nav-link.active::after,
.app-sidebar .app-nav-link.active::after {
  content: '';
  position: absolute;
  left: 6px;
  top: 11px;
  bottom: 11px;
  width: 3px;
  border-radius: 999px;
  background: #d9b76f;
  opacity: 0;
}

body.sidebar-compact .app-sidebar.is-compact .app-nav-link.active::after {
  opacity: 1;
}

body.sidebar-compact .app-sidebar.is-compact .app-nav-link.active i,
.app-sidebar .app-nav-link.active i {
  display: inline-grid;
  place-items: center;
}

body.sidebar-compact .app-sidebar.is-compact .app-session-card,
.app-sidebar .app-session-card {
  min-width: 0;
}

body.sidebar-compact .app-sidebar.is-compact .app-session-card {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 78px;
}

body.sidebar-compact .app-sidebar.is-compact .app-session-card strong {
  display: block;
  max-width: none;
  min-width: 76px;
  margin: 0;
  opacity: 1;
  overflow: visible;
  color: #fff;
  font-size: 11px;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  transform: rotate(-90deg);
  transform-origin: center;
  pointer-events: auto;
}

body.sidebar-compact .app-sidebar.is-compact .app-session-card span,
body.sidebar-compact .app-sidebar.is-compact .app-session-progress {
  display: none;
}

body.sidebar-compact .app-sidebar.is-compact:hover .app-session-card,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-session-card {
  display: block;
  min-height: 0;
}

body.sidebar-compact .app-sidebar.is-compact:hover .app-session-card span,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-session-card span,
body.sidebar-compact .app-sidebar.is-compact:hover .app-session-progress,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-session-progress {
  display: block;
}

body.sidebar-compact .app-sidebar.is-compact:hover .app-session-card strong,
body.sidebar-compact .app-sidebar.is-compact:focus-within .app-session-card strong {
  min-width: 0;
  margin: 4px 0 8px;
  font-size: 18px;
  line-height: 1.2;
  text-align: left;
  transform: none;
}

@media (max-width: 1199.98px) {
  .app-sidebar .app-nav-link.active {
    box-shadow: none;
  }

  .app-sidebar .app-nav-link.active::after {
    opacity: 1;
  }

  .app-sidebar:hover .app-nav-link.active,
  .app-sidebar:focus-within .app-nav-link.active,
  body.sidebar-expanded .app-sidebar .app-nav-link.active {
    box-shadow: inset 3px 0 0 #d9b76f;
  }

  .app-sidebar:hover .app-nav-link.active::after,
  .app-sidebar:focus-within .app-nav-link.active::after,
  body.sidebar-expanded .app-sidebar .app-nav-link.active::after {
    opacity: 0;
  }

  .app-sidebar .app-session-card {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 78px;
    padding: 10px !important;
  }

  .app-sidebar .app-session-card strong {
    display: block;
    max-width: none;
    min-width: 76px;
    margin: 0;
    opacity: 1;
    overflow: visible;
    color: #fff;
    font-size: 11px;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    transform: rotate(-90deg);
    transform-origin: center;
    pointer-events: auto;
  }

  .app-sidebar .app-session-card span,
  .app-sidebar .app-session-progress {
    display: none;
  }

  .app-sidebar:hover .app-session-card,
  .app-sidebar:focus-within .app-session-card,
  body.sidebar-expanded .app-sidebar .app-session-card {
    display: block;
    min-height: 0;
    padding: 14px !important;
  }

  .app-sidebar:hover .app-session-card span,
  .app-sidebar:focus-within .app-session-card span,
  body.sidebar-expanded .app-sidebar .app-session-card span,
  .app-sidebar:hover .app-session-progress,
  .app-sidebar:focus-within .app-session-progress,
  body.sidebar-expanded .app-sidebar .app-session-progress {
    display: block;
  }

  .app-sidebar:hover .app-session-card strong,
  .app-sidebar:focus-within .app-session-card strong,
  body.sidebar-expanded .app-sidebar .app-session-card strong {
    min-width: 0;
    margin: 4px 0 8px;
    font-size: 18px;
    line-height: 1.2;
    text-align: left;
    transform: none;
  }
}

@media (max-width: 767.98px) {
  .app-sidebar .app-session-card strong,
  body.sidebar-compact .app-sidebar.is-compact .app-session-card strong {
    min-width: 72px;
    font-size: 10px;
  }
}

.submission-readonly-calc {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 14px;
  padding: 14px 16px;
  border: 1px solid #bfe1dc;
  border-radius: 10px;
  background: #f7fffd;
  color: #102a43;
}

.submission-readonly-calc span {
  color: #667085;
  font-size: 13px;
  font-weight: 850;
}

.submission-readonly-calc strong {
  font-size: 18px;
  font-weight: 950;
}

.submission-d62-breakdown {
  margin-top: 16px;
}
