/* =======================================================================
   OwnWebServers — Nexus Theme Override
   Replaces header, navigation, footer, and adds proper dark/light mode.
   All OWS classes are prefixed with .ows- to avoid Bootstrap conflicts.
   ======================================================================= */

/* ── 1. DESIGN TOKENS ─────────────────────────────────────────────────── */
:root {
  /* Brand palette */
  --ows-brand-50:   #eef4ff;
  --ows-brand-100:  #d9e6ff;
  --ows-brand-200:  #bcd3ff;
  --ows-brand-300:  #8eb6ff;
  --ows-brand-400:  #598dff;
  --ows-brand-500:  #3464f6;
  --ows-brand-600:  #1f47eb;
  --ows-brand-700:  #1836d8;
  --ows-brand-800:  #1a2faf;
  --ows-brand-900:  #1b2d8a;

  /* Accent */
  --ows-accent-300: #67e8f9;
  --ows-accent-400: #22d3ee;
  --ows-accent-500: #06b6d4;

  /* Ink (darkest navy) */
  --ows-ink:        #0a0e1a;
  --ows-ink-soft:   #0f1525;

  /* Slate */
  --ows-slate-50:   #f8fafc;
  --ows-slate-100:  #f1f5f9;
  --ows-slate-200:  #e2e8f0;
  --ows-slate-300:  #cbd5e1;
  --ows-slate-400:  #94a3b8;
  --ows-slate-500:  #64748b;
  --ows-slate-600:  #475569;
  --ows-slate-700:  #334155;
  --ows-slate-800:  #1e293b;
  --ows-slate-900:  #0f172a;
  --ows-white:      #ffffff;

  /* Radius */
  --ows-r-sm:  0.5rem;
  --ows-r:     0.75rem;
  --ows-r-lg:  1rem;
  --ows-r-xl:  1.5rem;

  /* Shadows */
  --ows-shadow-glow: 0 0 0 1px rgba(52,100,246,.15), 0 20px 60px -20px rgba(52,100,246,.45);
  --ows-shadow-card: 0 1px 2px rgba(16,24,40,.06), 0 12px 32px -12px rgba(16,24,40,.18);
  --ows-transition:  200ms cubic-bezier(.4,0,.2,1);

  /* LIGHT mode semantic tokens */
  --ows-bg-page:    var(--ows-white);
  --ows-bg-card:    var(--ows-white);
  --ows-bg-subtle:  var(--ows-slate-50);
  --ows-text-head:  var(--ows-slate-900);
  --ows-text-base:  var(--ows-slate-600);
  --ows-text-muted: var(--ows-slate-500);
  --ows-border:     rgba(15,23,42,.12);
  --ows-border-sub: rgba(15,23,42,.07);

  /* Header (light) */
  --ows-header-bg:           rgba(255,255,255,.92);
  --ows-header-border:       rgba(15,23,42,.10);
  --ows-header-scrolled-bg:  rgba(255,255,255,.97);
  --ows-header-scrolled-shd: 0 2px 20px rgba(15,23,42,.10);

  /* Nav (light) */
  --ows-nav-text:       var(--ows-slate-600);
  --ows-nav-text-hover: var(--ows-slate-900);
  --ows-nav-hover-bg:   rgba(15,23,42,.05);

  /* Dropdown (light) */
  --ows-dd-bg:         var(--ows-white);
  --ows-dd-border:     var(--ows-slate-200);
  --ows-dd-item-hover: rgba(15,23,42,.05);

  /* Mobile (light) */
  --ows-mob-bg:         var(--ows-white);
  --ows-mob-border:     rgba(15,23,42,.08);
  --ows-mob-item-hover: var(--ows-slate-100);

  /* Footer (light) */
  --ows-footer-bg:          rgba(248,250,252,.7);
  --ows-footer-border:      rgba(15,23,42,.10);
  --ows-footer-text:        var(--ows-slate-600);
  --ows-footer-head:        var(--ows-slate-900);
  --ows-footer-muted:       var(--ows-slate-500);
  --ows-footer-link:        var(--ows-slate-600);
  --ows-footer-link-hover:  var(--ows-brand-600);
  --ows-footer-social-bg:   var(--ows-white);
  --ows-footer-social-bdr:  var(--ows-slate-200);
  --ows-footer-social-text: var(--ows-slate-500);

  /* Logo */
  --ows-logo-text: var(--ows-slate-900);
  --ows-grad-from: var(--ows-brand-600);
  --ows-grad-via:  var(--ows-brand-500);
  --ows-grad-to:   var(--ows-accent-500);

  /* Toggle / Hamburger */
  --ows-toggle-bg:    rgba(255,255,255,.6);
  --ows-toggle-bdr:   var(--ows-slate-200);
  --ows-toggle-text:  var(--ows-slate-600);
  --ows-toggle-hover: var(--ows-brand-600);
  --ows-ham-bg:       rgba(255,255,255,.6);
  --ows-ham-bdr:      var(--ows-slate-200);
  --ows-ham-text:     var(--ows-slate-700);

  /* Topbar (account notifications) */
  --ows-topbar-bg:     var(--ows-slate-900);
  --ows-topbar-text:   var(--ows-slate-300);
  --ows-topbar-border: rgba(255,255,255,.08);
}

/* DARK mode tokens */
html.dark {
  color-scheme: dark;
  --ows-bg-page:    var(--ows-ink);
  --ows-bg-card:    var(--ows-ink-soft);
  --ows-bg-subtle:  rgba(255,255,255,.03);
  --ows-text-head:  var(--ows-white);
  --ows-text-base:  var(--ows-slate-300);
  --ows-text-muted: var(--ows-slate-400);
  --ows-border:     rgba(255,255,255,.10);
  --ows-border-sub: rgba(255,255,255,.06);

  --ows-header-bg:           rgba(10,14,26,.92);
  --ows-header-border:       rgba(255,255,255,.08);
  --ows-header-scrolled-bg:  rgba(10,14,26,.97);
  --ows-header-scrolled-shd: 0 2px 24px rgba(0,0,0,.4);

  --ows-nav-text:       var(--ows-slate-300);
  --ows-nav-text-hover: var(--ows-white);
  --ows-nav-hover-bg:   rgba(255,255,255,.06);

  --ows-dd-bg:         var(--ows-ink-soft);
  --ows-dd-border:     rgba(255,255,255,.10);
  --ows-dd-item-hover: rgba(255,255,255,.05);

  --ows-mob-bg:         var(--ows-ink);
  --ows-mob-border:     rgba(255,255,255,.08);
  --ows-mob-item-hover: rgba(255,255,255,.05);

  --ows-footer-bg:          var(--ows-ink-soft);
  --ows-footer-border:      rgba(255,255,255,.10);
  --ows-footer-text:        var(--ows-slate-400);
  --ows-footer-head:        var(--ows-white);
  --ows-footer-muted:       var(--ows-slate-400);
  --ows-footer-link:        var(--ows-slate-400);
  --ows-footer-link-hover:  var(--ows-brand-300);
  --ows-footer-social-bg:   rgba(255,255,255,.05);
  --ows-footer-social-bdr:  rgba(255,255,255,.10);
  --ows-footer-social-text: var(--ows-slate-400);

  --ows-logo-text: var(--ows-white);
  --ows-grad-from: var(--ows-brand-300);
  --ows-grad-via:  var(--ows-brand-400);
  --ows-grad-to:   var(--ows-accent-300);

  --ows-toggle-bg:    rgba(255,255,255,.05);
  --ows-toggle-bdr:   rgba(255,255,255,.10);
  --ows-toggle-text:  var(--ows-slate-300);
  --ows-toggle-hover: var(--ows-brand-300);
  --ows-ham-bg:       rgba(255,255,255,.05);
  --ows-ham-bdr:      rgba(255,255,255,.10);
  --ows-ham-text:     var(--ows-slate-200);

  --ows-topbar-bg:     rgba(10,14,26,.95);
  --ows-topbar-text:   var(--ows-slate-400);
  --ows-topbar-border: rgba(255,255,255,.05);

  /* ── Override Nexus theme semantic variables (custom.css) for dark mode ── */
  /* Without these, any element using var(--text), var(--bg-lifted), etc.
     stays in light-mode colours regardless of our html.dark toggle.         */
  --neutral-50:  #0a0e1a;
  --neutral-100: #0f1525;
  --neutral-200: #1e293b;
  --neutral-300: #2d3748;
  --neutral-400: #4a5568;
  --neutral-500: #718096;
  --neutral-600: #a0aec0;
  --neutral-700: #cbd5e0;
  --neutral-800: #e2e8f0;
  --neutral-900: #f7fafc;
  --neutral-950: #ffffff;

  --text:          #f1f5f9;
  --text-inverted: #0a0e1a;
  --text-muted:    #64748b;
  --text-lifted:   #94a3b8;
  --text-accented: #cbd5e1;

  --border-muted:   rgba(255,255,255,.06);
  --border:         rgba(255,255,255,.10);
  --border-lifted:  rgba(255,255,255,.18);
  --border-accented:rgba(255,255,255,.30);

  --bg:          #0a0e1a;
  --bg-muted:    #0a0e1a;
  --bg-lifted:   #0f1525;
  --bg-accented: #1e293b;
  --bg-inverted: #f1f5f9;

  --primary:          #3464f6;
  --primary-lifted:   #1f47eb;
  --primary-accented: #1836d8;
}

@media (prefers-color-scheme: dark) {
  html:not(.light) {
    color-scheme: dark;
    --ows-bg-page:    var(--ows-ink);
    --ows-bg-card:    var(--ows-ink-soft);
    --ows-bg-subtle:  rgba(255,255,255,.03);
    --ows-text-head:  var(--ows-white);
    --ows-text-base:  var(--ows-slate-300);
    --ows-text-muted: var(--ows-slate-400);
    --ows-border:     rgba(255,255,255,.10);
    --ows-border-sub: rgba(255,255,255,.06);

    --ows-header-bg:           rgba(10,14,26,.92);
    --ows-header-border:       rgba(255,255,255,.08);
    --ows-header-scrolled-bg:  rgba(10,14,26,.97);
    --ows-header-scrolled-shd: 0 2px 24px rgba(0,0,0,.4);

    --ows-nav-text:       var(--ows-slate-300);
    --ows-nav-text-hover: var(--ows-white);
    --ows-nav-hover-bg:   rgba(255,255,255,.06);

    --ows-dd-bg:         var(--ows-ink-soft);
    --ows-dd-border:     rgba(255,255,255,.10);
    --ows-dd-item-hover: rgba(255,255,255,.05);

    --ows-mob-bg:         var(--ows-ink);
    --ows-mob-border:     rgba(255,255,255,.08);
    --ows-mob-item-hover: rgba(255,255,255,.05);

    --ows-footer-bg:          var(--ows-ink-soft);
    --ows-footer-border:      rgba(255,255,255,.10);
    --ows-footer-text:        var(--ows-slate-400);
    --ows-footer-head:        var(--ows-white);
    --ows-footer-muted:       var(--ows-slate-400);
    --ows-footer-link:        var(--ows-slate-400);
    --ows-footer-link-hover:  var(--ows-brand-300);
    --ows-footer-social-bg:   rgba(255,255,255,.05);
    --ows-footer-social-bdr:  rgba(255,255,255,.10);
    --ows-footer-social-text: var(--ows-slate-400);

    --ows-logo-text: var(--ows-white);
    --ows-grad-from: var(--ows-brand-300);
    --ows-grad-via:  var(--ows-brand-400);
    --ows-grad-to:   var(--ows-accent-300);

    --ows-toggle-bg:    rgba(255,255,255,.05);
    --ows-toggle-bdr:   rgba(255,255,255,.10);
    --ows-toggle-text:  var(--ows-slate-300);
    --ows-toggle-hover: var(--ows-brand-300);
    --ows-ham-bg:       rgba(255,255,255,.05);
    --ows-ham-bdr:      rgba(255,255,255,.10);
    --ows-ham-text:     var(--ows-slate-200);

    --ows-topbar-bg:     rgba(10,14,26,.95);
    --ows-topbar-text:   var(--ows-slate-400);
    --ows-topbar-border: rgba(255,255,255,.05);

    /* Nexus theme semantic variable overrides (mirrors html.dark block above) */
    --neutral-50:  #0a0e1a;
    --neutral-100: #0f1525;
    --neutral-200: #1e293b;
    --neutral-300: #2d3748;
    --neutral-400: #4a5568;
    --neutral-500: #718096;
    --neutral-600: #a0aec0;
    --neutral-700: #cbd5e0;
    --neutral-800: #e2e8f0;
    --neutral-900: #f7fafc;
    --neutral-950: #ffffff;

    --text:          #f1f5f9;
    --text-inverted: #0a0e1a;
    --text-muted:    #64748b;
    --text-lifted:   #94a3b8;
    --text-accented: #cbd5e1;

    --border-muted:    rgba(255,255,255,.06);
    --border:          rgba(255,255,255,.10);
    --border-lifted:   rgba(255,255,255,.18);
    --border-accented: rgba(255,255,255,.30);

    --bg:          #0a0e1a;
    --bg-muted:    #0a0e1a;
    --bg-lifted:   #0f1525;
    --bg-accented: #1e293b;
    --bg-inverted: #f1f5f9;

    --primary:          #3464f6;
    --primary-lifted:   #1f47eb;
    --primary-accented: #1836d8;
  }
}

/* ── 2. PAGE-LEVEL DARK MODE ADAPTATION ──────────────────────────────── */
/* Override Nexus's permanent dark body with OWS adaptive tokens */
html, body {
  background-color: var(--ows-bg-page) !important;
}
html {
  font-size: 16px;
}

/* Main body section background */
section#main-body {
  background-color: var(--ows-bg-subtle) !important;
}

/* Page text color */
html.dark body, html.dark .primary-content {
  color: var(--ows-text-base);
}
@media (prefers-color-scheme: dark) {
  html:not(.light) body,
  html:not(.light) .primary-content { color: var(--ows-text-base); }
}

/* Dark mode — Bootstrap cards */
html.dark .card,
html.dark .panel { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; color: var(--ows-text-base); }
html.dark .card-header,
html.dark .panel-heading { background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; color: var(--ows-text-head); }
html.dark .card-body,
html.dark .panel-body { background-color: var(--ows-bg-card) !important; color: var(--ows-text-base); }
html.dark .card-footer,
html.dark .panel-footer { background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; }
@media (prefers-color-scheme: dark) {
  html:not(.light) .card,
  html:not(.light) .panel { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; color: var(--ows-text-base); }
  html:not(.light) .card-header,
  html:not(.light) .panel-heading { background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; color: var(--ows-text-head); }
  html:not(.light) .card-body,
  html:not(.light) .panel-body { background-color: var(--ows-bg-card) !important; color: var(--ows-text-base); }
  html:not(.light) .card-footer,
  html:not(.light) .panel-footer { background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; }
}

/* Dark mode — forms */
html.dark .form-control,
html.dark .custom-select,
html.dark .input-group-text {
  background-color: var(--ows-ink-soft) !important;
  border-color: var(--ows-border) !important;
  color: var(--ows-text-base) !important;
  color-scheme: dark;
}
html.dark .form-control::placeholder { color: var(--ows-text-muted); }
@media (prefers-color-scheme: dark) {
  html:not(.light) .form-control,
  html:not(.light) .custom-select,
  html:not(.light) .input-group-text {
    background-color: var(--ows-ink-soft) !important;
    border-color: var(--ows-border) !important;
    color: var(--ows-text-base) !important;
    color-scheme: dark;
  }
  html:not(.light) .form-control::placeholder { color: var(--ows-text-muted); }
}

/* Dark mode — text */
html.dark h1, html.dark h2, html.dark h3,
html.dark h4, html.dark h5, html.dark h6,
html.dark .h1, html.dark .h2, html.dark .h3,
html.dark .h4, html.dark .h5, html.dark .h6 { color: var(--ows-text-head); }
html.dark p, html.dark label, html.dark th, html.dark td, html.dark li { color: var(--ows-text-base); }
html.dark .text-muted { color: var(--ows-text-muted) !important; }
html.dark a { color: var(--ows-brand-400); }
html.dark a:hover { color: var(--ows-brand-300); }
@media (prefers-color-scheme: dark) {
  html:not(.light) h1, html:not(.light) h2, html:not(.light) h3,
  html:not(.light) h4, html:not(.light) h5, html:not(.light) h6 { color: var(--ows-text-head); }
  html:not(.light) p, html:not(.light) label, html:not(.light) th, html:not(.light) td, html:not(.light) li { color: var(--ows-text-base); }
  html:not(.light) .text-muted { color: var(--ows-text-muted) !important; }
  html:not(.light) a { color: var(--ows-brand-400); }
  html:not(.light) a:hover { color: var(--ows-brand-300); }
}

/* Dark mode — tables */
html.dark .table { color: var(--ows-text-base); border-color: var(--ows-border); }
html.dark .table thead th { border-color: var(--ows-border); color: var(--ows-text-head); background-color: var(--ows-ink-soft); }
html.dark .table td, html.dark .table th { border-color: var(--ows-border); }
html.dark .table-striped tbody tr:nth-of-type(odd) { background-color: rgba(255,255,255,.03); }
html.dark .table-hover tbody tr:hover { background-color: rgba(255,255,255,.05); }
@media (prefers-color-scheme: dark) {
  html:not(.light) .table { color: var(--ows-text-base); border-color: var(--ows-border); }
  html:not(.light) .table thead th { border-color: var(--ows-border); color: var(--ows-text-head); background-color: var(--ows-ink-soft); }
  html:not(.light) .table td, html:not(.light) .table th { border-color: var(--ows-border); }
  html:not(.light) .table-striped tbody tr:nth-of-type(odd) { background-color: rgba(255,255,255,.03); }
  html:not(.light) .table-hover tbody tr:hover { background-color: rgba(255,255,255,.05); }
}

/* Dark mode — list groups */
html.dark .list-group-item {
  background-color: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
  color: var(--ows-text-base);
}
html.dark .list-group-item:hover { background-color: rgba(255,255,255,.05) !important; }
html.dark .list-group-item.active {
  background-color: var(--ows-brand-600) !important;
  border-color: var(--ows-brand-700) !important;
  color: var(--ows-white) !important;
}
@media (prefers-color-scheme: dark) {
  html:not(.light) .list-group-item { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; color: var(--ows-text-base); }
  html:not(.light) .list-group-item.active { background-color: var(--ows-brand-600) !important; border-color: var(--ows-brand-700) !important; color: var(--ows-white) !important; }
}

/* Dark mode — alerts */
html.dark .alert { border-color: var(--ows-border); }
html.dark .alert-info { background-color: rgba(31,71,235,.1); border-color: rgba(31,71,235,.25); color: var(--ows-brand-300); }
html.dark .alert-success { background-color: rgba(22,163,74,.1); border-color: rgba(22,163,74,.25); color: #4ade80; }
html.dark .alert-warning { background-color: rgba(234,179,8,.1); border-color: rgba(234,179,8,.25); color: #fbbf24; }
html.dark .alert-danger { background-color: rgba(220,38,38,.1); border-color: rgba(220,38,38,.25); color: #f87171; }
@media (prefers-color-scheme: dark) {
  html:not(.light) .alert-info { background-color: rgba(31,71,235,.1); border-color: rgba(31,71,235,.25); color: var(--ows-brand-300); }
  html:not(.light) .alert-success { background-color: rgba(22,163,74,.1); border-color: rgba(22,163,74,.25); color: #4ade80; }
  html:not(.light) .alert-warning { background-color: rgba(234,179,8,.1); border-color: rgba(234,179,8,.25); color: #fbbf24; }
  html:not(.light) .alert-danger { background-color: rgba(220,38,38,.1); border-color: rgba(220,38,38,.25); color: #f87171; }
}

/* Dark mode — dropdowns */
html.dark .dropdown-menu {
  background-color: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
}
html.dark .dropdown-item { color: var(--ows-text-base); }
html.dark .dropdown-item:hover { background-color: rgba(255,255,255,.06) !important; color: var(--ows-text-head); }
html.dark .dropdown-divider { border-color: var(--ows-border); }
html.dark .dropdown-header { color: var(--ows-text-muted); }
@media (prefers-color-scheme: dark) {
  html:not(.light) .dropdown-menu { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
  html:not(.light) .dropdown-item { color: var(--ows-text-base); }
  html:not(.light) .dropdown-item:hover { background-color: rgba(255,255,255,.06) !important; color: var(--ows-text-head); }
}

/* Dark mode — modals */
html.dark .modal-content {
  background-color: var(--ows-bg-card);
  border-color: var(--ows-border);
  color: var(--ows-text-base);
}
html.dark .modal-header {
  background-color: var(--ows-ink-soft);
  border-color: var(--ows-border);
}
html.dark .modal-footer { border-color: var(--ows-border); }
html.dark .modal-header .close { color: var(--ows-text-head); }
@media (prefers-color-scheme: dark) {
  html:not(.light) .modal-content { background-color: var(--ows-bg-card); border-color: var(--ows-border); color: var(--ows-text-base); }
  html:not(.light) .modal-header { background-color: var(--ows-ink-soft); border-color: var(--ows-border); }
  html:not(.light) .modal-footer { border-color: var(--ows-border); }
}

/* Dark mode — sidebar */
html.dark .sidebar .panel { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
html.dark .sidebar .panel-heading { color: var(--ows-text-head) !important; background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; }
html.dark .sidebar .panel-body { background-color: var(--ows-bg-card) !important; }
html.dark .sidebar .list-group-item { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; color: var(--ows-text-base) !important; }
html.dark .card-sidebar { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
@media (prefers-color-scheme: dark) {
  html:not(.light) .sidebar .panel { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
  html:not(.light) .sidebar .panel-heading { color: var(--ows-text-head) !important; background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; }
  html:not(.light) .sidebar .panel-body { background-color: var(--ows-bg-card) !important; }
  html:not(.light) .sidebar .list-group-item { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; color: var(--ows-text-base) !important; }
}

/* Dark mode — breadcrumb */
html.dark .master-breadcrumb { background-color: var(--ows-ink-soft); border-bottom: 1px solid var(--ows-border); }
html.dark .breadcrumb { background-color: transparent; }
html.dark .breadcrumb-item, html.dark .breadcrumb-item a { color: var(--ows-text-base); }
html.dark .breadcrumb-item.active { color: var(--ows-text-muted); }
html.dark .breadcrumb-item + .breadcrumb-item::before { color: var(--ows-text-muted); }
@media (prefers-color-scheme: dark) {
  html:not(.light) .master-breadcrumb { background-color: var(--ows-ink-soft); border-bottom: 1px solid var(--ows-border); }
  html:not(.light) .breadcrumb { background-color: transparent; }
  html:not(.light) .breadcrumb-item, html:not(.light) .breadcrumb-item a { color: var(--ows-text-base); }
  html:not(.light) .breadcrumb-item.active { color: var(--ows-text-muted); }
}

/* Dark mode — buttons */
html.dark .btn-default { background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; color: var(--ows-text-base) !important; }
html.dark .btn-default:hover { background-color: rgba(255,255,255,.08) !important; color: var(--ows-text-head) !important; }
html.dark .btn-primary { background: linear-gradient(135deg, var(--ows-brand-600), var(--ows-brand-500)) !important; border-color: transparent !important; color: var(--ows-white) !important; }
html.dark .btn-primary:hover { background: linear-gradient(135deg, var(--ows-brand-700), var(--ows-brand-600)) !important; }
html.dark .btn-link { color: var(--ows-brand-400); }
html.dark .btn-link:hover { color: var(--ows-brand-300); }
html.dark select, html.dark select.form-control {
  color-scheme: dark;
  background-color: var(--ows-ink-soft) !important;
  border-color: var(--ows-border) !important;
  color: var(--ows-text-base) !important;
}
@media (prefers-color-scheme: dark) {
  html:not(.light) .btn-default { background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; color: var(--ows-text-base) !important; }
  html:not(.light) .btn-primary { background: linear-gradient(135deg, var(--ows-brand-600), var(--ows-brand-500)) !important; border-color: transparent !important; color: var(--ows-white) !important; }
  html:not(.light) select, html:not(.light) select.form-control { color-scheme: dark; background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; color: var(--ows-text-base) !important; }
}

/* Dark mode — topbar (logged-in notifications bar) */
html.dark .ows-topbar { background-color: var(--ows-topbar-bg); border-color: var(--ows-topbar-border); }
html.dark .ows-topbar, html.dark .ows-topbar a, html.dark .ows-topbar span { color: var(--ows-topbar-text); }
html.dark .ows-topbar .btn { color: var(--ows-slate-300); border-color: var(--ows-border); }
html.dark .ows-topbar .btn:hover { color: var(--ows-white); }
html.dark .ows-topbar .input-group-text { background-color: var(--ows-ink-soft); border-color: var(--ows-border); color: var(--ows-text-muted); }
html.dark .ows-topbar .btn-active-client { background-color: var(--ows-brand-600); color: var(--ows-white); }
@media (prefers-color-scheme: dark) {
  html:not(.light) .ows-topbar { background-color: var(--ows-topbar-bg); border-color: var(--ows-topbar-border); }
  html:not(.light) .ows-topbar .btn { color: var(--ows-slate-300); border-color: var(--ows-border); }
  html:not(.light) .ows-topbar .btn-active-client { background-color: var(--ows-brand-600); color: var(--ows-white); }
}

/* ── 3. OWS TOPBAR (logged-in notifications) ──────────────────────────── */
.ows-topbar {
  background-color: var(--ows-slate-900);
  border-bottom: 1px solid rgba(255,255,255,.08);
  font-size: 0.8125rem;
}
.ows-topbar .container {
  display: flex;
  align-items: center;
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
}
.ows-topbar .btn {
  font-size: 0.8125rem;
  padding: 0.25rem 0.75rem;
  color: var(--ows-slate-300);
  border-radius: var(--ows-r-sm);
}
.ows-topbar .btn:hover { color: var(--ows-white); }
.ows-topbar .input-group-text {
  font-size: 0.8125rem;
  background-color: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.08);
  color: var(--ows-slate-400);
}
.ows-topbar .btn-active-client {
  background-color: var(--ows-brand-600);
  color: var(--ows-white);
  border-color: transparent;
}
.ows-topbar .btn-active-client:hover { background-color: var(--ows-brand-700); }
.ows-topbar .active-client { border-color: rgba(255,255,255,.12); }
.ows-topbar .input-group { border-color: rgba(255,255,255,.12); }
.ows-topbar a { color: var(--ows-slate-300); text-decoration: none; }
.ows-topbar a:hover { color: var(--ows-white); text-decoration: none; }
.ows-topbar .btn-return-to-admin { color: #fbbf24; border-color: rgba(251,191,36,.3); }
.ows-topbar .badge { background-color: var(--ows-brand-600) !important; color: var(--ows-white); }

/* popover for notifications */
#accountNotificationsContent { display: none; }

/* ── 4. OWS HEADER ────────────────────────────────────────────────────── */

/* Apply Inter font across all OWS structural elements */
.ows-header,
.ows-mobile-menu,
.ows-footer {
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
}

.ows-header {
  position: sticky;
  top: 0;
  /* 1031 = above Bootstrap navbar (1030) but below modal-backdrop (1040) */
  z-index: 1031;
  width: 100%;
  background: var(--ows-header-bg);
  border-bottom: 1px solid var(--ows-header-border);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  transition: background var(--ows-transition), box-shadow var(--ows-transition);
}
.ows-header.scrolled {
  background: var(--ows-header-scrolled-bg);
  box-shadow: var(--ows-header-scrolled-shd);
}

.ows-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  height: 4rem;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1.25rem;
}
@media (min-width: 1024px) {
  .ows-header-inner { height: 4.5rem; padding: 0 2rem; }
}

/* ── Logo ── */
.ows-logo {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  text-decoration: none;
  flex-shrink: 0;
  border-radius: var(--ows-r-sm);
  outline-offset: 2px;
}
.ows-logo:hover { text-decoration: none; }
.ows-logo:focus-visible { outline: 2px solid var(--ows-brand-500); }
.ows-logo-icon {
  position: relative;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 0.75rem;
  background: linear-gradient(135deg, var(--ows-brand-600), var(--ows-accent-500));
  display: grid;
  place-items: center;
  flex-shrink: 0;
  box-shadow: var(--ows-shadow-glow);
}
.ows-logo-icon svg { width: 1.25rem; height: 1.25rem; color: var(--ows-white); }
.ows-logo-text {
  font-size: 1.125rem;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--ows-logo-text);
  line-height: 1;
}
.ows-logo-text .ows-gradient-text {
  background: linear-gradient(90deg, var(--ows-grad-from), var(--ows-grad-via), var(--ows-grad-to));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Desktop Nav ── */
.ows-nav {
  display: none;
  align-items: center;
  gap: 0.25rem;
  flex: 1;
  justify-content: center;
}
@media (min-width: 1024px) { .ows-nav { display: flex; } }

.ows-nav-group { position: relative; }

.ows-nav-btn {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.5rem 0.75rem;
  border: none;
  background: none;
  font-size: 0.875rem;
  font-weight: 500;
  font-family: inherit;
  color: var(--ows-nav-text);
  border-radius: var(--ows-r-sm);
  transition: color var(--ows-transition), background var(--ows-transition);
  white-space: nowrap;
  cursor: pointer;
  line-height: 1;
}
.ows-nav-btn:hover { color: var(--ows-nav-text-hover); background: var(--ows-nav-hover-bg); }
.ows-nav-btn:focus-visible { outline: 2px solid var(--ows-brand-500); outline-offset: 2px; }
.ows-nav-btn svg { width: 0.875rem; height: 0.875rem; transition: transform var(--ows-transition); }
.ows-nav-group.open .ows-nav-btn { color: var(--ows-nav-text-hover); }
.ows-nav-group.open .ows-nav-btn svg { transform: rotate(180deg); }

.ows-dropdown {
  position: absolute;
  top: calc(100% + 0.75rem);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  width: 20rem;
  background: var(--ows-dd-bg);
  border: 1px solid var(--ows-dd-border);
  border-radius: var(--ows-r-xl);
  padding: 0.5rem;
  box-shadow: var(--ows-shadow-glow);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--ows-transition), transform var(--ows-transition), visibility 0s var(--ows-transition);
  z-index: 400;
}
.ows-nav-group.open .ows-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  transition: opacity var(--ows-transition), transform var(--ows-transition), visibility 0s;
}
.ows-dropdown a {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.625rem 0.75rem;
  border-radius: var(--ows-r-lg);
  text-decoration: none !important;
  transition: background var(--ows-transition);
  color: inherit;
}
.ows-dropdown a:hover { background: var(--ows-dd-item-hover); text-decoration: none !important; }
.ows-dropdown-label {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--ows-text-head);
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.ows-dropdown-desc {
  font-size: 0.75rem;
  color: var(--ows-text-muted);
  margin-top: 0.125rem;
  display: block;
  font-weight: 400;
}
.ows-dropdown-from {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--ows-brand-600);
  white-space: nowrap;
  flex-shrink: 0;
  margin-top: 0.125rem;
}
html.dark .ows-dropdown-from { color: var(--ows-brand-300); }
@media (prefers-color-scheme: dark) { html:not(.light) .ows-dropdown-from { color: var(--ows-brand-300); } }

/* ── Header Right Actions ── */
.ows-header-actions {
  display: none;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
@media (min-width: 1024px) { .ows-header-actions { display: flex; } }

/* Cart button in header */
.ows-cart-btn {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--ows-toggle-bdr);
  border-radius: var(--ows-r-sm);
  background: var(--ows-toggle-bg);
  color: var(--ows-nav-text);
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  transition: all var(--ows-transition);
  position: relative;
}
.ows-cart-btn:hover { color: var(--ows-nav-text-hover); border-color: var(--ows-brand-400); text-decoration: none; }
.ows-cart-btn:focus-visible { outline: 2px solid var(--ows-brand-500); outline-offset: 2px; }
.ows-cart-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  font-size: 0.6875rem;
  font-weight: 700;
  background: var(--ows-brand-600);
  color: var(--ows-white);
  border-radius: 9999px;
  padding: 0 0.25rem;
}

/* Theme toggle button */
.ows-theme-btn {
  display: grid;
  place-items: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--ows-toggle-bdr);
  border-radius: var(--ows-r-lg);
  background: var(--ows-toggle-bg);
  color: var(--ows-toggle-text);
  transition: all var(--ows-transition);
  flex-shrink: 0;
  cursor: pointer;
}
.ows-theme-btn:hover { color: var(--ows-toggle-hover); }
.ows-theme-btn:focus-visible { outline: 2px solid var(--ows-brand-500); outline-offset: 2px; }
.ows-theme-btn svg { width: 1.125rem; height: 1.125rem; }

/* Hamburger */
.ows-hamburger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--ows-ham-bdr);
  border-radius: var(--ows-r-lg);
  background: var(--ows-ham-bg);
  color: var(--ows-ham-text);
  transition: all var(--ows-transition);
  cursor: pointer;
}
.ows-hamburger:hover { opacity: .8; }
.ows-hamburger:focus-visible { outline: 2px solid var(--ows-brand-500); outline-offset: 2px; }
.ows-hamburger svg { width: 1.25rem; height: 1.25rem; }
@media (min-width: 1024px) { .ows-hamburger { display: none; } }

/* Mobile controls row */
.ows-mobile-controls {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
@media (min-width: 1024px) { .ows-mobile-controls { display: none; } }

/* OWS header buttons */
.ows-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  border-radius: var(--ows-r-sm);
  font-size: 0.875rem;
  font-weight: 600;
  font-family: inherit;
  padding: 0.5rem 1rem;
  border: 1px solid transparent;
  text-decoration: none;
  transition: all var(--ows-transition);
  cursor: pointer;
  white-space: nowrap;
  line-height: 1.4;
}
.ows-btn:hover { text-decoration: none; }
.ows-btn:focus-visible { outline: 2px solid var(--ows-brand-500); outline-offset: 2px; }

.ows-btn-ghost { color: var(--ows-nav-text); background: transparent; border-color: transparent; }
.ows-btn-ghost:hover { color: var(--ows-nav-text-hover); background: var(--ows-nav-hover-bg); }

.ows-btn-outline {
  color: var(--ows-text-base);
  background: transparent;
  border-color: var(--ows-toggle-bdr);
}
.ows-btn-outline:hover { border-color: var(--ows-brand-400); color: var(--ows-brand-600); }
html.dark .ows-btn-outline:hover { color: var(--ows-brand-300); }
@media (prefers-color-scheme: dark) { html:not(.light) .ows-btn-outline:hover { color: var(--ows-brand-300); } }

.ows-btn-primary {
  color: var(--ows-white) !important;
  background: linear-gradient(135deg, var(--ows-brand-600), var(--ows-brand-500));
  border-color: transparent;
  box-shadow: 0 2px 8px rgba(31,71,235,.3);
}
.ows-btn-primary:hover {
  background: linear-gradient(135deg, var(--ows-brand-700), var(--ows-brand-600));
  box-shadow: 0 4px 16px rgba(31,71,235,.4);
  transform: translateY(-1px);
  color: var(--ows-white) !important;
}

.ows-btn-sm { padding: 0.375rem 0.75rem; font-size: 0.8125rem; }

/* ── 5. MOBILE MENU ────────────────────────────────────────────────────── */
.ows-mobile-menu {
  overflow: hidden;
  max-height: 0;
  background: var(--ows-mob-bg);
  border-top: 1px solid var(--ows-mob-border);
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
  transition: max-height 0.35s cubic-bezier(.4,0,.2,1);
}
@media (min-width: 1024px) { .ows-mobile-menu { display: none !important; } }

.ows-mobile-inner { padding: 0.5rem 0 1rem; max-height: 70vh; overflow-y: auto; }

.ows-mobile-group { border-bottom: 1px solid rgba(15,23,42,.06); }
html.dark .ows-mobile-group { border-color: rgba(255,255,255,.05); }
@media (prefers-color-scheme: dark) { html:not(.light) .ows-mobile-group { border-color: rgba(255,255,255,.05); } }

.ows-mobile-group-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.875rem 1.25rem;
  background: none;
  border: none;
  font-size: 1rem;
  font-weight: 600;
  font-family: inherit;
  color: var(--ows-text-head);
  text-align: left;
  cursor: pointer;
}
.ows-mobile-group-btn:focus-visible { outline: 2px solid var(--ows-brand-500); outline-offset: -2px; }
.ows-mobile-group-btn svg { width: 1rem; height: 1rem; color: var(--ows-text-muted); transition: transform var(--ows-transition); }
.ows-mobile-group.open .ows-mobile-group-btn svg { transform: rotate(180deg); }

.ows-mobile-group-items {
  display: none;
  padding: 0 0 0.75rem;
  background: var(--ows-mob-item-hover);
}
.ows-mobile-group.open .ows-mobile-group-items { display: block; }
.ows-mobile-group-items a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.625rem 2rem;
  font-size: 0.9375rem;
  color: var(--ows-nav-text);
  text-decoration: none;
  transition: background var(--ows-transition);
}
.ows-mobile-group-items a:hover { background: rgba(0,0,0,.04); color: var(--ows-nav-text-hover); text-decoration: none; }
html.dark .ows-mobile-group-items a:hover { background: rgba(255,255,255,.06); }
@media (prefers-color-scheme: dark) { html:not(.light) .ows-mobile-group-items a:hover { background: rgba(255,255,255,.06); } }
.ows-mob-from { font-size: 0.75rem; color: var(--ows-brand-600); }
html.dark .ows-mob-from { color: var(--ows-brand-300); }
@media (prefers-color-scheme: dark) { html:not(.light) .ows-mob-from { color: var(--ows-brand-300); } }

.ows-mobile-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
}
.ows-mobile-actions .ows-btn { width: 100%; justify-content: center; }

/* Mobile cart link */
.ows-mobile-cart {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  font-size: 0.9375rem;
  color: var(--ows-nav-text);
  border-bottom: 1px solid rgba(15,23,42,.06);
  text-decoration: none;
  font-weight: 500;
}
.ows-mobile-cart:hover { background: var(--ows-mob-item-hover); text-decoration: none; color: var(--ows-nav-text-hover); }
html.dark .ows-mobile-cart { border-color: rgba(255,255,255,.05); }

/* ── 6. OWS FOOTER ────────────────────────────────────────────────────── */
.ows-footer {
  background: var(--ows-footer-bg);
  border-top: 1px solid var(--ows-footer-border);
  padding: 3.5rem 0 0;
}

.ows-footer-container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1.25rem;
}
@media (min-width: 1024px) { .ows-footer-container { padding: 0 2rem; } }

.ows-footer-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  padding-bottom: 3rem;
}
@media (min-width: 1024px) {
  .ows-footer-top { grid-template-columns: 300px 1fr; gap: 4rem; }
}

.ows-footer-brand p {
  margin-top: 1rem;
  font-size: 0.875rem;
  color: var(--ows-footer-text);
  line-height: 1.75;
  max-width: 22rem;
}

.ows-footer-contact { margin-top: 1.25rem; display: flex; flex-direction: column; gap: 0.625rem; }
.ows-footer-contact a, .ows-footer-contact span {
  font-size: 0.875rem;
  color: var(--ows-footer-text) !important;
  text-decoration: none !important;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: color var(--ows-transition);
}
.ows-footer-contact a:hover { color: var(--ows-footer-link-hover) !important; text-decoration: none !important; }
.ows-footer-contact svg { width: 1rem; height: 1rem; color: var(--ows-brand-500); flex-shrink: 0; }

.ows-footer-socials { display: flex; gap: 0.75rem; margin-top: 1.5rem; }
.ows-footer-socials a {
  display: grid;
  place-items: center;
  width: 2.25rem;
  height: 2.25rem;
  border: 1px solid var(--ows-footer-social-bdr);
  border-radius: var(--ows-r-sm);
  background: var(--ows-footer-social-bg);
  color: var(--ows-footer-social-text);
  transition: all var(--ows-transition);
  text-decoration: none;
}
.ows-footer-socials a:hover { color: var(--ows-brand-600); border-color: var(--ows-brand-300); text-decoration: none; }
html.dark .ows-footer-socials a:hover { color: var(--ows-brand-300); border-color: rgba(31,71,235,.4); }
@media (prefers-color-scheme: dark) { html:not(.light) .ows-footer-socials a:hover { color: var(--ows-brand-300); border-color: rgba(31,71,235,.4); } }
.ows-footer-socials svg { width: 1rem; height: 1rem; }

.ows-payment-methods { margin-top: 1rem; display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.ows-payment-methods > span:first-child { font-size: 0.75rem; color: var(--ows-footer-muted); }
.ows-payment-tag {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--ows-footer-muted);
  background: rgba(100,116,139,.1);
  border: 1px solid var(--ows-footer-border);
  border-radius: 0.375rem;
  padding: 0.25rem 0.625rem;
}

.ows-footer-cols {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
@media (min-width: 640px)  { .ows-footer-cols { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .ows-footer-cols { grid-template-columns: repeat(6, 1fr); } }

.ows-footer-col h3 {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--ows-footer-head);
  margin-bottom: 1rem;
}
.ows-footer-col ul { display: flex; flex-direction: column; gap: 0.75rem; list-style: none; padding: 0; margin: 0; }
.ows-footer-col a {
  font-size: 0.875rem;
  color: var(--ows-footer-link) !important;
  text-decoration: none !important;
  transition: color var(--ows-transition);
}
.ows-footer-col a:hover { color: var(--ows-footer-link-hover) !important; text-decoration: none !important; }

/* Datacenter section */
.ows-footer-datacenters {
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid var(--ows-footer-border);
}
.ows-footer-dc-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ows-footer-muted);
  margin-bottom: 0.75rem;
}
.ows-footer-dc-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.25rem;
  font-size: 0.875rem;
  color: var(--ows-footer-muted);
}
.ows-footer-dc-item {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  white-space: nowrap;
}
.ows-dc-dot {
  display: inline-block;
  width: 0.375rem;
  height: 0.375rem;
  border-radius: 50%;
  flex-shrink: 0;
}
.ows-dc-dot--live { background: #10b981; }
.ows-dc-dot--soon { background: #f59e0b; }
.ows-dc-code { color: var(--ows-footer-muted); opacity: 0.7; }

/* Footer bottom */
.ows-footer-bottom {
  border-top: 1px solid var(--ows-footer-border);
  padding: 1.75rem 0 1.5rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 2.5rem;
}
.ows-footer-bottom p { font-size: 0.875rem; color: var(--ows-footer-muted); margin: 0; }
.ows-footer-legal { display: flex; flex-wrap: wrap; gap: 1.25rem; }
.ows-footer-legal a { font-size: 0.875rem; color: var(--ows-footer-muted) !important; text-decoration: none !important; transition: color var(--ows-transition); }
.ows-footer-legal a:hover { color: var(--ows-footer-link-hover) !important; text-decoration: none !important; }

/* ── 7. BREADCRUMB (Nexus-compatible, dark-mode-aware) ─────────────────── */
.master-breadcrumb {
  background: var(--ows-bg-subtle);
  border-bottom: 1px solid var(--ows-border);
  padding: 0;
}
html.dark .master-breadcrumb { background: var(--ows-ink-soft); border-color: var(--ows-border); }
@media (prefers-color-scheme: dark) { html:not(.light) .master-breadcrumb { background: var(--ows-ink-soft); border-color: var(--ows-border); } }

.master-breadcrumb .breadcrumb {
  background: transparent;
  margin: 0;
  padding: 0.625rem 0;
  font-size: 0.875rem;
}
.master-breadcrumb .breadcrumb-item a { color: var(--ows-text-muted); }
.master-breadcrumb .breadcrumb-item.active { color: var(--ows-text-muted); }
.master-breadcrumb .breadcrumb-item + .breadcrumb-item::before { color: var(--ows-text-muted); opacity: 0.5; }

/* ── 8. UTILITY — hide old Nexus header/footer ─────────────────────────── */
/* Ensure our sticky header doesn't interfere with the Nexus full-page overlay */
#fullpage-overlay { z-index: 2000; }

/* ── 9. DARK MODE — btn-outline-* ──────────────────────────────────────── */
/* Bootstrap btn-outline-* have transparent backgrounds — in dark mode the
   border/text colours must be brightened so they remain legible. */
html.dark .btn-outline-primary {
  color: var(--ows-brand-300) !important;
  border-color: var(--ows-brand-400) !important;
  background-color: transparent !important;
}
html.dark .btn-outline-primary:hover,
html.dark .btn-outline-primary:focus,
html.dark .btn-outline-primary:active,
html.dark .btn-outline-primary.active,
html.dark .show > .btn-outline-primary.dropdown-toggle {
  color: var(--ows-white) !important;
  background-color: var(--ows-brand-600) !important;
  border-color: var(--ows-brand-600) !important;
}
html.dark .btn-outline-secondary {
  color: var(--ows-slate-300) !important;
  border-color: var(--ows-slate-500) !important;
  background-color: transparent !important;
}
html.dark .btn-outline-secondary:hover,
html.dark .btn-outline-secondary:focus {
  color: var(--ows-white) !important;
  background-color: rgba(255,255,255,.10) !important;
  border-color: var(--ows-slate-400) !important;
}
html.dark .btn-outline-success {
  color: #4ade80 !important;
  border-color: rgba(74,222,128,.55) !important;
  background-color: transparent !important;
}
html.dark .btn-outline-success:hover,
html.dark .btn-outline-success:focus {
  color: var(--ows-white) !important;
  background-color: rgba(22,163,74,.60) !important;
  border-color: rgba(74,222,128,.7) !important;
}
html.dark .btn-outline-danger {
  color: #f87171 !important;
  border-color: rgba(248,113,113,.55) !important;
  background-color: transparent !important;
}
html.dark .btn-outline-danger:hover,
html.dark .btn-outline-danger:focus {
  color: var(--ows-white) !important;
  background-color: rgba(220,38,38,.60) !important;
  border-color: rgba(248,113,113,.7) !important;
}
html.dark .btn-outline-warning {
  color: #fbbf24 !important;
  border-color: rgba(251,191,36,.55) !important;
  background-color: transparent !important;
}
html.dark .btn-outline-warning:hover,
html.dark .btn-outline-warning:focus {
  color: var(--ows-ink) !important;
  background-color: rgba(234,179,8,.70) !important;
  border-color: rgba(251,191,36,.8) !important;
}
html.dark .btn-outline-info {
  color: var(--ows-accent-400) !important;
  border-color: rgba(34,211,238,.50) !important;
  background-color: transparent !important;
}
html.dark .btn-outline-info:hover,
html.dark .btn-outline-info:focus {
  color: var(--ows-ink) !important;
  background-color: rgba(6,182,212,.65) !important;
  border-color: rgba(34,211,238,.75) !important;
}
html.dark .btn-outline-light {
  color: var(--ows-slate-200) !important;
  border-color: rgba(255,255,255,.25) !important;
  background-color: transparent !important;
}
html.dark .btn-outline-light:hover,
html.dark .btn-outline-light:focus {
  color: var(--ows-ink) !important;
  background-color: var(--ows-slate-200) !important;
  border-color: var(--ows-slate-200) !important;
}
html.dark .btn-outline-dark {
  color: var(--ows-slate-300) !important;
  border-color: rgba(255,255,255,.20) !important;
  background-color: transparent !important;
}
html.dark .btn-outline-dark:hover,
html.dark .btn-outline-dark:focus {
  color: var(--ows-white) !important;
  background-color: rgba(255,255,255,.10) !important;
  border-color: rgba(255,255,255,.35) !important;
}
/* btn-success / btn-info / btn-warning / btn-danger — solid variants */
html.dark .btn-success { background-color: rgba(22,163,74,.85) !important; border-color: rgba(22,163,74,.9) !important; color: var(--ows-white) !important; }
html.dark .btn-danger  { background-color: rgba(220,38,38,.85)  !important; border-color: rgba(220,38,38,.9)  !important; color: var(--ows-white) !important; }
html.dark .btn-warning { background-color: rgba(202,138,4,.85)  !important; border-color: rgba(202,138,4,.9)  !important; color: var(--ows-ink)   !important; }
html.dark .btn-info    { background-color: rgba(6,182,212,.80)  !important; border-color: rgba(6,182,212,.9)  !important; color: var(--ows-ink)   !important; }
html.dark .btn-secondary { background-color: var(--ows-slate-700) !important; border-color: var(--ows-slate-600) !important; color: var(--ows-slate-200) !important; }

@media (prefers-color-scheme: dark) {
  html:not(.light) .btn-outline-primary { color: var(--ows-brand-300) !important; border-color: var(--ows-brand-400) !important; background-color: transparent !important; }
  html:not(.light) .btn-outline-primary:hover, html:not(.light) .btn-outline-primary:focus, html:not(.light) .btn-outline-primary:active { color: var(--ows-white) !important; background-color: var(--ows-brand-600) !important; border-color: var(--ows-brand-600) !important; }
  html:not(.light) .btn-outline-secondary { color: var(--ows-slate-300) !important; border-color: var(--ows-slate-500) !important; background-color: transparent !important; }
  html:not(.light) .btn-outline-secondary:hover { color: var(--ows-white) !important; background-color: rgba(255,255,255,.10) !important; }
  html:not(.light) .btn-outline-success { color: #4ade80 !important; border-color: rgba(74,222,128,.55) !important; background-color: transparent !important; }
  html:not(.light) .btn-outline-success:hover { color: var(--ows-white) !important; background-color: rgba(22,163,74,.60) !important; }
  html:not(.light) .btn-outline-danger { color: #f87171 !important; border-color: rgba(248,113,113,.55) !important; background-color: transparent !important; }
  html:not(.light) .btn-outline-danger:hover { color: var(--ows-white) !important; background-color: rgba(220,38,38,.60) !important; }
  html:not(.light) .btn-outline-warning { color: #fbbf24 !important; border-color: rgba(251,191,36,.55) !important; background-color: transparent !important; }
  html:not(.light) .btn-outline-warning:hover { color: var(--ows-ink) !important; background-color: rgba(234,179,8,.70) !important; }
  html:not(.light) .btn-outline-info { color: var(--ows-accent-400) !important; border-color: rgba(34,211,238,.50) !important; background-color: transparent !important; }
  html:not(.light) .btn-outline-info:hover { color: var(--ows-ink) !important; background-color: rgba(6,182,212,.65) !important; }
  html:not(.light) .btn-outline-light { color: var(--ows-slate-200) !important; border-color: rgba(255,255,255,.25) !important; background-color: transparent !important; }
  html:not(.light) .btn-outline-dark  { color: var(--ows-slate-300) !important; border-color: rgba(255,255,255,.20) !important; background-color: transparent !important; }
  html:not(.light) .btn-success { background-color: rgba(22,163,74,.85) !important; border-color: rgba(22,163,74,.9) !important; color: var(--ows-white) !important; }
  html:not(.light) .btn-danger  { background-color: rgba(220,38,38,.85) !important; border-color: rgba(220,38,38,.9) !important; color: var(--ows-white) !important; }
  html:not(.light) .btn-warning { background-color: rgba(202,138,4,.85) !important; border-color: rgba(202,138,4,.9) !important; color: var(--ows-ink)   !important; }
  html:not(.light) .btn-info    { background-color: rgba(6,182,212,.80) !important; border-color: rgba(6,182,212,.9) !important; color: var(--ows-ink)   !important; }
  html:not(.light) .btn-secondary { background-color: var(--ows-slate-700) !important; border-color: var(--ows-slate-600) !important; color: var(--ows-slate-200) !important; }
}

/* ── 10. DARK MODE — WHMCS dynamic store (product pages) ───────────────── */
/* The dynamic store embeds per-page CSS vars (--bg-color, --bg-light, etc.)
   via inline style from WHMCS branding — those don't switch in dark mode.
   We override the hardcoded light values at the html.dark level. */
html.dark .dynamic-landing-page .background-light,
html.dark .dynamic-landing-page .background-main {
  background: var(--ows-bg-page) !important;
}
html.dark .dynamic-landing-page .background-gradient {
  background: linear-gradient(135deg, var(--ows-ink-soft) 0%, var(--ows-ink) 100%) !important;
}

/* Pricing cards — hardcoded #ffffff background */
html.dark .pricing-card {
  background: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.35) !important;
}
html.dark .pricing-card:hover {
  border-color: var(--ows-brand-500) !important;
  box-shadow: 0 12px 40px rgba(0,0,0,.55) !important;
}
html.dark .pricing-card:has(.plan-button:hover) { border-color: var(--ows-brand-500) !important; }
html.dark .plan-name    { color: var(--ows-text-head) !important; }
html.dark .price-amount { color: var(--ows-brand-300) !important; }
html.dark .price-period,
html.dark .plan-description { color: var(--ows-text-muted) !important; }
html.dark .feature-item { color: var(--ows-text-base) !important; }
html.dark .plan-button {
  background: var(--ows-brand-600) !important;
  border-color: var(--ows-brand-600) !important;
  color: var(--ows-white) !important;
}
html.dark .plan-button:hover {
  background: var(--ows-brand-500) !important;
  border-color: var(--ows-brand-500) !important;
}

/* Pricing section headings */
html.dark .pricing-title   { color: var(--ows-text-head) !important; }
html.dark .pricing-subtitle { color: var(--ows-text-muted) !important; }

/* Comparison / features table */
html.dark .table-wrapper {
  background: var(--ows-bg-card) !important;
  border: 1px solid var(--ows-border) !important;
}
html.dark .comparison-table th,
html.dark .comparison-table td {
  border-color: var(--ows-border) !important;
  color: var(--ows-text-base) !important;
}
html.dark .comparison-table .product-name,
html.dark .comparison-table .feature-title { color: var(--ows-text-head) !important; }
html.dark .comparison-table .feature-description,
html.dark .comparison-table .feature-text  { color: var(--ows-text-muted) !important; }
html.dark .comparison-table .feature-number,
html.dark .table-price,
html.dark .table-price .price-amount,
html.dark .table-price .price-period { color: var(--ows-brand-300) !important; }
html.dark .feature-row:hover { background: rgba(255,255,255,.03) !important; }
html.dark .buy-row {
  background: var(--ows-ink-soft) !important;
  border-top-color: var(--ows-border) !important;
}
html.dark .table-cta-button {
  background: var(--ows-brand-600) !important;
  border-color: var(--ows-brand-600) !important;
  color: var(--ows-white) !important;
}
html.dark .table-cta-button:hover { background: var(--ows-brand-500) !important; border-color: var(--ows-brand-500) !important; }
html.dark .table-note p { color: var(--ows-text-muted) !important; }

/* FAQ section */
html.dark .faq-section .faq-item { border-color: var(--ows-border) !important; }
html.dark .faq-question-text    { color: var(--ows-text-head) !important; }
html.dark .faq-title,
html.dark .faq-subtitle         { color: var(--ows-text-head) !important; }
html.dark .faq-subtitle         { color: var(--ows-text-muted) !important; }
html.dark .faq-answer-content,
html.dark .faq-answer-content p { color: var(--ows-text-base) !important; }
html.dark .faq-contact {
  background: var(--ows-bg-card) !important;
  border: 1px solid var(--ows-border);
}
html.dark .faq-contact-text { color: var(--ows-text-base) !important; }

/* Hero / showcase sections */
html.dark .hero-logo-container {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid var(--ows-border);
  box-shadow: none !important;
}
html.dark .hero-title  { color: var(--ows-text-head); }
html.dark .hero-subtitle,
html.dark .hero-description { color: var(--ows-text-muted) !important; }
html.dark .showcase-title   { color: var(--ows-text-head) !important; }
html.dark .showcase-subtitle,
html.dark .showcase-description { color: var(--ows-text-muted) !important; }

/* CTA sections */
html.dark .cta-title       { color: var(--ows-text-head) !important; }
html.dark .cta-subtitle,
html.dark .cta-description { color: var(--ows-text-muted) !important; }
html.dark .cta-primary-button:not(.cta-section--gradient .cta-primary-button) {
  background: var(--ows-brand-600) !important;
  color: var(--ows-white) !important;
}
html.dark .cta-secondary-button {
  color: var(--ows-slate-300) !important;
  border-color: var(--ows-slate-500) !important;
}
html.dark .cta-secondary-button:hover {
  background: rgba(255,255,255,.08) !important;
  color: var(--ows-white) !important;
}

/* Feature sections (free_form / product_preview) */
html.dark .features-section,
html.dark .product-showcase { color: var(--ows-text-base); }
html.dark .features-table-title,
html.dark .features-table-subtitle { color: var(--ows-text-head) !important; }
html.dark .features-table-subtitle { color: var(--ows-text-muted) !important; }

/* Prefers-color-scheme mirror */
@media (prefers-color-scheme: dark) {
  html:not(.light) .dynamic-landing-page .background-light,
  html:not(.light) .dynamic-landing-page .background-main { background: var(--ows-bg-page) !important; }
  html:not(.light) .dynamic-landing-page .background-gradient { background: linear-gradient(135deg, var(--ows-ink-soft) 0%, var(--ows-ink) 100%) !important; }
  html:not(.light) .pricing-card { background: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; box-shadow: 0 4px 20px rgba(0,0,0,.35) !important; }
  html:not(.light) .pricing-card:hover { border-color: var(--ows-brand-500) !important; }
  html:not(.light) .plan-name    { color: var(--ows-text-head) !important; }
  html:not(.light) .price-amount { color: var(--ows-brand-300) !important; }
  html:not(.light) .price-period, html:not(.light) .plan-description { color: var(--ows-text-muted) !important; }
  html:not(.light) .feature-item { color: var(--ows-text-base) !important; }
  html:not(.light) .plan-button { background: var(--ows-brand-600) !important; border-color: var(--ows-brand-600) !important; color: var(--ows-white) !important; }
  html:not(.light) .plan-button:hover { background: var(--ows-brand-500) !important; border-color: var(--ows-brand-500) !important; }
  html:not(.light) .table-wrapper { background: var(--ows-bg-card) !important; border: 1px solid var(--ows-border) !important; }
  html:not(.light) .comparison-table th, html:not(.light) .comparison-table td { border-color: var(--ows-border) !important; color: var(--ows-text-base) !important; }
  html:not(.light) .comparison-table .product-name, html:not(.light) .comparison-table .feature-title { color: var(--ows-text-head) !important; }
  html:not(.light) .feature-row:hover { background: rgba(255,255,255,.03) !important; }
  html:not(.light) .buy-row { background: var(--ows-ink-soft) !important; border-top-color: var(--ows-border) !important; }
  html:not(.light) .table-cta-button { background: var(--ows-brand-600) !important; color: var(--ows-white) !important; }
  html:not(.light) .faq-section .faq-item { border-color: var(--ows-border) !important; }
  html:not(.light) .faq-question-text { color: var(--ows-text-head) !important; }
  html:not(.light) .faq-answer-content, html:not(.light) .faq-answer-content p { color: var(--ows-text-base) !important; }
  html:not(.light) .faq-contact { background: var(--ows-bg-card) !important; }
  html:not(.light) .hero-logo-container { background: rgba(255,255,255,.06) !important; box-shadow: none !important; }
  html:not(.light) .pricing-title  { color: var(--ows-text-head) !important; }
  html:not(.light) .pricing-subtitle { color: var(--ows-text-muted) !important; }
  html:not(.light) .showcase-title { color: var(--ows-text-head) !important; }
  html:not(.light) .showcase-subtitle, html:not(.light) .showcase-description { color: var(--ows-text-muted) !important; }
  html:not(.light) .cta-title { color: var(--ows-text-head) !important; }
  html:not(.light) .cta-subtitle, html:not(.light) .cta-description { color: var(--ows-text-muted) !important; }
}

/* ── 11. DARK MODE — WHMCS Store & Cart (hardcoded backgrounds & high-specificity selectors) ── */
/*
 * The Nexus SASS compiles to hardcoded `background: white` for several cart
 * and product elements. CSS variable overrides alone don't fix those — we need
 * explicit !important rules that beat the compiled all.css selectors.
 *
 * We also match the full SASS-compiled selector chains exactly so our rules
 * have equal or higher specificity.
 */

/* ── Product listing cards ── */
html.dark body #order-standard_cart .products .product {
  background: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .products .product header {
  background: var(--ows-ink-soft) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .cart-body .products .product header {
  background: var(--ows-ink-soft) !important;
  border-bottom-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .products .product div.product-desc {
  color: var(--ows-text-base) !important;
}
/* Blanket override — catches any hardcoded #333 anywhere inside the product header */
html.dark body #order-standard_cart .products .product header,
html.dark body #order-standard_cart .products .product header * {
  color: #cbd5e1 !important;
}
/* Re-apply muted color for the qty badge after the blanket above */
html.dark body #order-standard_cart .products .product header .qty {
  color: var(--ows-text-muted) !important;
}
html.dark body #order-standard_cart .products .product footer .btn-order-now {
  background: var(--ows-brand-600) !important;
  border-color: var(--ows-brand-600) !important;
  color: #fff !important;
}
html.dark body #order-standard_cart .products .product footer .btn-order-now:hover {
  background: var(--ows-brand-500) !important;
  border-color: var(--ows-brand-500) !important;
}

/* ── Cart sidebar — panel-title (var(--text) resolves to #111827 before our fix lands) ── */
html.dark body #order-standard_cart .cart-sidebar .card-sidebar .panel-title {
  color: var(--ows-text-head) !important;
}
html.dark body #order-standard_cart .cart-sidebar .card-header {
  color: var(--ows-text-head) !important;
}
html.dark body #order-standard_cart .cart-sidebar .list-group-item {
  color: var(--ows-text-base) !important;
  background-color: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .cart-sidebar .card-footer {
  background-color: var(--ows-ink-soft) !important;
}

/* ── General sidebar (client area pages) ── */
html.dark .sidebar .card-sidebar .panel-title { color: var(--ows-text-head) !important; }
html.dark .sidebar .card-header             { color: var(--ows-text-head) !important; }

/* ── Breadcrumb — match compiled SASS specificity (.master-breadcrumb .breadcrumb .breadcrumb-item) ── */
html.dark .master-breadcrumb .breadcrumb .breadcrumb-item       { color: var(--ows-text-muted) !important; }
html.dark .master-breadcrumb .breadcrumb .breadcrumb-item a     { color: var(--ows-text-muted) !important; }
html.dark .master-breadcrumb .breadcrumb .breadcrumb-item.active { color: var(--ows-text-muted) !important; }
html.dark .master-breadcrumb .breadcrumb .breadcrumb-item + .breadcrumb-item::before { color: var(--ows-text-muted) !important; opacity: .4; }

/* ── View-cart empty state ── */
html.dark body #order-standard_cart .view-cart-empty {
  background-color: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .cart-body .view-cart-items-header {
  background-color: var(--ows-ink-soft) !important;
  border-color: var(--ows-border) !important;
  color: var(--ows-text-head) !important;
}
html.dark body #order-standard_cart .cart-body .view-cart-items {
  color: var(--ows-text-base) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .cart-body .view-cart-items .item {
  border-color: var(--ows-border) !important;
}

/* ── Order summary ── */
html.dark body #order-standard_cart .order-summary {
  background-color: var(--ows-bg-card) !important;
}
html.dark body #order-standard_cart .order-summary h2 {
  background-color: var(--ows-ink-soft) !important;
  border-color: var(--ows-border) !important;
  color: var(--ows-text-head) !important;
}
html.dark body #order-standard_cart .order-summary .summary-container {
  background-color: var(--ows-ink-soft) !important;
  border-color: var(--ows-border) !important;
}

/* ── Checkout button ── */
html.dark body #order-standard_cart .text-right .btn-checkout {
  background: var(--ows-brand-600) !important;
  border-color: var(--ows-brand-600) !important;
  color: #fff !important;
}

/* ── Sub-heading ── */
html.dark body #order-standard_cart .sub-heading span {
  background: var(--ows-ink-soft) !important;
  color: var(--ows-text-base) !important;
}

/* ── Domain selection ── */
html.dark body #order-standard_cart .domain-selection-options {
  background: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .domain-selection-options .option-selected {
  background: var(--ows-ink-soft) !important;
}

/* ── Transfer panel ── */
html.dark body #order-standard_cart .panel .panel-heading,
html.dark body #order-standard_cart .panel .panel-footer {
  background: var(--ows-ink-soft) !important;
  border-color: var(--ows-border) !important;
}

/* ── Apply promo / tabs ── */
html.dark body #order-standard_cart .secondary-cart-body .view-cart-tabs .nav-tabs a[aria-expanded="true"] {
  background-color: var(--ows-bg-card) !important;
  color: var(--ows-text-head) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .secondary-cart-body .view-cart-tabs .tab-content {
  background-color: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
}

/* ── Domain pricing ── */
html.dark body #order-standard_cart .domain-pricing .tld-filters .badge {
  background: var(--ows-bg-card) !important;
  color: var(--ows-text-base) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .domain-pricing .tld-pricing-header .tld-column,
html.dark body #order-standard_cart .domain-pricing .tld-pricing-header div {
  background: var(--ows-ink-soft) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .domain-pricing .bg-white {
  background: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .domain-promo-box {
  background: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
}

/* ── Product info / MC promo ── */
html.dark body #order-standard_cart .product-info {
  background-color: var(--ows-bg-card) !important;
  border-color: var(--ows-border) !important;
}
html.dark body #order-standard_cart .mc-promo {
  border-color: var(--ows-border) !important;
}

/* ── Configure product form ── */
html.dark body #frmConfigureProduct .form-control { color: var(--ows-text-base) !important; }

/* ── Prefers-color-scheme mirrors ── */
@media (prefers-color-scheme: dark) {
  html:not(.light) body #order-standard_cart .products .product { background: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .products .product header { background: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .cart-body .products .product header { background: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .products .product div.product-desc { color: var(--ows-text-base) !important; }
  html:not(.light) body #order-standard_cart .products .product footer .btn-order-now { background: var(--ows-brand-600) !important; border-color: var(--ows-brand-600) !important; color: #fff !important; }
  html:not(.light) body #order-standard_cart .cart-sidebar .card-sidebar .panel-title { color: var(--ows-text-head) !important; }
  html:not(.light) body #order-standard_cart .cart-sidebar .card-header { color: var(--ows-text-head) !important; }
  html:not(.light) body #order-standard_cart .cart-sidebar .list-group-item { color: var(--ows-text-base) !important; background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
  html:not(.light) .sidebar .card-sidebar .panel-title { color: var(--ows-text-head) !important; }
  html:not(.light) .master-breadcrumb .breadcrumb .breadcrumb-item { color: var(--ows-text-muted) !important; }
  html:not(.light) .master-breadcrumb .breadcrumb .breadcrumb-item a { color: var(--ows-text-muted) !important; }
  html:not(.light) .master-breadcrumb .breadcrumb .breadcrumb-item.active { color: var(--ows-text-muted) !important; }
  html:not(.light) body #order-standard_cart .order-summary { background-color: var(--ows-bg-card) !important; }
  html:not(.light) body #order-standard_cart .order-summary h2 { background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; color: var(--ows-text-head) !important; }
  html:not(.light) body #order-standard_cart .order-summary .summary-container { background-color: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .view-cart-empty { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .domain-selection-options { background: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .panel .panel-heading, html:not(.light) body #order-standard_cart .panel .panel-footer { background: var(--ows-ink-soft) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .sub-heading span { background: var(--ows-ink-soft) !important; color: var(--ows-text-base) !important; }
  html:not(.light) body #order-standard_cart .domain-pricing .tld-filters .badge { background: var(--ows-bg-card) !important; color: var(--ows-text-base) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .domain-pricing .bg-white { background: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .domain-promo-box { background: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .product-info { background-color: var(--ows-bg-card) !important; border-color: var(--ows-border) !important; }
  html:not(.light) body #order-standard_cart .text-right .btn-checkout { background: var(--ows-brand-600) !important; border-color: var(--ows-brand-600) !important; color: #fff !important; }
  html:not(.light) body #frmConfigureProduct .form-control { color: var(--ows-text-base) !important; }
  html:not(.light) body #order-standard_cart .products .product header,
  html:not(.light) body #order-standard_cart .products .product header * { color: #cbd5e1 !important; }
  html:not(.light) body #order-standard_cart .products .product header .qty { color: var(--ows-text-muted) !important; }
}
