/*
  Modern admin polish for PerfexCRM.
  Kept as an override layer so views, data bindings, routes and modules remain untouched.
*/
:root {
  --crm-bg: #f6f8fb;
  --crm-surface: #ffffff;
  --crm-surface-soft: #f9fafb;
  --crm-border: #e5e7eb;
  --crm-border-strong: #d1d5db;
  --crm-text: #111827;
  --crm-muted: #6b7280;
  --crm-primary: #2563eb;
  --crm-primary-dark: #1d4ed8;
  --crm-primary-soft: #eff6ff;
  --crm-success: #059669;
  --crm-warning: #d97706;
  --crm-danger: #dc2626;
  --crm-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
  --crm-shadow-md: 0 12px 28px rgba(15, 23, 42, 0.08);
  --crm-radius: 8px;
}

body {
  background: var(--crm-bg);
  color: var(--crm-text);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a {
  color: var(--crm-primary);
}

a:hover,
a:focus {
  color: var(--crm-primary-dark);
}

#wrapper {
  background: var(--crm-bg);
}

.content {
  padding: 24px;
}

#header {
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid var(--crm-border);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.03);
  backdrop-filter: blur(14px);
  left: 230px;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 990;
}

#header .logo,
#header .logo-text {
  color: var(--crm-text) !important;
  letter-spacing: 0;
}

body.hide-sidebar:not(.show-sidebar) #header,
body.page-small #header {
  left: 0;
}

[dir="rtl"] #header {
  left: 0;
  right: 230px;
}

[dir="rtl"] body.hide-sidebar:not(.show-sidebar) #header,
[dir="rtl"] body.page-small #header {
  right: 0;
}

#wrapper {
  padding-top: 57px;
}

body.page-full #wrapper {
  padding-top: 57px;
}

#header .hide-menu,
#header .mobile-menu-toggle,
#header .navbar-nav > li > a,
#header .navbar-nav > li > a i,
#header .navbar-nav > li > a svg,
#header .top-timers i,
#header .open_newsfeed svg,
#header .fa,
#header .fa-regular,
#header .fa-solid {
  color: #334155 !important;
}

#header .hide-menu:hover,
#header .hide-menu:focus,
#header .mobile-menu-toggle:hover,
#header .mobile-menu-toggle:focus,
#header .navbar-nav > li > a:hover,
#header .navbar-nav > li > a:focus,
#header .navbar-nav > li > a:hover i,
#header .navbar-nav > li > a:focus i,
#header .navbar-nav > li > a:hover svg,
#header .navbar-nav > li > a:focus svg {
  color: var(--crm-primary-dark) !important;
}

#header .navbar-nav > li > a {
  font-weight: 600;
}

#header .icon > a,
#header .navbar-nav > li.icon > a {
  border-radius: var(--crm-radius);
}

#header .icon > a:hover,
#header .navbar-nav > li.icon > a:hover,
#header .navbar-nav .open > a {
  background: var(--crm-primary-soft) !important;
}

#header .navbar-nav > li.icon a .tw-bg-primary-600,
#header .navbar-nav > li.icon a .tw-bg-primary-600 i,
#header .navbar-nav > li.icon a .tw-bg-primary-700,
#header .navbar-nav > li.icon a .tw-bg-primary-700 i {
  color: #fff !important;
}

#top_search #search_input {
  background: #f3f6fa !important;
  border: 1px solid transparent !important;
  border-radius: var(--crm-radius) !important;
  color: var(--crm-text) !important;
  transition: background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

#top_search #search_input:hover,
#top_search #search_input:focus {
  background: #fff !important;
  border-color: #bfdbfe !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12) !important;
}

.navbar-nav > li > a {
  color: #475569;
  font-weight: 500;
}

.navbar-nav > li > a:hover,
.navbar-nav > li > a:focus,
.navbar-nav .open > a,
.navbar-nav .open > a:hover,
.navbar-nav .open > a:focus {
  background: transparent;
  color: var(--crm-primary);
}

.sidebar {
  background: #101827;
  border-right: 0;
  box-shadow: 14px 0 36px rgba(15, 23, 42, 0.10);
}

@media (min-width: 769px) {
  .sidebar {
    bottom: auto;
    height: 100vh;
    left: 0;
    overflow: hidden;
    position: fixed;
    top: 0;
  }

  [dir="rtl"] .sidebar {
    left: auto;
    right: 0;
  }

  .sidebar .sidebar-user-profile {
    margin-top: 68px !important;
  }

  .sidebar #side-menu {
    max-height: calc(100vh - 145px);
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding-bottom: 14px;
    scrollbar-color: rgba(148, 163, 184, 0.45) transparent;
    scrollbar-width: thin;
  }

  .sidebar #side-menu::-webkit-scrollbar {
    width: 8px;
  }

  .sidebar #side-menu::-webkit-scrollbar-track {
    background: transparent;
  }

  .sidebar #side-menu::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.35);
    border: 2px solid #101827;
    border-radius: 999px;
  }

  .sidebar #side-menu::-webkit-scrollbar-thumb:hover {
    background: rgba(148, 163, 184, 0.55);
  }

  .sidebar #side-menu .nav-second-level.collapse:not(.in),
  .sidebar #side-menu .nav-second-level.collapsing {
    height: 0 !important;
    overflow: hidden !important;
  }
}

[dir="rtl"] .sidebar {
  box-shadow: -14px 0 36px rgba(15, 23, 42, 0.10);
}

.sidebar .sidebar-user-profile > a.profile {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.10) !important;
  color: #fff !important;
  box-shadow: none !important;
}

.sidebar .sidebar-user-profile > a.profile:hover,
.sidebar .sidebar-user-profile > a.profile:focus {
  background: rgba(255, 255, 255, 0.10) !important;
  border-color: rgba(255, 255, 255, 0.18) !important;
}

.sidebar ul.nav li a {
  border-radius: var(--crm-radius);
  color: #b8c2d6;
  font-weight: 500;
  margin: 2px 10px;
  padding-left: 12px;
  padding-right: 12px;
  transition: background-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.sidebar ul.nav li a i.menu-icon {
  color: #8391a8;
  transition: color 160ms ease;
}

.sidebar > ul.nav > li:hover a:first-child,
.sidebar > ul.nav > li.active a:first-child,
.sidebar ul.nav li.active > a,
.sidebar ul.nav > li > a:hover,
.sidebar ul.nav > li > a:focus {
  background: rgba(37, 99, 235, 0.16);
  color: #fff;
}

.sidebar ul.nav li.active > a .menu-icon,
.sidebar ul.nav > li > a:hover .menu-icon,
.sidebar ul.nav > li > a:focus .menu-icon {
  color: #93c5fd;
}

.sidebar ul.nav li .nav-second-level li a {
  color: #a8b4c8;
  margin-left: 18px;
  padding-top: 8px;
  padding-bottom: 8px;
}

.sidebar ul.nav > li .nav-second-level > li:not(.active) > a:hover,
.sidebar ul.nav > li .nav-second-level > li:not(.active) > a:focus,
.sidebar ul.nav li .nav-second-level li.active a {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.panel_s,
.panel {
  border: 1px solid var(--crm-border);
  border-radius: var(--crm-radius);
  box-shadow: var(--crm-shadow-sm);
}

.panel_s > .panel-body,
.panel-body {
  background: var(--crm-surface);
  border-radius: var(--crm-radius);
}

.panel-heading {
  background: var(--crm-surface);
  border-bottom: 1px solid var(--crm-border);
  color: var(--crm-text);
  font-weight: 600;
}

.widget,
.kan-ban-content,
.kanban-card,
.calendar,
.activity-feed,
.modal-content,
.dropdown-menu {
  border: 1px solid var(--crm-border);
  border-radius: var(--crm-radius);
  box-shadow: var(--crm-shadow-md);
}

.dropdown-menu {
  padding: 8px;
}

.dropdown-menu > li > a {
  border-radius: 6px;
  color: #374151;
  padding: 8px 10px;
}

.dropdown-menu > li > a:hover,
.dropdown-menu > li > a:focus {
  background: var(--crm-primary-soft);
  color: var(--crm-primary-dark);
}

.table,
table.dataTable {
  background: var(--crm-surface);
  color: #374151;
}

.table > thead > tr > th,
table.dataTable thead > tr > th {
  background: var(--crm-surface-soft);
  border-bottom: 1px solid var(--crm-border) !important;
  color: #4b5563;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

.table > tbody > tr > td,
table.dataTable tbody > tr > td {
  border-top: 1px solid #edf0f4;
  vertical-align: middle;
}

.table-hover > tbody > tr:hover,
table.dataTable tbody tr:hover {
  background: #f8fbff;
}

.dataTables_wrapper .dataTables_filter input,
.form-control,
.bootstrap-select .btn-default,
.input-group-addon,
input[type="text"],
input[type="email"],
input[type="number"],
input[type="password"],
input[type="search"],
input[type="url"],
select,
textarea {
  border-color: var(--crm-border-strong) !important;
  border-radius: var(--crm-radius) !important;
  box-shadow: none !important;
}

.form-control:focus,
.bootstrap-select.open .btn-default,
.bootstrap-select .btn-default:focus,
input:focus,
select:focus,
textarea:focus {
  border-color: #93c5fd !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12) !important;
  outline: none !important;
}

.btn {
  border-radius: var(--crm-radius);
  font-weight: 600;
  letter-spacing: 0;
  box-shadow: none;
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
}

.btn-primary,
.btn-info {
  background: var(--crm-primary) !important;
  border-color: var(--crm-primary) !important;
  color: #fff !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-info:hover,
.btn-info:focus {
  background: var(--crm-primary-dark) !important;
  border-color: var(--crm-primary-dark) !important;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.22);
}

.btn-default {
  background: #fff;
  border-color: var(--crm-border-strong);
  color: #374151;
}

.btn-default:hover,
.btn-default:focus {
  background: #f8fafc;
  border-color: #bfdbfe;
  color: var(--crm-primary-dark);
}

.btn-success {
  background: var(--crm-success) !important;
  border-color: var(--crm-success) !important;
}

.btn-warning {
  background: var(--crm-warning) !important;
  border-color: var(--crm-warning) !important;
}

.btn-danger {
  background: var(--crm-danger) !important;
  border-color: var(--crm-danger) !important;
}

.label,
.badge {
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0;
  padding: 0.28em 0.62em;
}

.alert {
  border: 0;
  border-radius: var(--crm-radius);
  box-shadow: var(--crm-shadow-sm);
}

.alert-info {
  background: #eff6ff;
  color: #1e40af;
}

.alert-success {
  background: #ecfdf5;
  color: #065f46;
}

.alert-warning {
  background: #fffbeb;
  color: #92400e;
}

.alert-danger {
  background: #fef2f2;
  color: #991b1b;
}

.nav-tabs {
  border-bottom-color: var(--crm-border);
}

.nav-tabs > li > a {
  border-radius: var(--crm-radius) var(--crm-radius) 0 0;
  color: var(--crm-muted);
  font-weight: 600;
}

.nav-tabs > li.active > a,
.nav-tabs > li.active > a:hover,
.nav-tabs > li.active > a:focus {
  border-color: var(--crm-border);
  border-bottom-color: #fff;
  color: var(--crm-primary);
}

.modal-content {
  overflow: hidden;
}

.modal-header,
.modal-footer {
  border-color: var(--crm-border);
}

.modal-title,
h1,
h2,
h3,
h4 {
  color: var(--crm-text);
  font-weight: 650;
  letter-spacing: 0;
}

hr {
  border-top-color: var(--crm-border);
}

::-webkit-scrollbar {
  height: 10px;
  width: 10px;
}

::-webkit-scrollbar-track {
  background: #eef2f7;
}

::-webkit-scrollbar-thumb {
  background: #c7d2e1;
  border: 2px solid #eef2f7;
  border-radius: 999px;
}

::-webkit-scrollbar-thumb:hover {
  background: #94a3b8;
}

@media (max-width: 768px) {
  .content {
    padding: 16px;
  }

  .panel_s,
  .panel,
  .modal-content,
  .dropdown-menu {
    border-radius: 6px;
  }
}
