:root {
  --green: #2d8653;
  --green-l: #e8f5ee;
  --green-d: #1e6b3f;
  --amber: #f59e0b;
  --amber-l: #fef3c7;
  --amber-d: #92400e;
  --red: #ef4444;
  --red-l: #fee2e2;
  --red-d: #991b1b;
  --blue: #3b82f6;
  --blue-l: #eff6ff;
  --purple: #7c3aed;
  --purple-l: #f3e8ff;
  --g50: #f9fafb;
  --g100: #f3f4f6;
  --g200: #e5e7eb;
  --g300: #d1d5db;
  --g400: #9ca3af;
  --g500: #6b7280;
  --g600: #4b5563;
  --g700: #374151;
  --g800: #1f2937;
  --g900: #111827;
  --surface: #ffffff;
  --surface-strong: #f8fafb;
  --font: 'Segoe UI', 'DM Sans', system-ui, sans-serif;
  --mono: 'DM Mono', monospace;
  --blue-d: #2563eb;
}

* {
  box-sizing: border-box;
}

html {
  font-family: var(--font);
  scroll-behavior: smooth;
}

html.opsus360-theme,
body.opsus360-theme {
  height: 100%;
}

body.opsus360-theme {
  background: linear-gradient(160deg, #f7fafc 0%, #edf7f1 100%);
  color: var(--g800);
}

#login-screen {
  min-height: 0;
  flex: 1 1 auto;
  height: 100%;
  overflow-y: auto;
}

#login-screen .content-wrapper {
  min-height: 100%;
  overflow: visible;
}

body.opsus360-theme, button, input, select, textarea {
  font-family: var(--font);
}

/* .opsus360-theme ::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.opsus360-theme ::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.15);
}

.opsus360-theme ::-webkit-scrollbar-thumb {
  background: rgba(45,134,83,0.45);
  border-radius: 999px;
}

.opsus360-theme {
  scrollbar-width: thin;
  scrollbar-color: rgba(45,134,83,0.45) rgba(255,255,255,0.15);
} */

a {
  color: var(--green);
}
a:hover {
  color: var(--green-d);
}

#login-screen {
  min-height: 100vh;
  background: radial-gradient(circle at top left, rgba(45,134,83,.18), transparent 28%),
              radial-gradient(circle at bottom right, rgba(59,130,246,.12), transparent 28%),
              linear-gradient(160deg, #111827 0%, #1f2937 45%, #2d8653 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.bg-radial {
  background: radial-gradient(circle at top left, rgba(45,134,83,.18), transparent 28%),
              radial-gradient(circle at bottom right, rgba(59,130,246,.12), transparent 28%),
              linear-gradient(160deg, #111827 0%, #1f2937 45%, #2d8653 100%);
}

.login-box {
  width: 420px;
  max-width: 460px;
  background: var(--surface);
  border-radius: 24px;
  /* padding: 36px; */
  box-shadow: 0 30px 80px rgba(15, 23, 42, .18);
  border: 1px solid rgba(15, 23, 42, .08);
}

.login-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-bottom: 18px;
}

.login-logo-icon {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: var(--green);
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 800;
  font-size: 20px;
}

.login-title { 
  text-align: center; 
  font-size: 19px; 
  font-weight: 800; 
  color: var(--g800); 
  margin-bottom: 4px; 
}


.login-subtitle {
  color: var(--g500);
  font-size: 14px;
  margin-bottom: 26px;
}

.login-box .card {
  border: 0;
  box-shadow: none;
  background: rgba(255,255,255,0.96);
}

.login-box .card-body {
  padding: 36px;
}

.login-form .btn-primary,
.login-box .btn-primary {
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #fff !important;
}

.login-form .btn-primary:hover,
.login-box .btn-primary:hover {
  background: #246d42 !important;
  border-color: #246d42 !important;
}

.login-box .form-label {
  font-weight: 700;
  color: var(--g700);
}

.login-box .form-control,
.login-box .form-control-feedback-start input {
  border-radius: 14px;
  border: 1px solid var(--g200);
  background: var(--surface-strong);
  color: var(--g800);
  padding: 12px 16px;
}

.login-box .form-control:focus,
.login-box .form-control-feedback-start input:focus {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(45, 134, 83, .12);
}

.login-box .btn-primary {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
}

.login-box .btn-primary:hover {
  background: #246d42;
  border-color: #246d42;
}

.login-box .form-check-input {
  background-color: #fff !important;
  border-color: var(--g200) !important;
  box-shadow: none !important;
  accent-color: var(--green) !important;
  background-clip: content-box;
}

.login-box .form-check-input:checked {
  background-color: var(--green) !important;
  border-color: var(--green) !important;
}

.login-box .form-check-label {
  color: var(--g600);
}

.login-box .text-muted {
  color: var(--g500) !important;
}

.login-box .alert {
  border-radius: 16px;
  color: #935656 !important;
  background: var(--red-l) !important;
}

.login-box .form-control-feedback-icon {
  position: absolute !important;
  top: 60%;
  transform: translateY(-50%);
  color: var(--g400);
}

.login-box .form-control-feedback-icon.icon-left {
  /* left: 16px; */
  right: auto;
}

.login-box .form-control-feedback-icon.icon-right {
  right: 16px;
  left: auto;
}

.login-box .form-control-feedback-start .form-control,
.login-box .form-control-feedback-start input {
  padding-left: 48px;
}

.login-box .form-control-feedback-end .form-control,
.login-box .form-control-feedback-end input {
  padding-right: 48px;
}

.login-box .form-control-feedback {
  position: relative;
}

.login-box .toggle-password-icon {
  z-index: 10;
}

.login-box .form-control-feedback-start {
  padding-left: 0;
}

.login-box .form-control-feedback-start .form-control,
.login-box .form-control-feedback-start input {
  padding-left: 40px;
  width: 100%;
}

.login-box .form-control-feedback-end .form-control,
.login-box .form-control-feedback-end input {
  padding-right: 48px;
}

.login-box .mb-2 {
  margin-bottom: 16px !important;
}

.login-box .mb-3 {
  margin-bottom: 20px !important;
}

.login-box .forgot-password-link {
  color: var(--g600);
}

.login-box .forgot-password-link:hover {
  color: var(--g800);
}

/* Validation error label styling placed after the input wrapper */
.login-box label.error {
  color: var(--red);
  margin-top: 8px;
  display: block;
  font-size: 0.9rem;
}

/* Bumping card defaults for dashboard/content pages */
.opsus360-theme .card {
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 12px 30px rgba(15,23,42,.06);
}

.opsus360-theme .content {
  padding: 24px;
}

.opsus360-theme .content-wrapper {
  padding-top: 24px;
}

.opsus360-theme .page-content {
  background: transparent;
}
.login-page-content {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
}

body.opsus360-theme.login-page > .navbar,
body.opsus360-theme.login-page > .navbar-footer {
  min-height: auto;
  padding-top: 0.4rem !important;
  padding-bottom: 0.4rem !important;
}
html,
body {
  height: 100%;
}

body.opsus360-theme {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

body.opsus360-theme:has(.page-content) {
  overflow: hidden;
}

body.opsus360-theme > .navbar {
  position: sticky;
  top: 0;
  z-index: 1000;
  min-height: 88px;
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

body.opsus360-theme > .navbar-footer {
  position: sticky;
  bottom: 0;
  z-index: 1000;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

body.opsus360-theme .page-content {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
}

body.opsus360-theme .content-wrapper {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1 1 auto;
  overflow: hidden;                     
  height: 100%;                
}

body.opsus360-theme .content-inner {
  flex: 1 1 auto;
  min-height: 0;
  height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(45,134,83,0.5) transparent;
}

body.opsus360-theme .content-inner::-webkit-scrollbar {
  width: 5px;
}

body.opsus360-theme .content-inner::-webkit-scrollbar-track {
  background: transparent;
}

body.opsus360-theme .content-inner::-webkit-scrollbar-thumb {
  background: rgba(45,134,83,0.5);
  border-radius: 999px;
}

.opsus360-theme .page-header,
.opsus360-theme .page-title {
  color: var(--g900);
  padding: 0 !important;
  margin-bottom: 2px !important;
}

.opsus360-theme .sidebar .nav-btn.active,
.opsus360-theme .sidebar .nav-btn:hover {
  color: var(--green);
}

.theme-bg {
  background-color: var(--green-l);
}

.theme-color {
  color: var(--green);
}

.btn { 
  display: inline-flex; 
  align-items: center; 
  gap: 6px; 
  padding: 8px 18px; 
  border-radius: 8px; 
  font-size: 13.5px; 
  font-weight: 600; 
  cursor: pointer; 
  font-family: var(--font); 
  border: none; 
  transition: opacity .15s; 
}

.field {
  margin-bottom: 14px;
}

.field label {
  display: block;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--g600);
  margin-bottom: 4px;
}

.field label .req {
  color: var(--red);
}

.field input,
.field select,
.field textarea {
  width: 100%;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid var(--g300);
  font-size: 13.5px;
  font-family: var(--font);
  color: var(--g800);
  background: var(--white);
  outline: none;
  transition: border-color .15s;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: var(--green);
}

.field input[readonly] {
  background: var(--g50);
}

.field textarea {
  resize: vertical;
}

.field-row {
  display: grid;
  gap: 12px;
}

.field-row.cols-2 {
  grid-template-columns: 1fr 1fr;
}

.field-row.span-2 {
  grid-column: 1 / -1;
}

@media (max-width: 768px) {
  .login-box {
    padding: 28px;
  }
}

/* ── NEW PREMIUM DASHBOARD LAYOUT & COMPONENTS ── */
#app { display: flex; height: 100vh; width: 100vw; overflow: hidden; }
#sidebar { width: var(--sidebar-w, 230px); background: var(--surface, #ffffff); border-right: 1px solid var(--g200); display: flex; flex-direction: column; flex-shrink: 0; transition: background .2s; height: 100vh; }
#sidebar.admin { background: var(--g800); border-right-color: var(--g700); }
#main { flex: 1; display: flex; flex-direction: column; overflow: hidden; height: 100vh; }
#topbar { height: 58px; background: var(--surface, #ffffff); border-bottom: 1px solid var(--g200); display: flex; align-items: center; padding: 0 22px; gap: 14px; flex-shrink: 0; position: relative; }
#content { flex: 1; overflow-y: auto; padding: 26px; background: var(--g50); }

/* ── SIDEBAR BRAND ── */
.brand { padding: 18px 16px; border-bottom: 1px solid var(--g200); display: flex; align-items: center; gap: 9px; }
.admin .brand { border-bottom-color: var(--g700); }
.brand-icon { width: 30px; height: 30px; background: var(--green); border-radius: 7px; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; color: #fff; }
.brand-text { font-size: 15px; font-weight: 800; color: var(--g800); line-height: 1; }
.admin .brand-text { color: var(--white, #ffffff); }
.brand-text span { color: var(--green); }
.brand-sub { font-size: 10px; color: var(--g400); }
.admin-badge { margin-left: 4px; background: rgba(239,68,68,.15); color: #f87171; padding: 1px 7px; border-radius: 10px; font-size: 10px; font-weight: 700; }

/* ── NAV ── */
#nav-links { flex: 1; padding: 10px 8px; overflow-y: auto; }
.nav-btn { width: 100%; display: flex; align-items: center; justify-content: space-between; padding: 9px 12px; border-radius: 8px; border: none; margin-bottom: 2px; background: transparent; color: var(--g600); font-weight: 500; font-size: 13.5px; cursor: pointer; font-family: var(--font); text-align: left; transition: background .12s, color .12s; text-decoration: none; }
.nav-btn:hover { background: var(--g50); color: var(--green); }
.admin .nav-btn { color: #9ca3af; }
.admin .nav-btn:hover { background: var(--g700); color: var(--white); }
.nav-btn.active { background: var(--green-l); color: var(--green); font-weight: 700; }
.admin .nav-btn.active { background: var(--green); color: var(--white); }
.nav-icon { font-size: 15px; margin-right: 9px; }
.nav-badge { background: var(--red); color: var(--white); font-size: 10px; font-weight: 800; padding: 1px 7px; border-radius: 10px; }
.sidebar-footer { padding: 10px 8px; border-top: 1px solid var(--g200); }
.admin .sidebar-footer { border-top-color: var(--g700); }
.switch-btn { width: 100%; display: flex; align-items: center; gap: 9px; padding: 9px 12px; border-radius: 8px; border: none; background: var(--green-l); color: var(--green); font-weight: 700; font-size: 13px; cursor: pointer; font-family: var(--font); text-align: left; margin-top: 4px; }
.admin .switch-btn { background: var(--g700); color: var(--white); }

/* ── TOPBAR ── */
.co-switcher { display: flex; align-items: center; gap: 8px; padding: 6px 14px; border-radius: 8px; border: 1px solid var(--g200); background: var(--white, #ffffff); cursor: pointer; font-family: var(--font); font-weight: 600; font-size: 13.5px; color: var(--g800); position: relative; }
.co-dot { width: 20px; height: 20px; background: var(--green); border-radius: 5px; display: flex; align-items: center; justify-content: center; font-size: 11px; color: var(--white, #ffffff); font-weight: 800; flex-shrink: 0; }
.topbar-spacer { flex: 1; }
.profile-btn { display: flex; align-items: center; gap: 8px; padding: 5px 10px; border: none; background: transparent; cursor: pointer; font-family: var(--font); }
.avatar { width: 34px; height: 34px; background: var(--green); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--white, #ffffff); font-weight: 800; font-size: 13px; flex-shrink: 0; }
.profile-name { font-size: 13px; font-weight: 700; color: var(--g800); text-align: left; }
.profile-role { font-size: 11px; color: var(--g400); }

/* ── DROPDOWN ── */
.dropdown { position: absolute; top: calc(100% + 6px); background: var(--white, #ffffff); border: 1px solid var(--g200); border-radius: 12px; box-shadow: 0 8px 24px rgba(0,0,0,.12); z-index: 500; min-width: 240px; padding: 8px; }
.dropdown.hidden { display: none !important; }
.dd-item { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 8px 10px; border: none; background: transparent; border-radius: 8px; cursor: pointer; font-family: var(--font); font-size: 13px; font-weight: 600; color: var(--g800); text-align: left; margin-bottom: 2px; text-decoration: none; }
.dd-item:hover, .dd-item.active { background: var(--green-l); color: var(--green); }
.dd-item.danger { color: var(--red); }
.dd-item.danger:hover { background: var(--red-l); }
.dd-sep { height: 1px; background: var(--g100); margin: 6px 0; }
.dd-header { padding: 10px 12px; border-bottom: 1px solid var(--g100); margin-bottom: 6px; }

/* ── PAGE HEADER ── */
.page-header { margin-bottom: 22px; }
.page-title { font-size: 21px; font-weight: 800; color: var(--g800); }
.page-sub { font-size: 12.5px; color: var(--g400); margin-top: 2px; }

/* ── ADDITIONAL COMPONENT STYLES FOR THE DASHBOARD REDESIGN ── */
.stat-grid { display: flex; gap: 14px; margin-bottom: 20px; flex-wrap: wrap; }
.stat-card { flex: 1; min-width: 180px; background: var(--white, #ffffff); border-radius: 12px; border: 1px solid var(--g200); box-shadow: 0 1px 4px rgba(0,0,0,.05); padding: 18px; }
.stat-label { font-size: 11px; color: var(--g500); font-weight: 700; text-transform: uppercase; letter-spacing: .4px; margin-bottom: 8px; display: flex; justify-content: space-between; align-items: center; }
.stat-value { font-size: 26px; font-weight: 800; color: var(--g800); line-height: 1; }
.stat-sub { font-size: 11px; color: var(--g400); margin-top: 3px; }
.stat-bar { height: 3px; background: var(--g100); border-radius: 2px; margin-top: 12px; overflow: hidden; }
.stat-fill { height: 3px; border-radius: 2px; width: 55%; }

/* Compliance Banner */
.compliance-banner { border-radius: 12px; padding: 16px 20px; margin-bottom: 20px; display: flex; align-items: center; gap: 14px; }
.compliance-banner.green { background: var(--green-l); border: 1px solid rgba(45,134,83,.2); }
.compliance-banner.amber { background: var(--amber-l); border: 1px solid rgba(245,158,11,.2); }
.compliance-banner.red { background: var(--red-l); border: 1px solid rgba(239,68,68,.2); }
.cb-icon { width: 44px; height: 44px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.cb-title { font-weight: 700; font-size: 15px; }
.cb-sub { font-size: 12.5px; color: var(--g600); margin-top: 2px; }

/* Dashboard layout grid */
.dash-grid { display: grid; grid-template-columns: 1fr 300px; gap: 18px; }
@media (max-width: 991px) { .dash-grid { grid-template-columns: 1fr; } }
.inner-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
@media (max-width: 768px) { .inner-grid { grid-template-columns: 1fr; } }

.task-row { padding: 0; display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.task-title { font-size: 13.5px; font-weight: 600; color: var(--g800); margin-bottom: 2px; }
.task-meta { font-size: 11px; font-weight: 700; }
.task-meta.client { color: var(--amber-d); }
.task-meta.staff { color: var(--blue-d); }

/* Badges */
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 20px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.badge.green { background: var(--green-l); color: var(--green-d); }
.badge.amber { background: var(--amber-l); color: var(--amber-d); }
.badge.red { background: var(--red-l); color: var(--red-d); }
.badge.blue { background: var(--blue-l); color: var(--blue-d); }
.badge.purple { background: var(--purple-l); color: var(--purple); }
.badge.gray { background: var(--g100); color: var(--g600); }
.badge-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* Tables */
.tbl-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 13px; }
thead tr { background: var(--g50); }
th { padding: 9px 14px; text-align: left; color: var(--g500); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: .4px; border-bottom: 1px solid var(--g200); white-space: nowrap; }
td { padding: 11px 14px; border-bottom: 1px solid var(--g100); color: var(--g600); }
td.bold { color: var(--g800); font-weight: 600; }
tbody tr:hover { background: var(--g50); }
.empty-row { text-align: center; padding: 32px; color: var(--g400); }

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 18px; border-radius: 8px; font-size: 13.5px; font-weight: 600; cursor: pointer; font-family: var(--font); border: none; transition: opacity .15s; text-decoration: none; }
.btn:hover { opacity: .82; }
.btn.sm { padding: 5px 12px; font-size: 11.5px; }
.btn.full { width: 100%; justify-content: center; }
.btn.primary { background: var(--green); color: #fff; }
.btn.secondary { background: #fff; color: var(--g700); border: 1px solid var(--g200); }
.btn.ghost { background: transparent; color: var(--green); border: 1px solid var(--green); }

/* Gauge SVG alignment */
.gauge-wrap { text-align: center; cursor: pointer; display: flex; flex-direction: column; align-items: center; justify-content: center; }

.card {
    background: var(--white);
    border-radius: 12px;
    border: 1px solid var(--g200);
    box-shadow: 0 1px 4px rgba(0, 0, 0, .05);
    padding: 20px;
    transition: box-shadow .15s;
}

.form-control {
    background-color: #ffffff !important;
    color: #1f2937 !important;
    border: 1px solid #d1d5db !important;
    border-radius: 6px;
    height: 38px;
}

.btn-primary {
    background-color: #2d8653 !important;
    border-color: #2d8653 !important;
    color: #fff !important;
}

@media (min-width: 768px) {
    .custom-scrollbars * {
        -ms-overflow-style: -ms-autohiding-scrollbar !important;
        scrollbar-width: none !important;
        scrollbar-color: #d1d5db #ffffff00 !important;
    }
}

.form-check-input:checked {
    background-color: #2d8653   !important;
    border-color: var(--form-check-input-checked-border-color) !important;
}

.form-check-input[data-color-theme=dark], [data-color-theme=dark] .form-check-input:not([data-color-theme]), html[data-color-theme=dark] .form-check-input {
    color-scheme: dark;
    --form-check-input-bg: #ffffff !important;
}

.alert-warning[data-color-theme=dark], [data-color-theme=dark] .alert-warning:not([data-color-theme]), html[data-color-theme=dark] .alert-warning {
    color-scheme: dark;
    --alert-color: #d11919;
    --alert-bg: rgba(100, 73, 58, 0.25);
    /* --alert-border-color: #956d56; */
    --alert-link-color: #caafa0;
    --alert-link-hover-color: #0c83ff;
}

.btn-outline-primary {
    --btn-color: #2d8653 !important;
    --btn-border-color: #2d8653 !important;
    --btn-hover-color: #fff;
    --btn-hover-bg: #2d8653 !important;
    --btn-hover-border-color: #2d8653 !important;
    --btn-focus-shadow-rgb: 12, 131, 255;
    --btn-active-color: #fff;
    --btn-active-bg: #2d8653 !important;
    --btn-active-border-color: #2d8653 !important;
    --btn-active-shadow: inset 0 0 0 0 transparent;
    --btn-disabled-color: #2d8653 !important;
    --btn-disabled-bg: transparent;
    --gradient: none;
}

.alert-success[data-color-theme=dark], [data-color-theme=dark] .alert-success:not([data-color-theme]), html[data-color-theme=dark] .alert-success {
    color-scheme: dark;
    --alert-color: #2d8653 !important;
    --alert-bg: var(--green-l) !important;
    --alert-border-color: #3f7363 !important;
    --alert-link-color: #90b3a8;
    --alert-link-hover-color: #7e9d93;
}

.mt-auto {
    margin-top: auto !important;
}

/* Focused but not selected cell */
.datepicker-cell.focused:not(.selected) {
    background-color: #2d8653;
    color: var(--dp-item-hover-color);
}

/* Datepicker control buttons */
.datepicker-controls .btn,
.datepicker-controls .btn:focus,
.datepicker-controls .btn:hover {
    --btn-color: #2d8653;
    --btn-hover-color: #2d8653;
    --btn-bg: transparent;
}

/* Hover effect for enabled cells */
.datepicker-cell:not(.disabled):hover {
    background-color: #2d8653;
    color: var(--dp-item-hover-color);
    cursor: pointer;
}

/* Selected cell */
.datepicker-cell.selected,
.datepicker-cell.selected:hover {
    background-color: #2d8653;
    color: var(--dp-item-active-color);
}

/* Range start and end (if not selected) */
.datepicker-cell.range-start:not(.selected),
.datepicker-cell.range-end:not(.selected) {
    background-color: #2d8653;
    color: var(--dp-item-active-color);
}

/* Cells within the selected range */
.datepicker-cell.range {
    border-radius: 0;
    background-color: #4b5563;
    color: var(--dp-item-hover-color);
}

.form-select {
    --form-select-bg: var(--white) !important;
    --form-select-bg-position: right 0.875rem center;
    --form-select-bg-size: 16px 12px;
    --form-select-color: #050505 !important;
}

/* ── Page header ── */
.billing-page-header { margin-bottom: 4px; }
.billing-title {
    font-size: 22px;
    font-weight: 800;
    color: var(--g800, #1f2937);
    margin-bottom: 2px;
}
.billing-subtitle {
    font-size: 12.5px;
    color: var(--g400, #9ca3af);
    margin-bottom: 0;
}

.custom-select-sm { 
    --form-select-padding-y: 5px;
    --form-select-padding-x: 10px;
    --form-select-font-size: 11.5px;
    background-color: #2d8653 !important;
}

html[data-color-theme="dark"] .fc .fc-daygrid-day.fc-day-today {
    background-color: #2d8653 !important;
}

/* ── SWEETALERT2 GLOBAL THEME OVERRIDES ──────────────────────────────────────
   Forces all Swal popups to always render in the light opsus360 theme,
   regardless of the data-color-theme="dark" attribute on <html>.
   ──────────────────────────────────────────────────────────────────────────── */

/* Reset dark-mode variables and color-scheme at the container level.
   Covers all selector forms used by the base Swal dark-mode rules. */
.swal2-container,
.swal2-container[data-color-theme=dark],
[data-color-theme=dark] .swal2-container,
[data-color-theme=dark] .swal2-container:not([data-color-theme]),
html[data-color-theme=dark] .swal2-container {
    color-scheme: light !important;
    --swal-bg: #ffffff !important;
    --swal-progress-color: rgba(45, 134, 83, 0.25) !important;
    --swal-success-color: #2d8653 !important;
    --swal-info-color: #3b82f6 !important;
    --swal-warning-color: #f59e0b !important;
    --swal-error-color: #ef4444 !important;
}

/* Popup box */
.swal2-popup {
    color-scheme: light !important;
    background-color: #ffffff !important;
    border-radius: 18px !important;
    box-shadow: 0 20px 60px rgba(15, 23, 42, .14) !important;
    border: 1px solid #e5e7eb !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    color: #1f2937 !important;
}

/* Title */
.swal2-title {
    color: #111827 !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.1rem !important;
}

/* Body / html container */
.swal2-html-container,
.swal2-content {
    color: #4b5563 !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 0.93rem !important;
}

/* Confirm button — primary green */
.swal2-confirm {
    background-color: #2d8653 !important;
    border-color: #2d8653 !important;
    color: #ffffff !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    padding: 9px 22px !important;
    box-shadow: none !important;
}
.swal2-confirm:hover,
.swal2-confirm:focus {
    background-color: #1e6b3f !important;
    border-color: #1e6b3f !important;
    box-shadow: 0 0 0 3px rgba(45, 134, 83, .22) !important;
}

/* Cancel button — neutral */
.swal2-cancel {
    background-color: #ffffff !important;
    border: 1px solid #d1d5db !important;
    color: #374151 !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    padding: 9px 22px !important;
    box-shadow: none !important;
}
.swal2-cancel:hover,
.swal2-cancel:focus {
    background-color: #f3f4f6 !important;
    box-shadow: none !important;
}

/* Deny button — red */
.swal2-deny {
    background-color: #ef4444 !important;
    border-color: #ef4444 !important;
    color: #ffffff !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    padding: 9px 22px !important;
    box-shadow: none !important;
}
.swal2-deny:hover,
.swal2-deny:focus {
    background-color: #dc2626 !important;
    border-color: #dc2626 !important;
}

/* Loader spinner — green */
.swal2-loader {
    border-color: #2d8653 transparent #2d8653 transparent !important;
}

/* Success icon — green */
.swal2-icon.swal2-success,
.swal2-icon.swal2-success .swal2-success-ring {
    border-color: #2d8653 !important;
    color: #2d8653 !important;
}
.swal2-icon.swal2-success [class^="swal2-success-line"] {
    border-color: #2d8653 !important;
}
.swal2-icon.swal2-success::before,
.swal2-icon.swal2-success::after {
    background: #ffffff !important;
}

/* Warning icon — amber */
.swal2-icon.swal2-warning {
    border-color: #f59e0b !important;
    color: #f59e0b !important;
}

/* Error icon — red */
.swal2-icon.swal2-error {
    border-color: #ef4444 !important;
    color: #ef4444 !important;
}
.swal2-icon.swal2-error [class^="swal2-x-mark-line"] {
    background-color: #ef4444 !important;
}

/* Info icon — blue */
.swal2-icon.swal2-info {
    border-color: #3b82f6 !important;
    color: #3b82f6 !important;
}

/* Question icon — gray */
.swal2-icon.swal2-question {
    border-color: #9ca3af !important;
    color: #6b7280 !important;
}

/* Close button */
.swal2-close {
    color: #9ca3af !important;
    font-size: 1.5rem !important;
}
.swal2-close:hover {
    color: #374151 !important;
}

/* Input / textarea inside Swal (e.g. input prompt) */
.swal2-input,
.swal2-textarea,
.swal2-select {
    background-color: #ffffff !important;
    color: #1f2937 !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    box-shadow: none !important;
}
.swal2-input:focus,
.swal2-textarea:focus,
.swal2-select:focus {
    border-color: #2d8653 !important;
    box-shadow: 0 0 0 3px rgba(45, 134, 83, .14) !important;
}

/* Validation message */
.swal2-validation-message {
    background: #fee2e2 !important;
    color: #991b1b !important;
    border-radius: 6px !important;
}

/* Progress bar */
.swal2-timer-progress-bar {
    background: #2d8653 !important;
}

.form-text {
    color: var(--g400) !important;
}