/* ================================================
   iResponse Pro — Professional Dark Theme v4
   COLOR ONLY — zero structural or layout overrides.
   Metronic / Bootstrap handle all positioning.
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  /* Backgrounds — deepest to highest */
  --bg-base:    #07080c;
  --bg-surface: #0d1018;
  --bg-raised:  #131720;
  --bg-input:   #191e2a;
  --bg-hover:   #1f2535;
  --bg-active:  #252d40;

  /* Borders */
  --border-0: #151c2c;
  --border-1: #1d2640;
  --border-2: #263050;

  /* Brand accent */
  --accent:       #4f8ef7;
  --accent-hover: #6ba3ff;
  --accent-muted: rgba(79,142,247,0.10);
  --accent-glow:  rgba(79,142,247,0.20);

  /* Text */
  --text-0: #f1f5ff;   /* primary */
  --text-1: #8896b3;   /* secondary */
  --text-2: #4f5e7a;   /* muted */

  /* Semantic */
  --success: #22c55e;
  --warning: #f59e0b;
  --danger:  #ef4444;
  --info:    #06b6d4;
  --purple:  #a855f7;

  /* Semantic muted */
  --success-bg: rgba(34,197,94,0.08);
  --warning-bg: rgba(245,158,11,0.08);
  --danger-bg:  rgba(239,68,68,0.08);
  --info-bg:    rgba(6,182,212,0.08);
  --purple-bg:  rgba(168,85,247,0.08);

  /* Typography */
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;
}

/* ===========================================
   BASE
   =========================================== */

body {
  background: var(--bg-base) !important;
  color: var(--text-0) !important;
  font-family: var(--font-sans) !important;
  font-size: 13px !important;
  -webkit-font-smoothing: antialiased !important;
}

a { color: var(--accent) !important; }
a:hover { color: var(--accent-hover) !important; }

h1, h2, h3, h4, h5, h6 { color: var(--text-0) !important; }
p { color: var(--text-1) !important; }

/* ===========================================
   HEADER
   =========================================== */

.page-header.navbar {
  background: rgba(7,8,12,0.96) !important;
  border-bottom: 1px solid var(--border-1) !important;
  box-shadow: 0 1px 0 var(--border-0) !important;
}

/* Logo area — color only, NO width/height/display/overflow */
.page-logo {
  background: var(--bg-base) !important;
  border-right: 1px solid var(--border-1) !important;
}

/* Constrain the img only, not the container */
.page-logo img.logo-default {
  max-height: 32px !important;
  width: auto !important;
  object-fit: contain !important;
}

/* Header nav icons */
.page-header .page-top .top-menu .navbar-nav > li > a {
  color: var(--text-1) !important;
}
.page-header .page-top .top-menu .navbar-nav > li > a:hover {
  color: var(--text-0) !important;
  background: var(--bg-hover) !important;
}

/* Header search */
.page-header .search-form .input-group .form-control {
  background: var(--bg-input) !important;
  border-color: var(--border-1) !important;
  color: var(--text-0) !important;
}

/* ===========================================
   SIDEBAR
   =========================================== */

/* Color only — NO display, position, width, height, overflow */
.page-sidebar,
.page-sidebar-wrapper {
  background: var(--bg-base) !important;
  border-right: 1px solid var(--border-1) !important;
}

/* Top-level menu items */
.page-sidebar-menu > li > a {
  color: var(--text-0) !important;
  border-radius: 6px !important;
}
.page-sidebar-menu > li > a:hover {
  color: var(--text-0) !important;
  background: var(--bg-hover) !important;
}
.page-sidebar-menu > li.active > a,
.page-sidebar-menu > li.open > a {
  color: var(--accent) !important;
  background: var(--accent-muted) !important;
}
.page-sidebar-menu > li > a > i {
  color: inherit !important;
}

/* Arrow icons */
.page-sidebar-menu > li > a > .arrow { color: var(--text-0) !important; opacity: 0.6; }
.page-sidebar-menu > li.open > a > .arrow,
.page-sidebar-menu > li.active > a > .arrow { color: var(--accent) !important; }

/* Sub-menus */
.page-sidebar-menu .sub-menu { background: transparent !important; }
.page-sidebar-menu .sub-menu > li > a {
  color: #e2e8f0 !important;
  border-radius: 4px !important;
}
.page-sidebar-menu .sub-menu > li > a:hover {
  color: var(--text-0) !important;
  background: var(--bg-hover) !important;
}
.page-sidebar-menu .sub-menu > li.active > a {
  color: var(--accent) !important;
}

/* Sidebar separators */
.page-sidebar-menu .sidebar-separator {
  height: 1px !important;
  background: var(--border-0) !important;
  margin: 8px 12px !important;
  list-style: none !important;
}

/* ===========================================
   PAGE CONTENT AREAS
   =========================================== */

.page-content,
.page-content-wrapper,
.page-content-inner,
.page-container {
  background: var(--bg-base) !important;
}

/* Kill lingering white backgrounds */
.white,
.page-content-white,
.form-body,
.bg-white,
.bg-default {
  background: transparent !important;
}

/* ===========================================
   PAGE HEADER (ir-page-header / ir-page-title / ir-page-actions)
   Used on every feature page — flex row, title left, actions right
   =========================================== */

.ir-page-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin: 0 0 20px 0 !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--border-0) !important;
  min-height: 40px;
}

.ir-page-title {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  color: var(--text-0) !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.3 !important;
}

.ir-page-title i,
h1.ir-page-title i {
  color: var(--accent) !important;
  font-size: 15px !important;
}

/* Support h1.ir-page-title — reset browser defaults */
h1.ir-page-title {
  font-size: 17px !important;
  font-weight: 700 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ir-page-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0;
}

/* ===========================================
   PORTLETS / CARDS
   =========================================== */

.portlet,
.portlet.light,
.portlet.solid {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-1) !important;
  border-radius: 10px !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.4) !important;
}
.portlet.light > .portlet-title,
.portlet > .portlet-title {
  background: var(--bg-raised) !important;
  border-bottom: 1px solid var(--border-1) !important;
  border-radius: 10px 10px 0 0 !important;
}
.portlet-title .caption {
  color: var(--text-0) !important;
}
.portlet-title .caption-subject {
  color: var(--text-1) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.6px !important;
}
.portlet-title .caption > i { color: var(--accent) !important; }
.portlet-body { background: var(--bg-surface) !important; }

/* ===========================================
   TABLES
   =========================================== */

table td, table th,
.table td, .table th,
.table > thead > tr > th,
.table > tbody > tr > td,
.dataTable > tbody > tr > td,
div.dataTables_wrapper table td,
div.dataTables_wrapper table th {
  background-color: transparent !important;
  color: var(--text-0) !important;
  border-color: var(--border-0) !important;
}

.table > thead > tr > th,
table.dataTable thead th,
table.dataTable thead td {
  background-color: var(--bg-raised) !important;
  color: var(--text-2) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.7px !important;
  border-bottom: 1px solid var(--border-1) !important;
}

.table > tbody > tr:hover > td,
table.dataTable tbody tr:hover > td {
  background: var(--bg-hover) !important;
}

table.dataTable.stripe tbody tr.odd  { background: rgba(255,255,255,0.015) !important; }
table.dataTable.stripe tbody tr.even { background: transparent !important; }
table.dataTable tbody tr > .sorting_1 { background: rgba(79,142,247,0.04) !important; }

/* DataTable wrapper */
.dataTables_wrapper {
  color: var(--text-0) !important;
}
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_info {
  color: var(--text-1) !important;
}
.dataTables_wrapper select,
.dataTables_wrapper input[type="search"] {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-1) !important;
  color: var(--text-0) !important;
  border-radius: 4px !important;
}

/* Table filter row */
.table > thead > tr.filter > td {
  background: var(--bg-surface) !important;
  border-color: var(--border-1) !important;
}
.table > thead > tr.filter > td input,
.table > thead > tr.filter > td select {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-1) !important;
  color: var(--text-0) !important;
  border-radius: 4px !important;
}

/* ===========================================
   BUTTONS
   =========================================== */

.btn-primary, .btn-info {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #fff !important;
  font-weight: 500 !important;
  letter-spacing: 0.2px !important;
}
.btn-primary:hover, .btn-info:hover {
  background: var(--accent-hover) !important;
  border-color: var(--accent-hover) !important;
  box-shadow: 0 0 0 3px var(--accent-glow) !important;
}
.btn-success {
  background: var(--success) !important;
  border-color: var(--success) !important;
  color: #fff !important;
}
.btn-danger {
  background: var(--danger) !important;
  border-color: var(--danger) !important;
  color: #fff !important;
}
.btn-warning {
  background: var(--warning) !important;
  border-color: var(--warning) !important;
  color: #000 !important;
}
.btn-default {
  background: var(--bg-raised) !important;
  border-color: var(--border-2) !important;
  color: var(--text-1) !important;
}
.btn-default:hover {
  background: var(--bg-hover) !important;
  color: var(--text-0) !important;
  border-color: var(--border-2) !important;
}

/* ===========================================
   FORMS
   =========================================== */

.form-control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="search"],
input[type="tel"],
input[type="url"],
textarea,
select {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-1) !important;
  color: var(--text-0) !important;
  border-radius: 6px !important;
  font-family: var(--font-sans) !important;
}
.form-control:focus,
input:focus,
textarea:focus,
select:focus {
  background: var(--bg-input) !important;
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-muted) !important;
  color: var(--text-0) !important;
  outline: none !important;
}
.form-control::placeholder,
input::placeholder,
textarea::placeholder {
  color: var(--text-2) !important;
}

label,
.control-label {
  color: var(--text-1) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

.input-group-addon {
  background: var(--bg-raised) !important;
  border-color: var(--border-1) !important;
  color: var(--text-2) !important;
}
.input-icon > i {
  color: var(--text-2) !important;
  z-index: 3 !important;
}

/* Form help text */
.help-block { color: var(--text-2) !important; font-size: 11px !important; }

/* ===========================================
   BOOTSTRAP SELECT
   =========================================== */

body .bootstrap-select > .btn,
body .bootstrap-select > .dropdown-toggle {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-1) !important;
  color: var(--text-0) !important;
  box-shadow: none !important;
}
body .bootstrap-select > .btn:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-muted) !important;
  outline: none !important;
}
body .bootstrap-select .dropdown-menu {
  background: var(--bg-raised) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: 8px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.6) !important;
  z-index: 9999 !important;
}
body .bootstrap-select .dropdown-menu li > a {
  color: var(--text-1) !important;
  border-radius: 4px !important;
}
body .bootstrap-select .dropdown-menu li > a:hover {
  background: var(--bg-hover) !important;
  color: var(--text-0) !important;
}
body .bootstrap-select .dropdown-menu li.selected > a {
  background: var(--accent-muted) !important;
  color: var(--accent) !important;
}
body .bootstrap-select .filter-option-inner-inner { color: var(--text-0) !important; }
body .bootstrap-select .bs-placeholder .filter-option-inner-inner { color: var(--text-2) !important; }

/* ===========================================
   DROPDOWNS
   =========================================== */

.dropdown-menu {
  background: var(--bg-raised) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: 8px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.6) !important;
}
.dropdown-menu > li > a {
  color: var(--text-1) !important;
}
.dropdown-menu > li > a:hover,
.dropdown-menu > li > a:focus {
  background: var(--bg-hover) !important;
  color: var(--text-0) !important;
}
.dropdown-menu .divider {
  background: var(--border-1) !important;
}

/* ===========================================
   MODALS
   =========================================== */

.modal-content {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: 12px !important;
  color: var(--text-0) !important;
  box-shadow: 0 16px 64px rgba(0,0,0,0.7) !important;
}
.modal-header {
  background: var(--bg-raised) !important;
  border-bottom: 1px solid var(--border-1) !important;
  border-radius: 12px 12px 0 0 !important;
}
.modal-footer {
  background: var(--bg-raised) !important;
  border-top: 1px solid var(--border-1) !important;
  border-radius: 0 0 12px 12px !important;
}
.modal-title { color: var(--text-0) !important; font-weight: 600 !important; }
.modal-backdrop { background: rgba(0,0,0,0.75) !important; }
.close { color: var(--text-2) !important; opacity: 1 !important; }
.close:hover { color: var(--text-0) !important; }

/* ===========================================
   SWEET ALERT
   =========================================== */

.sweet-alert {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: 12px !important;
  box-shadow: 0 16px 64px rgba(0,0,0,0.7) !important;
}
.sweet-alert h2 { color: var(--text-0) !important; }
.sweet-alert p  { color: var(--text-1) !important; }

/* ===========================================
   TOASTR
   =========================================== */

#toast-container { top: 65px !important; right: 20px !important; }
#toast-container > .toast {
  background: var(--bg-raised) !important;
  border: 1px solid var(--border-1) !important;
  border-radius: 8px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.6) !important;
  color: var(--text-0) !important;
  opacity: 0.98 !important;
}
#toast-container > .toast-success { border-left: 3px solid var(--success) !important; }
#toast-container > .toast-error   { border-left: 3px solid var(--danger)  !important; }
#toast-container > .toast-warning { border-left: 3px solid var(--warning) !important; }
#toast-container > .toast-info    { border-left: 3px solid var(--accent)  !important; }
.toast-title   { color: var(--text-0) !important; font-weight: 600 !important; font-size: 13px !important; }
.toast-message { color: var(--text-1) !important; font-size: 12px !important; }

/* ===========================================
   TABS
   =========================================== */

.nav-tabs {
  border-bottom: 1px solid var(--border-1) !important;
}
.nav-tabs > li > a {
  color: var(--text-2) !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  background: transparent !important;
  font-size: 12px !important;
  font-weight: 500 !important;
}
.nav-tabs > li > a:hover {
  color: var(--text-1) !important;
  background: transparent !important;
  border-bottom-color: var(--border-2) !important;
}
.nav-tabs > li.active > a,
.nav-tabs > li.active > a:hover,
.nav-tabs > li.active > a:focus {
  color: var(--accent) !important;
  border-bottom: 2px solid var(--accent) !important;
  background: transparent !important;
}
.tab-content { color: var(--text-0) !important; }

/* ===========================================
   PAGINATION
   =========================================== */

.pagination > li > a,
.pagination > li > span {
  background: var(--bg-raised) !important;
  border-color: var(--border-1) !important;
  color: var(--text-1) !important;
}
.pagination > li > a:hover {
  background: var(--bg-hover) !important;
  color: var(--text-0) !important;
  border-color: var(--border-2) !important;
}
.pagination > li.active > a,
.pagination > li.active > span {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #fff !important;
}
.pagination > li.disabled > a {
  background: var(--bg-raised) !important;
  color: var(--text-2) !important;
  border-color: var(--border-0) !important;
}

/* ===========================================
   PROGRESS BARS
   =========================================== */

.progress {
  background: var(--bg-raised) !important;
  border-radius: 4px !important;
  height: 6px !important;
}
.progress-bar { background: var(--accent) !important; }
.progress-bar-success { background: var(--success) !important; }
.progress-bar-warning { background: var(--warning) !important; }
.progress-bar-danger  { background: var(--danger)  !important; }

/* ===========================================
   CHECKBOXES & RADIOS (Metronic)
   =========================================== */

.mt-checkbox > span {
  border-color: var(--border-2) !important;
  background: var(--bg-input) !important;
}
.mt-checkbox input:checked ~ span {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
}
.mt-radio > span {
  border-color: var(--border-2) !important;
  background: var(--bg-input) !important;
}
.mt-radio input:checked ~ span { border-color: var(--accent) !important; }
.mt-radio input:checked ~ span:after { background: var(--accent) !important; }

/* ===========================================
   SPINNER / LOADING OVERLAY
   NOTE: NO display property — layout.min.js
   controls visibility with jQuery fadeOut().
   !important on display blocks that from ever
   hiding.
   =========================================== */

section.wrapper { background: var(--bg-base) !important; }
.spinner i      { background: var(--accent) !important; }

/* ===========================================
   SCROLLBAR
   =========================================== */

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg-base); }
::-webkit-scrollbar-thumb { background: var(--border-1); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--border-2); }

/* ===========================================
   ALERTS
   =========================================== */

.alert {
  border-radius: 8px !important;
  border: 1px solid !important;
}
.alert-success { background: var(--success-bg) !important; border-color: rgba(34,197,94,0.2) !important; color: var(--success) !important; }
.alert-warning { background: var(--warning-bg) !important; border-color: rgba(245,158,11,0.2) !important; color: var(--warning) !important; }
.alert-danger  { background: var(--danger-bg)  !important; border-color: rgba(239,68,68,0.2)  !important; color: var(--danger)  !important; }
.alert-info    { background: var(--info-bg)    !important; border-color: rgba(6,182,212,0.2)   !important; color: var(--info)    !important; }

/* ===========================================
   PANELS (Bootstrap)
   =========================================== */

.panel { background: var(--bg-surface) !important; border-color: var(--border-1) !important; border-radius: 10px !important; }
.panel-heading { background: var(--bg-raised) !important; border-color: var(--border-1) !important; color: var(--text-0) !important; }
.panel-body { color: var(--text-0) !important; }
.panel-footer { background: var(--bg-raised) !important; border-color: var(--border-1) !important; }

/* ===========================================
   WELLS
   =========================================== */

.well {
  background: var(--bg-raised) !important;
  border-color: var(--border-1) !important;
  border-radius: 8px !important;
  color: var(--text-0) !important;
}

/* ===========================================
   LOGIN PAGE
   =========================================== */

body.login {
  background: var(--bg-base) !important;
}

.login-form {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: 16px !important;
  padding: 40px !important;
  box-shadow: 0 16px 64px rgba(0,0,0,0.7) !important;
}
.login-form .btn-primary {
  width: 100% !important;
  height: 42px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
}
.login-logo img {
  max-height: 36px !important;
  width: auto !important;
}
.login .copyright {
  color: var(--text-2) !important;
  font-size: 11px !important;
}

/* ===========================================
   DASHBOARD KPI CARDS
   =========================================== */

.kpi-card {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-1) !important;
  border-radius: 10px !important;
  padding: 20px !important;
  transition: border-color 0.18s ease, box-shadow 0.18s ease !important;
}
.kpi-card:hover {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 1px var(--accent-muted), 0 4px 16px rgba(0,0,0,0.4) !important;
}
.kpi-number {
  font-size: 28px !important;
  font-weight: 700 !important;
  color: var(--text-0) !important;
  line-height: 1 !important;
  font-family: var(--font-mono) !important;
  letter-spacing: -0.5px !important;
}
.kpi-label {
  font-size: 10px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.7px !important;
  color: var(--text-2) !important;
}
.kpi-rate {
  font-size: 12px !important;
  color: var(--text-1) !important;
  margin-top: 4px !important;
}

/* Metronic stat widgets */
.dashboard-stat2 {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-1) !important;
  border-radius: 10px !important;
}
.dashboard-stat2 .number h3 { color: inherit !important; }
.dashboard-stat2 .number small { color: var(--text-2) !important; font-size: 11px !important; }
.dashboard-stat { background: var(--bg-surface) !important; border-radius: 10px !important; }

/* ===========================================
   STATUS BADGES
   =========================================== */

.badge-pass {
  background: var(--success-bg) !important;
  color: var(--success) !important;
  border: 1px solid rgba(34,197,94,0.2) !important;
  padding: 2px 10px !important;
  border-radius: 9999px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  font-family: var(--font-sans) !important;
}
.badge-warn {
  background: var(--warning-bg) !important;
  color: var(--warning) !important;
  border: 1px solid rgba(245,158,11,0.2) !important;
  padding: 2px 10px !important;
  border-radius: 9999px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
}
.badge-fail {
  background: var(--danger-bg) !important;
  color: var(--danger) !important;
  border: 1px solid rgba(239,68,68,0.2) !important;
  padding: 2px 10px !important;
  border-radius: 9999px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
}

/* Bootstrap default labels */
.label-success { background: var(--success) !important; }
.label-warning { background: var(--warning) !important; color: #000 !important; }
.label-danger  { background: var(--danger)  !important; }
.label-info    { background: var(--info)    !important; }
.label-primary { background: var(--accent)  !important; }
.label-default { background: var(--bg-active) !important; color: var(--text-1) !important; }

/* ===========================================
   MISC
   =========================================== */

/* Breadcrumbs */
.breadcrumb { background: transparent !important; }
.breadcrumb > li > a { color: var(--text-1) !important; }
.breadcrumb > li.active { color: var(--text-0) !important; }
.breadcrumb > li + li:before { color: var(--text-2) !important; }

/* List groups */
.list-group-item {
  background: var(--bg-surface) !important;
  border-color: var(--border-1) !important;
  color: var(--text-0) !important;
}
.list-group-item:hover { background: var(--bg-hover) !important; }
.list-group-item.active {
  background: var(--accent-muted) !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

/* Code */
code, kbd, pre, samp {
  font-family: var(--font-mono) !important;
  background: var(--bg-raised) !important;
  border: 1px solid var(--border-1) !important;
  color: var(--accent) !important;
  border-radius: 4px !important;
}
pre {
  color: var(--text-0) !important;
  border-color: var(--border-1) !important;
}

/* HR */
hr { border-color: var(--border-0) !important; }

/* Jumbotron */
.jumbotron { background: var(--bg-raised) !important; color: var(--text-0) !important; border-radius: 10px !important; }

/* Tooltips */
.tooltip-inner { background: var(--bg-raised) !important; color: var(--text-0) !important; border: 1px solid var(--border-2) !important; border-radius: 6px !important; }

/* Popover */
.popover { background: var(--bg-raised) !important; border-color: var(--border-2) !important; border-radius: 10px !important; }
.popover-title { background: var(--bg-hover) !important; color: var(--text-0) !important; border-color: var(--border-1) !important; }
.popover-content { color: var(--text-1) !important; }

/* ===========================================
   CUSTOM COMPONENT CLASSES
   =========================================== */

.ir-card {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-1) !important;
  border-radius: 10px !important;
  padding: 20px !important;
  margin-bottom: 20px !important;
}
.ir-card-header {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: var(--accent) !important;
  margin-bottom: 16px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--border-1) !important;
}

/* ===========================================
   LOGIN PAGE — Premium Redesign
   =========================================== */

html, body.login { height: 100%; margin: 0; padding: 0; }

body.login {
    background-color: #07080c !important;
    background-image:
        radial-gradient(ellipse 80% 60% at 50% -10%, rgba(79,142,247,0.08) 0%, transparent 60%),
        radial-gradient(rgba(79,142,247,0.06) 1px, transparent 1px) !important;
    background-size: 100% 100%, 32px 32px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 100vh !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
}

/* Spinner — display WITHOUT !important so jQuery fadeOut() wins */
body.login section.wrapper {
    position: fixed !important;
    top: 0; left: 0; right: 0; bottom: 0;
    background: #07080c !important;
    z-index: 9999 !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.login .content {
    width: 100% !important;
    max-width: 420px !important;
    padding: 20px !important;
    box-sizing: border-box !important;
}

/* Card */
body.login .login-form {
    background: #0d1018 !important;
    border: 1px solid #1d2640 !important;
    border-radius: 16px !important;
    padding: 40px !important;
    box-shadow:
        0 24px 64px rgba(0,0,0,0.6),
        0 0 0 1px rgba(79,142,247,0.05) !important;
    box-sizing: border-box !important;
}

/* Logo */
body.login .login-form .form-title {
    text-align: center !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
}
body.login .login-form .form-title img {
    height: 30px !important;
    width: auto !important;
    display: inline-block !important;
}
body.login .form-divider {
    border: none !important;
    border-top: 1px solid #151c2c !important;
    margin: 24px 0 !important;
}

/* Field groups */
body.login .login-form .form-group { margin-bottom: 16px !important; }
body.login .login-form label.control-label {
    font-size: 10.5px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: #4f5e7a !important;
    margin-bottom: 6px !important;
    display: block !important;
    line-height: 1 !important;
}

/* Input icon wrapper */
body.login .login-form .input-icon { position: relative !important; }
body.login .login-form .input-icon > i {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 13px !important;
    z-index: 4 !important;
    pointer-events: none !important;
    color: #4f5e7a !important;
    left: 13px !important;
}
body.login .login-form .input-icon .pw-toggle {
    left: auto !important;
    right: 13px !important;
    cursor: pointer !important;
    pointer-events: all !important;
    transition: color 0.12s !important;
}
body.login .login-form .input-icon .pw-toggle:hover { color: #8896b3 !important; }

/* Inputs */
body.login .login-form .form-control {
    height: 42px !important;
    background: #131720 !important;
    border: 1px solid #1d2640 !important;
    border-radius: 8px !important;
    color: #f1f5ff !important;
    font-size: 13px !important;
    padding: 0 12px 0 38px !important;
    box-shadow: none !important;
    transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
    box-sizing: border-box !important;
    width: 100% !important;
}
body.login .login-form .form-control.has-toggle { padding-right: 38px !important; }
body.login .login-form .form-control:focus {
    border-color: #4f8ef7 !important;
    box-shadow: 0 0 0 3px rgba(79,142,247,0.12) !important;
    background: #131720 !important;
    color: #f1f5ff !important;
    outline: none !important;
}
body.login .login-form .form-control::placeholder { color: #4f5e7a !important; }

/* Actions row */
body.login .login-form .form-actions {
    margin-top: 24px !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
}

/* Submit button */
body.login .login-form .btn-primary {
    width: 100% !important;
    height: 42px !important;
    background: linear-gradient(135deg, #4f8ef7 0%, #3b7af0 100%) !important;
    border: none !important;
    border-radius: 8px !important;
    color: #ffffff !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    letter-spacing: 0.2px !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    transition: filter 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease !important;
    box-shadow: 0 4px 14px rgba(79,142,247,0.25) !important;
}
body.login .login-form .btn-primary:hover {
    filter: brightness(1.08) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 8px 24px rgba(79,142,247,0.35) !important;
}
body.login .login-form .btn-primary:active {
    transform: translateY(0) !important;
    filter: brightness(0.98) !important;
}

/* Card footer copyright */
.login-card-footer {
    text-align: center !important;
    margin-top: 20px !important;
    color: #2d3a52 !important;
    font-size: 11px !important;
    line-height: 1.5 !important;
}
body.login .copyright { display: none !important; }

/* ===========================================
   SEND PROCESS PAGE — Section Styles
   =========================================== */

.ir-send-section {
    background: #0d1018 !important;
    border: 1px solid #1d2640 !important;
    border-radius: 12px !important;
    padding: 20px !important;
    margin-bottom: 16px !important;
}
.ir-send-section-header {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 10.5px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: #4f8ef7 !important;
    margin-bottom: 16px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #151c2c !important;
}
.ir-field-label {
    font-size: 10.5px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: #4f5e7a !important;
    margin-bottom: 5px !important;
    display: block !important;
}
.ir-send-footer {
    position: fixed !important;
    bottom: 0 !important;
    left: 215px !important;
    right: 0 !important;
    height: 54px !important;
    background: rgba(7,8,12,0.97) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    backdrop-filter: blur(12px) !important;
    border-top: 1px solid #1d2640 !important;
    padding: 0 20px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    z-index: 900 !important;
    box-shadow: 0 -4px 24px rgba(0,0,0,0.4) !important;
    margin: 0 !important;
    border-radius: 0 !important;
}
.page-sidebar-closed .ir-send-footer { left: 55px !important; }
.ir-send-footer-status {
    font-size: 12px !important;
    color: #4f5e7a !important;
    font-weight: 500 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}
.ir-send-footer-actions {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
}
.ir-btn-send {
    background: linear-gradient(135deg, #4f8ef7 0%, #3b7af0 100%) !important;
    border: none !important;
    border-radius: 6px !important;
    color: #fff !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    height: 36px !important;
    padding: 0 24px !important;
    cursor: pointer !important;
    transition: filter 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease !important;
    box-shadow: 0 2px 14px rgba(79,142,247,0.4) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
}
.ir-btn-send:hover {
    filter: brightness(1.08) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 8px 24px rgba(79,142,247,0.4) !important;
}
.ir-btn-send:active { transform: translateY(0) !important; }
.ir-btn-schedule {
    background: transparent !important;
    border: 1px solid #2d3a50 !important;
    border-radius: 6px !important;
    color: #8896b3 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    height: 36px !important;
    padding: 0 18px !important;
    cursor: pointer !important;
    transition: all 0.15s ease !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
}
.ir-btn-schedule:hover {
    border-color: #4f8ef7 !important;
    color: #4f8ef7 !important;
    background: rgba(79,142,247,0.06) !important;
}

/* ── Page Footer ── */
.page-footer {
    background: #07080c !important;
    border-top: 1px solid #1e2535 !important;
}
.page-footer-inner {
    color: #4e5d78 !important;
}

/* ===========================================
   NOTE / ALERT BANNERS — dark overrides
   =========================================== */
.note { border-radius: 6px !important; }

.note.note-info {
    background-color: #111827 !important;
    border-color: #1e3a5f !important;
    color: #e2e8f0 !important;
}
.note.note-info h4,
.note.note-info p,
.note.note-info .caption {
    color: #e2e8f0 !important;
}
.note.note-info i {
    color: #4f8ef7 !important;
}

.note.note-warning {
    background-color: #1a1305 !important;
    border-color: #78350f !important;
    color: #fde68a !important;
}
.note.note-warning h4,
.note.note-warning p { color: #fde68a !important; }

.note.note-danger {
    background-color: #1a0505 !important;
    border-color: #7f1d1d !important;
    color: #fca5a5 !important;
}
.note.note-danger h4,
.note.note-danger p { color: #fca5a5 !important; }

.note.note-success {
    background-color: #061209 !important;
    border-color: #14532d !important;
    color: #86efac !important;
}
.note.note-success h4,
.note.note-success p { color: #86efac !important; }

/* .portlet.light.bordered — Metronic's 3-class selector beats our 2-class rule */
.portlet.light.bordered {
    background: #0d1018 !important;
    border: 1px solid #2a3347 !important;
}
.portlet.light.bordered > .portlet-title {
    background: #131720 !important;
    border-bottom: 1px solid #2a3347 !important;
}

/* ===========================================
   HTML CLEANER — Grade Badges
   =========================================== */
.grade-badge {
  display: inline-block;
  width: 24px;
  height: 24px;
  line-height: 24px;
  text-align: center;
  font-size: 12px;
  font-weight: 800;
  border-radius: 5px;
}
.grade-a { background: #071b10; color: #22c55e; border: 1px solid #22c55e40; }
.grade-b { background: #071b10; color: #4ade80; border: 1px solid #4ade8040; }
.grade-c { background: #1a1200; color: #f59e0b; border: 1px solid #f59e0b40; }
.grade-d { background: #1a0e00; color: #f97316; border: 1px solid #f9731640; }
.grade-f { background: #1a0808; color: #ef4444; border: 1px solid #ef444440; }

/* ===========================================
   BOT CLICK DETECTION — Row Highlight
   =========================================== */
.bot-row { background: rgba(239,68,68,.04) !important; }
.bot-row:hover td { background: rgba(239,68,68,.07) !important; }

/* ===========================================
   TOOLS MENU — Grouped Category Labels
   =========================================== */

/* Label row: no pointer, no hover flash */
.page-sidebar .page-sidebar-menu .sub-menu li.menu-group-label,
.page-sidebar .page-sidebar-menu .sub-menu li.menu-group-label:hover {
  pointer-events: none;
  cursor: default;
  background: transparent !important;
}

/* Label text: accent blue, bold, uppercase */
.page-sidebar .page-sidebar-menu .sub-menu li.menu-group-label > span {
  display: block;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: #4f8ef7;
  opacity: 0.7;
  padding: 12px 16px 3px 16px;
  line-height: 1;
}

/* First category: tighter top padding */
.page-sidebar .page-sidebar-menu .sub-menu li.menu-group-label:first-child > span {
  padding-top: 7px;
}

/* Divider row: no hover, no pointer */
.page-sidebar .page-sidebar-menu .sub-menu li.menu-group-divider,
.page-sidebar .page-sidebar-menu .sub-menu li.menu-group-divider:hover {
  pointer-events: none;
  padding: 0;
  margin: 0;
  background: transparent !important;
}

/* Divider line: visible gradient hairline */
.page-sidebar .page-sidebar-menu .sub-menu li.menu-group-divider > span {
  display: block;
  height: 1px;
  background: linear-gradient(to right, transparent, #1d2a3f 25%, #1d2a3f 75%, transparent);
  margin: 7px 10px 3px 10px;
}

/* Tools submenu items: indent under category headers */
.tools-submenu li:not(.menu-group-label):not(.menu-group-divider) > a {
  padding-left: 26px !important;
  font-size: 12px !important;
}

/* Tools submenu item hover: left-border accent */
.tools-submenu li:not(.menu-group-label):not(.menu-group-divider) > a:hover {
  border-left: 2px solid rgba(79, 142, 247, 0.5) !important;
  padding-left: 24px !important;
}

/* Tools submenu active item: blue accent */
.tools-submenu li.active > a,
.tools-submenu li.open > a {
  color: #4f8ef7 !important;
  border-left: 2px solid #4f8ef7 !important;
  padding-left: 24px !important;
}

/* ===========================================
   TABLE CARD / ACTIONS — global (40+ list pages)
   =========================================== */

.ir-table-card {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-1) !important;
  border-radius: 10px !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.4) !important;
  overflow: hidden !important;
  margin-bottom: 20px !important;
}

.ir-table-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 10px 14px !important;
  border-bottom: 1px solid var(--border-1) !important;
  background: var(--bg-raised) !important;
  min-height: 52px !important;
  flex-wrap: wrap !important;
}

.table-container {
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

/* ===========================================
   IR-PAGE-ACTIONS bare .btn (no variant class)
   e.g. "Add New ISP", "Create Mailboxes" links
   =========================================== */

.ir-page-actions a.btn:not([class*="btn-"]),
.ir-page-actions button.btn:not([class*="btn-"]) {
  background: var(--bg-raised) !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text-1) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  border-radius: 6px !important;
  padding: 6px 14px !important;
  transition: all 0.15s ease !important;
  box-shadow: none !important;
  line-height: 1.5 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  text-decoration: none !important;
}
.ir-page-actions a.btn:not([class*="btn-"]):hover,
.ir-page-actions button.btn:not([class*="btn-"]):hover {
  background: var(--bg-hover) !important;
  border-color: rgba(79,142,247,0.4) !important;
  color: var(--text-0) !important;
}

/* ===========================================
   BTN-GROUP dropdown trigger (no variant class)
   e.g. Tools / Export buttons on list pages
   =========================================== */

.btn-group > a.btn:not([class*="btn-"]),
.btn-group > button.btn:not([class*="btn-"]) {
  background: var(--bg-raised) !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text-1) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  border-radius: 6px !important;
  padding: 6px 12px !important;
  transition: all 0.15s ease !important;
  box-shadow: none !important;
  line-height: 1.5 !important;
}
.btn-group > a.btn:not([class*="btn-"]):hover,
.btn-group > button.btn:not([class*="btn-"]):hover {
  background: var(--bg-hover) !important;
  color: var(--text-0) !important;
  border-color: var(--border-2) !important;
}

/* Calendar toggle button inside input-group-btn */
.input-group-btn > .btn.default,
.input-group-btn > button.default {
  background: var(--bg-raised) !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text-2) !important;
  transition: all 0.15s ease !important;
  line-height: 1.5 !important;
}
.input-group-btn > .btn.default:hover {
  background: var(--bg-hover) !important;
  color: var(--text-1) !important;
  border-color: var(--accent) !important;
}

/* ===========================================
   DATE RANGE PICKER — Dark Theme Override
   =========================================== */

.daterangepicker {
  background: #161b27 !important;
  border: 1px solid #2a3347 !important;
  border-radius: 10px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.6) !important;
  color: #e2e8f0 !important;
  font-family: var(--font-sans) !important;
}
.daterangepicker:before,
.daterangepicker:after {
  display: none !important;
}
.daterangepicker .calendar-table {
  background: #161b27 !important;
  border: none !important;
}
.daterangepicker .calendar-table table {
  background: transparent !important;
}
.daterangepicker table th {
  color: #4e5d78 !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  background: transparent !important;
  border: none !important;
}
.daterangepicker table td,
.daterangepicker td {
  color: #94a3b8 !important;
  border-radius: 5px !important;
  background: transparent !important;
  border: none !important;
}
.daterangepicker td:hover {
  background: #1e2536 !important;
  color: #e2e8f0 !important;
}
.daterangepicker td.in-range {
  background: rgba(79,142,247,0.1) !important;
  color: #e2e8f0 !important;
}
.daterangepicker td.active,
.daterangepicker td.active:hover,
.daterangepicker td.start-date,
.daterangepicker td.end-date {
  background: #4f8ef7 !important;
  color: #fff !important;
}
.daterangepicker td.off,
.daterangepicker td.disabled {
  color: #2d3a52 !important;
}
.daterangepicker .ranges ul {
  background: #161b27 !important;
}
.daterangepicker .ranges li {
  color: #94a3b8 !important;
  border: 1px solid #2a3347 !important;
  background: transparent !important;
  border-radius: 5px !important;
}
.daterangepicker .ranges li:hover,
.daterangepicker .ranges li.active {
  background: #1e2536 !important;
  color: #e2e8f0 !important;
  border-color: #4f8ef7 !important;
}
.daterangepicker .drp-buttons {
  border-top: 1px solid #2a3347 !important;
  background: #131929 !important;
  border-radius: 0 0 10px 10px !important;
  padding: 10px 14px !important;
}
.daterangepicker .drp-selected {
  color: #4e5d78 !important;
  font-size: 11px !important;
}
.daterangepicker select.monthselect,
.daterangepicker select.yearselect {
  background: #1e2536 !important;
  border: 1px solid #2a3347 !important;
  color: #e2e8f0 !important;
  border-radius: 4px !important;
}
.daterangepicker .prev span,
.daterangepicker .next span {
  border-color: #64748b !important;
}
.daterangepicker .prev:hover span,
.daterangepicker .next:hover span {
  border-color: #e2e8f0 !important;
}
