/*
  DHKS Project Control modern UI layer.
  Loaded after the legacy template so these rules can safely refine the app
  without editing every module view.
*/
:root {
  --dhks-ink: #17201c;
  --dhks-ink-2: #27352f;
  --dhks-muted: #66736f;
  --dhks-line: #dce6e2;
  --dhks-soft: #f3f7f5;
  --dhks-panel: #ffffff;
  --dhks-primary: #0f766e;
  --dhks-primary-2: #0284c7;
  --dhks-accent: #f59e0b;
  --dhks-danger: #e11d48;
  --dhks-success: #16a34a;
  --dhks-shadow: 0 12px 34px rgba(23, 32, 28, .09);
  --dhks-radius: 8px;
}

body,
body * {
  letter-spacing: 0 !important;
}

body.modern-layout,
body.dhks-auth {
  background: #edf3f1 !important;
  color: var(--dhks-ink);
}

body.modern-layout .pc-container,
body.modern-layout .pcoded-content,
body.modern-layout .page-wrapper,
body.modern-layout .main-body,
body.modern-layout .page-body,
body.modern-layout .pc-content {
  background: transparent !important;
  background-image: none !important;
}

body.modern-layout .pc-container .pcoded-content {
  padding-left: 20px;
  padding-right: 24px;
}

body.modern-layout .pc-container .page-header {
  background: rgba(255, 255, 255, .78) !important;
  border: 1px solid rgba(15, 118, 110, .14);
  border-radius: var(--dhks-radius);
  box-shadow: 0 10px 26px rgba(23, 32, 28, .06) !important;
  padding: 14px 18px !important;
  margin-bottom: 16px;
}

body.modern-layout .page-header .breadcrumb {
  margin-bottom: 0;
}

body.modern-layout .page-header .breadcrumb-item,
body.modern-layout .page-header .breadcrumb-item a,
body.modern-layout .page-header h5 {
  color: var(--dhks-ink) !important;
}

body.modern-layout .page-header .text-muted,
body.modern-layout .breadcrumb .breadcrumb-item:last-child {
  color: var(--dhks-muted) !important;
}

body.modern-layout .pc-header,
body.modern-layout .pc-header[class*="bg-"],
body.modern-layout .pc-header.dark-header {
  background: rgba(255, 255, 255, .92) !important;
  border-bottom: 1px solid rgba(15, 118, 110, .14);
  box-shadow: 0 10px 30px rgba(23, 32, 28, .08) !important;
  color: var(--dhks-ink) !important;
  backdrop-filter: blur(12px);
}

body.modern-layout .pc-header .pc-head-link,
body.modern-layout .pc-header[class*="bg-"] .pc-head-link,
body.modern-layout .pc-header.dark-header .pc-head-link {
  color: var(--dhks-ink) !important;
  border-radius: var(--dhks-radius);
}

body.modern-layout .pc-header .pc-head-link:hover,
body.modern-layout .pc-header .pc-head-link.active {
  background: #e8f5f3 !important;
  color: var(--dhks-primary) !important;
}

body.modern-layout .pc-header .pc-head-link i,
body.modern-layout .pc-header .pc-head-link svg,
body.modern-layout .pc-header[class*="bg-"] .pc-head-link i,
body.modern-layout .pc-header[class*="bg-"] .pc-head-link svg {
  color: currentColor !important;
  stroke: currentColor !important;
}

body.modern-layout .pc-header .b-brand,
body.modern-layout .pc-mob-header .pcm-logo {
  background: #ffffff;
  border: 1px solid var(--dhks-line);
  border-radius: var(--dhks-radius);
  padding: 7px 10px;
  box-shadow: 0 8px 18px rgba(23, 32, 28, .06);
}

body.modern-layout .pc-header .logo,
body.modern-layout .pc-mob-header .logo {
  object-fit: contain;
}

body.modern-layout .pc-header .user-avtar {
  border: 2px solid #e8f5f3;
  box-shadow: 0 5px 14px rgba(15, 118, 110, .16);
}

body.modern-layout .pc-header .user-name {
  color: var(--dhks-ink) !important;
  font-weight: 800;
}

body.modern-layout .pc-header .user-desc {
  color: var(--dhks-muted) !important;
}

body.modern-layout .pc-sidebar,
body.modern-layout .pc-sidebar.light-sidebar,
body.modern-layout .pc-sidebar .navbar-wrapper,
body.modern-layout .pc-sidebar .navbar-content,
body.modern-layout .pcoded-navbar,
body.modern-layout .navbar-wrapper {
  background: #101a18 !important;
  background-image: none !important;
}

body.modern-layout .pc-sidebar {
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: var(--dhks-radius);
  box-shadow: 0 18px 42px rgba(16, 26, 24, .22);
  overflow: hidden;
}

body.modern-layout .pc-sidebar .navbar-content {
  padding: 12px 10px;
}

body.modern-layout .pc-sidebar .pc-caption {
  padding: 14px 12px 6px;
}

body.modern-layout .pc-sidebar .pc-caption label {
  color: rgba(255, 255, 255, .46) !important;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

body.modern-layout .pc-sidebar .pc-link {
  margin: 2px 0;
  border-radius: var(--dhks-radius);
  color: rgba(255, 255, 255, .72) !important;
  padding: 10px 12px;
  transition: background .16s ease, color .16s ease, transform .16s ease;
}

body.modern-layout .pc-sidebar .pc-link:hover,
body.modern-layout .pc-sidebar .pc-item.active > .pc-link,
body.modern-layout .pc-sidebar .pc-item.pc-trigger > .pc-link {
  background: rgba(15, 118, 110, .20) !important;
  color: #ffffff !important;
  transform: translateX(2px);
}

body.modern-layout .pc-sidebar .pc-micon {
  width: 34px;
  height: 34px;
  min-width: 34px;
  border-radius: var(--dhks-radius);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .07);
  color: rgba(255, 255, 255, .78) !important;
  margin-right: 10px;
}

body.modern-layout .pc-sidebar .pc-link:hover .pc-micon,
body.modern-layout .pc-sidebar .pc-item.active > .pc-link .pc-micon {
  background: var(--dhks-primary);
  color: #ffffff !important;
}

body.modern-layout .pc-sidebar .pc-micon i,
body.modern-layout .pc-sidebar .pc-micon svg {
  color: currentColor !important;
  stroke: currentColor !important;
}

body.modern-layout .card,
body.modern-layout .modal-content,
body.modern-layout .dhks-card2,
body.modern-layout .dhks-cardx,
body.modern-layout .dhks-kpi,
body.modern-layout .dhks-kpi2 {
  background: var(--dhks-panel) !important;
  border: 1px solid var(--dhks-line) !important;
  border-radius: var(--dhks-radius) !important;
  box-shadow: var(--dhks-shadow) !important;
  overflow: hidden;
}

body.modern-layout .card .card-header,
body.modern-layout .dhks-card2 .dhks-card-head,
body.modern-layout .dhks-cardx .dhks-cardx-h {
  background: #ffffff !important;
  border-bottom: 1px solid var(--dhks-line) !important;
}

body.modern-layout .card .card-header h5,
body.modern-layout .dhks-card-head h3,
body.modern-layout .dhks-cardx .dhks-cardx-h h5 {
  color: var(--dhks-ink) !important;
  font-weight: 850 !important;
}

body.modern-layout .card .card-header small,
body.modern-layout .dhks-card-head p,
body.modern-layout .dhks-cardx .dhks-cardx-h span,
body.modern-layout .dhks-card-subtitle,
body.modern-layout .dhks-subtle {
  color: var(--dhks-muted) !important;
}

body.modern-layout .card-body,
body.modern-layout .dhks-card2,
body.modern-layout .dhks-cardx .dhks-cardx-b {
  color: var(--dhks-ink);
}

body.modern-layout .form-control,
body.modern-layout .select2-container--default .select2-selection--single,
body.modern-layout .select2-container--default .select2-selection--multiple,
body.modern-layout .custom-select {
  min-height: 42px;
  border-color: var(--dhks-line) !important;
  border-radius: var(--dhks-radius) !important;
  background: #ffffff !important;
  color: var(--dhks-ink) !important;
  box-shadow: none !important;
}

body.modern-layout textarea.form-control {
  min-height: 92px;
}

body.modern-layout .form-control:focus,
body.modern-layout .select2-container--default.select2-container--focus .select2-selection--single,
body.modern-layout .select2-container--default.select2-container--focus .select2-selection--multiple {
  border-color: rgba(15, 118, 110, .55) !important;
  box-shadow: 0 0 0 3px rgba(15, 118, 110, .12) !important;
}

body.modern-layout label,
body.modern-layout .form-group label {
  color: var(--dhks-ink-2);
  font-weight: 750;
}

body.modern-layout .btn {
  border-radius: var(--dhks-radius) !important;
  font-weight: 750 !important;
  box-shadow: none !important;
}

body.modern-layout .btn-primary,
body.modern-layout .btn-info,
body.modern-layout .dhks-btn-orange,
body.dhks-auth .dhks-login-btn {
  background: linear-gradient(135deg, var(--dhks-primary), var(--dhks-primary-2)) !important;
  border-color: transparent !important;
  color: #ffffff !important;
}

body.modern-layout .btn-primary:hover,
body.modern-layout .btn-info:hover,
body.modern-layout .dhks-btn-orange:hover,
body.dhks-auth .dhks-login-btn:hover {
  filter: brightness(.96);
  transform: translateY(-1px);
}

body.modern-layout .btn-outline-primary {
  color: var(--dhks-primary) !important;
  border-color: rgba(15, 118, 110, .36) !important;
  background: #ffffff !important;
}

body.modern-layout .btn-outline-primary:hover {
  color: #ffffff !important;
  background: var(--dhks-primary) !important;
}

body.modern-layout .btn-warning {
  background: var(--dhks-accent) !important;
  border-color: var(--dhks-accent) !important;
  color: #1f2933 !important;
}

body.modern-layout .btn-danger,
body.modern-layout .btn-outline-danger:hover {
  background: var(--dhks-danger) !important;
  border-color: var(--dhks-danger) !important;
  color: #ffffff !important;
}

body.modern-layout .badge {
  border-radius: 999px !important;
  padding: 5px 9px;
  font-weight: 800;
}

body.modern-layout .badge-info,
body.modern-layout .badge-primary,
body.modern-layout .badge-light-primary {
  background: #e8f5f3 !important;
  color: var(--dhks-primary) !important;
}

body.modern-layout .badge-warning {
  background: #fff4d6 !important;
  color: #9a6700 !important;
}

body.modern-layout .badge-success {
  background: #dcfce7 !important;
  color: #166534 !important;
}

body.modern-layout .badge-danger {
  background: #ffe4e6 !important;
  color: #be123c !important;
}

body.modern-layout .table {
  color: var(--dhks-ink);
  border-collapse: separate;
  border-spacing: 0;
}

body.modern-layout .table thead th {
  background: #f4f8f6 !important;
  color: var(--dhks-muted) !important;
  border-top: 0 !important;
  border-bottom: 1px solid var(--dhks-line) !important;
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
}

body.modern-layout .table td,
body.modern-layout .table th {
  border-color: #e7efec !important;
  vertical-align: middle;
}

body.modern-layout .table-striped tbody tr:nth-of-type(odd) {
  background-color: #fbfdfc !important;
}

body.modern-layout .table-hover tbody tr:hover {
  background-color: #edf7f4 !important;
}

body.modern-layout .table-responsive,
body.modern-layout .dhks-scroll-card,
body.modern-layout .dhks-contract-scroll,
body.modern-layout .dhks-boq-scroll,
body.modern-layout .dhks-matrix-scroll {
  border-radius: var(--dhks-radius) !important;
}

body.modern-layout .alert {
  border-radius: var(--dhks-radius) !important;
  border: 1px solid var(--dhks-line);
}

body.modern-layout .progress,
body.modern-layout .dhks-progress2,
body.modern-layout .dhks-progress-track,
body.modern-layout .dhks-mini-bar {
  background: #e6efeb !important;
  border-radius: 999px !important;
}

body.modern-layout .progress-bar,
body.modern-layout .dhks-progress2 span,
body.modern-layout .dhks-progress-fill,
body.modern-layout .dhks-mini-bar span {
  background: linear-gradient(90deg, var(--dhks-primary), var(--dhks-primary-2)) !important;
}

body.modern-layout .dhks-v9,
body.modern-layout .dhks-screen-dashboard {
  font-family: Inter, Segoe UI, Arial, sans-serif;
}

body.modern-layout .dhks-topbar {
  margin-bottom: 14px !important;
}

body.modern-layout .dhks-logo-mark {
  background: #101a18 !important;
  border: 1px solid rgba(255, 255, 255, .08) !important;
  color: #ffffff !important;
  border-radius: var(--dhks-radius) !important;
  box-shadow: 0 10px 28px rgba(16, 26, 24, .16) !important;
}

body.modern-layout .dhks-page-title h1,
body.modern-layout .dhks-hero2 h2,
body.modern-layout .dhks-detail-hero h2 {
  color: var(--dhks-ink) !important;
  letter-spacing: 0 !important;
}

body.modern-layout .dhks-hero2,
body.modern-layout .dhks-detail-hero {
  background: linear-gradient(135deg, #10201d 0%, #143b42 56%, #0f766e 100%) !important;
  border-radius: var(--dhks-radius) !important;
  box-shadow: 0 18px 42px rgba(16, 26, 24, .22) !important;
}

body.modern-layout .dhks-hero2:before,
body.modern-layout .dhks-detail-hero:after {
  display: none !important;
}

body.modern-layout .dhks-hero2 h2,
body.modern-layout .dhks-detail-hero h2 {
  color: #ffffff !important;
  text-shadow: none !important;
}

body.modern-layout .dhks-eyebrow,
body.modern-layout .dhks-hero2 p,
body.modern-layout .dhks-detail-hero p {
  color: rgba(255, 255, 255, .78) !important;
}

body.modern-layout .dhks-hero-mini,
body.modern-layout .dhks-detail-pill {
  background: rgba(255, 255, 255, .10) !important;
  border: 1px solid rgba(255, 255, 255, .18) !important;
  border-radius: var(--dhks-radius) !important;
}

body.modern-layout .dhks-kpi2 {
  min-height: 134px;
}

body.modern-layout .dhks-kpi2:after {
  display: none !important;
}

body.modern-layout .dhks-kpi-icon2 {
  background: #e8f5f3 !important;
  color: var(--dhks-primary) !important;
  border-radius: var(--dhks-radius) !important;
}

body.modern-layout .dhks-kpi-label,
body.modern-layout .dhks-kpi .label {
  color: var(--dhks-muted) !important;
  text-transform: uppercase;
}

body.modern-layout .dhks-kpi-value2,
body.modern-layout .dhks-kpi .value,
body.modern-layout .dhks-kpi .val {
  color: var(--dhks-ink) !important;
  letter-spacing: 0 !important;
}

body.modern-layout .dhks-kpi-sub2,
body.modern-layout .dhks-kpi .note {
  color: var(--dhks-muted) !important;
}

body.modern-layout .dhks-card2.soft,
body.modern-layout .dhks-filter2,
body.modern-layout .dhks-alert-focus,
body.modern-layout .dhks-cardx .dhks-cardx-h {
  background: #ffffff !important;
  border-color: var(--dhks-line) !important;
}

body.modern-layout .dhks-filter2 {
  border-radius: var(--dhks-radius) !important;
  box-shadow: var(--dhks-shadow) !important;
}

body.modern-layout .dhks-chip,
body.modern-layout .dhks-chip.orange,
body.modern-layout .dhks-badge2,
body.modern-layout .dhks-mini-count,
body.modern-layout .dhks-card-kpi {
  border-radius: 999px !important;
}

body.modern-layout .dhks-chip.orange,
body.modern-layout .dhks-alert-focus {
  background: #fff8e7 !important;
  border-color: #f7df9e !important;
  color: #7c5800 !important;
}

body.modern-layout .dhks-table2 tbody tr {
  box-shadow: none !important;
}

body.modern-layout .dhks-table2 tbody td:first-child,
body.modern-layout .dhks-table2 tbody td:last-child {
  border-radius: 0 !important;
}

body.modern-layout .dhks-chart2,
body.modern-layout .dhks-chart,
body.modern-layout .dhks-chart-sm,
body.modern-layout .dhks-chart-xs {
  min-width: 0;
}

body.dhks-auth .dhks-login-page {
  background: #edf3f1 !important;
  color: var(--dhks-ink) !important;
}

body.dhks-auth .dhks-hero::after {
  display: none !important;
}

body.dhks-auth .dhks-logo-box,
body.dhks-auth .dhks-login-card,
body.dhks-auth .dhks-feature,
body.dhks-auth .dhks-mini-note {
  border-radius: var(--dhks-radius) !important;
}

body.dhks-auth .dhks-logo-box {
  background: #ffffff !important;
}

body.dhks-auth .dhks-login-side {
  background: #f7faf9 !important;
}

body.dhks-auth .dhks-login-card {
  border: 1px solid var(--dhks-line) !important;
  box-shadow: 0 16px 44px rgba(23, 32, 28, .12) !important;
}

body.dhks-auth .dhks-login-card h3 span,
body.dhks-auth .dhks-forgot a {
  color: var(--dhks-primary) !important;
}

body.dhks-auth .dhks-input-wrap .input-group-text,
body.dhks-auth .dhks-input-wrap .form-control {
  border-color: var(--dhks-line) !important;
  background: #ffffff !important;
  color: var(--dhks-ink) !important;
}

body.dhks-auth .dhks-input-wrap .input-group-text {
  color: var(--dhks-primary) !important;
}

body.dhks-auth .dhks-mini-note {
  background: #e8f5f3 !important;
  border-color: rgba(15, 118, 110, .18) !important;
  color: #17544f !important;
}

body.dhks-auth .auth-wrapper {
  min-height: 100vh;
  background: #edf3f1 !important;
}

body.dhks-auth .auth-wrapper .card {
  border: 1px solid var(--dhks-line) !important;
  border-radius: var(--dhks-radius) !important;
  box-shadow: 0 16px 44px rgba(23, 32, 28, .12) !important;
}

body.dhks-auth .auth-wrapper .card-body {
  padding: 34px !important;
}

body.dhks-auth .auth-wrapper .input-group-text,
body.dhks-auth .auth-wrapper .form-control {
  border-color: var(--dhks-line) !important;
  background: #ffffff !important;
}

body.dhks-auth .auth-wrapper .input-group-text {
  color: var(--dhks-primary) !important;
}

@media (max-width: 1024px) {
  body.modern-layout .pc-sidebar {
    border-radius: 0;
  }

  body.modern-layout .pc-container .pcoded-content {
    padding-left: 14px;
    padding-right: 14px;
  }
}

@media (max-width: 640px) {
  body.modern-layout .pc-container .page-header {
    padding: 12px !important;
  }

  body.modern-layout .dhks-hero2,
  body.modern-layout .dhks-detail-hero,
  body.modern-layout .dhks-card2,
  body.modern-layout .dhks-kpi2,
  body.modern-layout .card {
    border-radius: var(--dhks-radius) !important;
  }
}

@media print {
  body.modern-layout {
    background: #ffffff !important;
  }

  body.modern-layout .pc-header,
  body.modern-layout .pc-sidebar,
  body.modern-layout .pc-mob-header,
  body.modern-layout .page-header,
  body.modern-layout .dhks-no-print {
    display: none !important;
  }

  body.modern-layout .pc-container,
  body.modern-layout .pcoded-content {
    margin: 0 !important;
    padding: 0 !important;
  }

  body.modern-layout .card,
  body.modern-layout .dhks-card2,
  body.modern-layout .dhks-cardx,
  body.modern-layout .dhks-kpi,
  body.modern-layout .dhks-kpi2 {
    box-shadow: none !important;
    break-inside: avoid;
  }
}
