/* Custom Dark Theme for al.uy */

/* Fira Code Font */
@import url('https://fonts.googleapis.com/css2?family=Fira+Code:wght@300;400;500;600;700&display=swap');

@font-face {
    font-family: 'FiraCode-Regular';
    src: url('fonts/FiraCode-Regular.woff2') format('woff2'),
         url('fonts/FiraCode-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

:root {
    --primary-red: #dc3545;
    --dark-bg: #0a0a0a;
    --darker-bg: #000000;
    --text-white: #ffffff;
    --text-gray: #cccccc;
    --font-family: 'Fira Code', 'FiraCode-Regular', 'Courier New', monospace;
}

/* Global Override - Force Dark Theme Everywhere */
* {
    box-sizing: border-box;
    font-family: var(--font-family) !important;
}

/* Icons use original fonts - exclude from Fira Code */
i,
.fa,
.fas,
.far,
.fal,
.fad,
.fab,
[class*="fa-"],
[class*="icon"],
.icon,
svg,
svg *,
[class*="icon-"],
[class*="glyphicon"],
[class*="fa-"]:before,
[class*="fa-"]:after {
    font-family: "Font Awesome 5 Free", "Font Awesome 5 Pro", "Font Awesome 5 Brands", "FontAwesome", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    font-style: normal !important;
    font-weight: normal !important;
}

html {
    background-color: var(--dark-bg) !important;
    min-height: 100% !important;
    height: 100% !important;
    position: relative;
}

body {
    background-color: var(--dark-bg) !important;
    color: var(--text-white) !important;
    font-family: var(--font-family) !important;
    min-height: 100vh !important;
    position: relative !important;
}

body.primary-bg-color {
    background-color: var(--dark-bg) !important;
}

/* Force all backgrounds to dark */
div, section, article, aside, main, header, footer, nav {
    background-color: transparent !important;
}

/* Force all text to white unless specifically styled */
*, *::before, *::after {
    color: inherit;
}

/* Remove text selection highlights that might create lighter squares */
::selection,
::-moz-selection {
    background-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.panel-title::selection,
.panel-title::-moz-selection,
.card-title::selection,
.card-title::-moz-selection,
h3.panel-title::selection,
h3.panel-title::-moz-selection {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

/* Override Bootstrap defaults */
.bg-light, .bg-white {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

.bg-dark {
    background-color: var(--darker-bg) !important;
}

.text-dark {
    color: var(--text-white) !important;
}

.border {
    border-color: rgba(220, 53, 69, 0.2) !important;
}

.border-light {
    border-color: rgba(220, 53, 69, 0.2) !important;
}

/* Grid Pattern Background */
html::before,
body::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100vw;
    height: 100vh;
    min-height: 100%;
    background-image: 
        linear-gradient(rgba(220, 53, 69, 0.1) 1px, transparent 1px),
        linear-gradient(90deg, rgba(220, 53, 69, 0.1) 1px, transparent 1px);
    background-size: 50px 50px;
    background-attachment: fixed;
    pointer-events: none;
    z-index: 0;
}

#main-body,
body > *,
.container,
.container-fluid,
.wrapper {
    position: relative;
    z-index: 1;
}

/* Ensure modals are always on top, even when inside containers */
body > .modal,
body > form > .modal,
.container .modal,
.container-fluid .modal,
.wrapper .modal {
    z-index: 99999 !important;
    position: fixed !important;
}

/* Header Styles */
#header,
header,
.header {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2);
    position: relative;
    z-index: 1000;
}

/* Ensure header is BELOW modals - AGGRESSIVE - ONLY when modal is open */
body.modal-open #header,
body.modal-open header,
body.modal-open .header,
body.modal-open .navbar,
body.modal-open .navbar-wrapper,
body.modal-open .main-navbar-wrapper,
.modal.show ~ #header,
.modal.show ~ header,
.modal.show ~ .header,
.modal.show ~ .navbar,
.modal.show ~ .navbar-wrapper,
.modal.show ~ .main-navbar-wrapper {
    z-index: 999 !important;
}

/* When modal is visible, force header even lower */
.modal.show,
.modal.in,
.modal.fade.show {
    z-index: 999999 !important;
}

.modal.show ~ *,
.modal.in ~ * {
    z-index: auto !important;
}

.header .navbar {
    background-color: transparent !important;
}

.header .navbar-light {
    background-color: transparent !important;
}

.header .navbar-nav .nav-link,
.header .nav-link,
#header .nav-link,
header .nav-link {
    background-color: transparent !important;
    background: transparent !important;
    color: var(--text-white) !important;
    padding: 0.5rem 1rem;
    transition: color 0.3s;
}

.header .navbar-nav .nav-link:hover,
.header .navbar-nav .nav-link.active {
    color: var(--text-white) !important;
}

.header .topbar,
.topbar {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
    color: var(--text-white) !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2);
}

.header .topbar .btn,
.header .btn,
#header .btn,
header .btn {
    background-color: transparent !important;
    background: transparent !important;
    color: var(--text-white) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
}

.header .topbar .btn:hover,
.header .btn:hover,
#header .btn:hover,
header .btn:hover {
    background-color: transparent !important;
    background: transparent !important;
    border-color: rgba(220, 53, 69, 0.5) !important;
}

/* Top Navbar Layout */
.header .navbar-light .container {
  display: flex;
  align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 100%;
}

.header .navbar-light .form-inline {
    display: flex;
    align-items: center;
    margin-left: auto;
    margin-right: 1rem;
}

.header .navbar-light .navbar-nav.toolbar {
    margin-left: 0;
}

/* Search Bar Styling */
.header .input-group.search {
    max-width: 400px;
}

.header .input-group.search .form-control {
    background-color: #212529 !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    color: var(--text-white) !important;
    padding: 0.5rem 1rem;
}

.header .input-group.search .form-control:focus {
    background-color: #212529 !important;
    border-color: rgba(255, 255, 255, 0.4) !important;
    box-shadow: none;
}

.header .input-group.search .form-control::placeholder {
    color: var(--text-gray) !important;
}

.header .input-group.search .btn {
    background-color: #212529 !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-right: none !important;
    color: var(--text-white) !important;
    padding: 0.5rem 1rem;
}

.header .input-group.search .btn:hover {
    background-color: #2a2e33 !important;
}

/* Shopping Cart Button */
.header .cart-btn,
.cart-btn {
    background-color: transparent !important;
    background: transparent !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
    padding: 0.5rem !important;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.header .cart-btn:hover,
.cart-btn:hover {
    background-color: transparent !important;
    background: transparent !important;
    border-color: rgba(220, 53, 69, 0.5) !important;
}

.header .cart-btn .badge {
  position: absolute;
    top: -5px;
    right: -5px;
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    border-radius: 50%;
    min-width: 18px;
    height: 18px;
    padding: 0;
    font-size: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Toolbar Nav */
.header .navbar-nav.toolbar,
.header .toolbar,
.toolbar {
    background-color: transparent !important;
    background: transparent !important;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.header .nav-item,
.nav-item {
    background-color: transparent !important;
    background: transparent !important;
}

/* Main Navbar */
.header .main-navbar-wrapper,
.main-navbar-wrapper {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
    border-top: 1px solid rgba(220, 53, 69, 0.2);
}

.header .main-navbar-wrapper .navbar-nav {
    display: flex;
    align-items: center;
}

.header .main-navbar-wrapper .navbar-nav .nav-link {
    color: var(--text-white) !important;
    padding: 0.75rem 1rem;
}

.header .main-navbar-wrapper .navbar-nav .nav-link:hover {
    color: var(--text-white) !important;
}

/* Force all navbar links to be white */
#header a,
#header .nav-link,
#header .navbar-nav a,
#header .navbar-nav .nav-link,
#header .dropdown-toggle,
#header .navbar-nav .dropdown-toggle {
    color: var(--text-white) !important;
}

#header a:hover,
#header .nav-link:hover,
#header .navbar-nav a:hover {
    color: var(--text-white) !important;
}

/* Logo Styles */
.header .navbar-brand {
    color: var(--text-white) !important;
    font-size: 1.5rem;
    font-weight: bold;
    display: flex;
    align-items: center;
    gap: 0.5rem;
  text-decoration: none;
    padding: 0.5rem 0;
}

.header .navbar-brand:hover {
    color: var(--text-white) !important;
  text-decoration: none;
}

.header .navbar-brand .logo-img {
    max-height: 40px;
    width: auto;
}

/* Portal Button */
.btn-portal {
    border: 2px solid var(--primary-red) !important;
    color: var(--text-white) !important;
    background-color: transparent !important;
    background: transparent !important;
    padding: 0.5rem 1.5rem;
    text-transform: uppercase;
    font-weight: bold;
    transition: all 0.3s;
    text-decoration: none;
    display: inline-block;
    margin-left: 1rem;
}

.btn-portal:hover {
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
  text-decoration: none;
}

/* Hero Section */
.hero-section {
    min-height: 80vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 4rem 2rem;
    position: relative;
    z-index: 1;
    background-color: var(--dark-bg);
}

.hero-bracket {
    color: var(--primary-red);
    font-size: 0.9rem;
    letter-spacing: 0.2em;
    margin-bottom: 1rem;
    text-transform: uppercase;
}

.hero-title {
    font-size: 4rem;
    font-weight: 900;
    line-height: 1.1;
    margin-bottom: 1.5rem;
}

.hero-title .text-white {
    color: var(--text-white);
}

.hero-title .text-red {
    color: var(--primary-red);
}

.hero-description {
    font-size: 1.2rem;
    color: var(--text-gray);
    max-width: 600px;
    margin: 0 auto 2rem;
    line-height: 1.6;
}

/* Red Button Style */
.btn-red {
    background-color: var(--primary-red);
    color: var(--text-white);
    border: none;
    padding: 1rem 2.5rem;
    font-size: 1rem;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: all 0.3s;
    display: inline-block;
  text-decoration: none;
}

.btn-red:hover {
    background-color: #c82333;
    color: var(--text-white);
    transform: translateY(-2px);
}

/* Services Section */
.services-section {
    padding: 4rem 2rem;
    text-align: center;
    background-color: var(--dark-bg);
}

.section-title {
    font-size: 3rem;
    font-weight: 900;
    color: var(--text-white);
    margin-bottom: 1rem;
    text-transform: uppercase;
}

.section-subtitle {
    font-size: 1.1rem;
    color: var(--text-gray);
    margin-bottom: 3rem;
}

/* Cards */
.card {
    background-color: transparent !important;
    background: transparent !important;
    border: 1px solid rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Force all card variants to be transparent */
.card *,
.card-body *,
.card-header *,
.card-footer * {
    background-color: transparent !important;
    background: transparent !important;
}

/* Exception: only allow transparent backgrounds, never light ones */
.card[style*="background"],
.card-body[style*="background"],
.card-header[style*="background"] {
    background: transparent !important;
    background-color: transparent !important;
}

.card-title {
    color: var(--text-white) !important;
    box-shadow: none !important;
    outline: none !important;
    border: none !important;
}

.card-title::before,
.card-title::after {
    display: none !important;
    content: none !important;
    background: none !important;
}

.card-header {
    background-color: transparent !important;
    box-shadow: none !important;
    outline: none !important;
}

.card-header::before,
.card-header::after {
    display: none !important;
    content: none !important;
    background: none !important;
}

.card-header:hover {
    box-shadow: none !important;
    outline: none !important;
}

.card-header:hover::before,
.card-header:hover::after {
    display: none !important;
    content: none !important;
}

/* Remove squares from all elements within card-header */
.card-header * {
    box-shadow: none !important;
    outline: none !important;
    border: none !important;
}

.card-header *::before,
.card-header *::after {
    display: none !important;
    content: none !important;
}

.card-body {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

.card-body p {
    color: var(--text-gray) !important;
}

/* Links */
a {
    color: var(--primary-red);
    transition: color 0.3s;
}

a:hover {
    color: #c82333;
}

/* Forms */
.form-control,
input.form-control,
textarea.form-control,
select.form-control {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.form-control:focus,
input.form-control:focus,
textarea.form-control:focus,
select.form-control:focus {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
}

.form-control::placeholder,
input.form-control::placeholder,
textarea.form-control::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
}

/* Disabled form controls */
.form-control:disabled,
.form-control.disabled,
input.form-control:disabled,
input.form-control.disabled,
textarea.form-control:disabled,
textarea.form-control.disabled {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: rgba(255, 255, 255, 0.6) !important;
    opacity: 0.7 !important;
}

/* Textareas specifically */
textarea.form-control,
textarea {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

textarea.form-control:focus,
textarea:focus {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
    outline: none !important;
}

/* Support Ticket Form - Force dark on all inputs */
#inputName,
#inputEmail,
#inputSubject,
#inputMessage,
input[name="name"],
input[name="email"],
input[name="subject"],
textarea[name="message"],
textarea[name="replymessage"] {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#inputName:disabled,
#inputEmail:disabled,
input[name="name"]:disabled,
input[name="email"]:disabled,
input[name="name"].disabled,
input[name="email"].disabled {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: rgba(255, 255, 255, 0.6) !important;
}

/* Markdown editor textarea */
.markdown-editor,
textarea.markdown-editor {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.markdown-editor:focus,
textarea.markdown-editor:focus {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* Rich Text Editor Toolbar */
.markdown-editor-toolbar,
.md-editor-toolbar,
[class*="markdown"] [class*="toolbar"],
[class*="editor"] [class*="toolbar"],
.CodeMirror-toolbar,
.editor-toolbar {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    border-bottom: none !important;
}

.markdown-editor-toolbar button,
.md-editor-toolbar button,
[class*="markdown"] [class*="toolbar"] button,
[class*="editor"] [class*="toolbar"] button,
.CodeMirror-toolbar button,
.editor-toolbar button {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.markdown-editor-toolbar button:hover,
.md-editor-toolbar button:hover,
[class*="markdown"] [class*="toolbar"] button:hover,
[class*="editor"] [class*="toolbar"] button:hover,
.CodeMirror-toolbar button:hover,
.editor-toolbar button:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* CodeMirror Editor */
.CodeMirror,
.CodeMirror-wrap {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.CodeMirror-cursor {
    border-color: var(--text-white) !important;
}

.CodeMirror-selected {
    background-color: rgba(220, 53, 69, 0.3) !important;
}

/* File Input Styling */
.custom-file-input,
input[type="file"],
input[type="file"].form-control {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.custom-file-label,
.custom-file-label::after {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.custom-file-label::after {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-left: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.custom-file-input:focus ~ .custom-file-label,
.custom-file-input:focus ~ .custom-file-label::after {
    border-color: var(--primary-red) !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
}

/* Custom File Input Group */
.custom-file {
    background-color: transparent !important;
}

.attachment-group .btn-default,
.input-group-append .btn-default {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    border-left: none !important;
    color: var(--text-white) !important;
}

.attachment-group .btn-default:hover,
.input-group-append .btn-default:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.attachment-group .btn-default i {
    color: var(--text-white) !important;
}

/* Additional Rich Text Editor Styles */
[data-markdown-editor],
[class*="markdown"],
[class*="editor"] {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

[data-markdown-editor] [class*="toolbar"],
[class*="markdown"] [class*="toolbar"],
[class*="editor"] [class*="toolbar"] {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

[data-markdown-editor] [class*="toolbar"] button,
[class*="markdown"] [class*="toolbar"] button,
[class*="editor"] [class*="toolbar"] button {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

[data-markdown-editor] [class*="toolbar"] button:hover,
[class*="markdown"] [class*="toolbar"] button:hover,
[class*="editor"] [class*="toolbar"] button:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
}

/* Preview button in editor */
[class*="preview"],
button[class*="preview"],
.btn[class*="preview"],
button:has([class*="preview"]),
button:has(.fa-search),
button:has(.fa-magnifying-glass) {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

[class*="preview"]:hover,
[class*="preview"]:focus,
[class*="preview"]:active,
button[class*="preview"]:hover,
button[class*="preview"]:focus,
button[class*="preview"]:active,
.btn[class*="preview"]:hover,
.btn[class*="preview"]:focus,
.btn[class*="preview"]:active {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Remove any blue borders or highlights from preview button */
[class*="preview"].active,
[class*="preview"][class*="active"],
button[class*="preview"].active,
button[class*="preview"][class*="active"],
button[class*="preview"]:focus,
button[class*="preview"]:focus-visible,
button[class*="preview"]:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: rgba(220, 53, 69, 0.5) !important;
    color: var(--text-white) !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Ensure preview button matches other toolbar buttons */
[class*="preview"],
button[class*="preview"] {
    border-color: rgba(220, 53, 69, 0.3) !important;
}

[class*="preview"]:not(:hover):not(:focus):not(.active),
button[class*="preview"]:not(:hover):not(:focus):not(.active) {
    border-color: rgba(220, 53, 69, 0.3) !important;
    background-color: rgba(255, 255, 255, 0.1) !important;
}

/* Remove blue colors from all editor buttons */
[class*="editor"] button,
[class*="markdown"] button,
[data-markdown-editor] button,
[class*="toolbar"] button {
    border-color: rgba(220, 53, 69, 0.3) !important;
}

[class*="editor"] button:focus,
[class*="markdown"] button:focus,
[data-markdown-editor] button:focus,
[class*="toolbar"] button:focus,
[class*="editor"] button:active,
[class*="markdown"] button:active,
[data-markdown-editor] button:active,
[class*="toolbar"] button:active {
    border-color: var(--primary-red) !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
    outline: none !important;
}

/* Remove any blue/light blue colors */
button[style*="blue"],
button[style*="#007bff"],
button[style*="#0056b3"],
[class*="preview"][style*="blue"],
[class*="preview"][style*="#007bff"] {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Iframe-based editors */
iframe[class*="editor"],
iframe[class*="markdown"],
.editor-iframe {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

/* Editor status indicators */
[class*="editor"] [class*="status"],
[class*="editor"] [class*="info"],
[class*="lines"],
[class*="words"],
[class*="saved"] {
    color: rgba(255, 255, 255, 0.7) !important;
    background-color: transparent !important;
}

/* All buttons in editor containers */
[class*="editor"] button,
[class*="markdown"] button,
[data-markdown-editor] button {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

[class*="editor"] button:hover,
[class*="markdown"] button:hover,
[data-markdown-editor] button:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* Footer */
#footer,
footer,
footer.footer,
.footer {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
    border-top: 1px solid rgba(220, 53, 69, 0.2);
    color: var(--text-gray) !important;
    padding: 2rem 0;
    position: relative;
    z-index: 1;
}

/* Override any grey backgrounds from theme.css */
[style*="background-color: #404040"],
[style*="background-color:#404040"],
[style*="background: #404040"],
[style*="background:#404040"] {
    background-color: transparent !important;
    background: transparent !important;
}

/* Remove any grey backgrounds */
[style*="grey"],
[style*="gray"],
[style*="#404"],
[style*="rgb(64,"] {
    background-color: transparent !important;
    background: transparent !important;
}

#footer .nav-link {
    color: var(--text-gray) !important;
}

#footer .nav-link:hover {
    color: var(--primary-red) !important;
}

#footer .copyright {
    color: var(--text-gray) !important;
}

/* Main Body */
#main-body {
    background-color: transparent !important;
    background: transparent !important;
    position: relative;
    z-index: 1;
}

/* Ensure all sections and containers are transparent to show grid */
section,
main,
article,
aside,
.container,
.container-fluid,
.wrapper,
.content,
.page-content {
    background-color: transparent !important;
    background: transparent !important;
    position: relative;
    z-index: 1;
}

.primary-content {
    color: var(--text-white) !important;
}

/* Breadcrumb */
.master-breadcrumb,
.breadcrumb {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2);
    position: relative;
    z-index: 1;
}

.master-breadcrumb a {
    color: var(--text-gray) !important;
}

.master-breadcrumb a:hover {
    color: var(--primary-red) !important;
}

/* Buttons */
.btn {
    transition: all 0.3s;
}

.btn-outline-primary {
    border-color: var(--primary-red) !important;
    color: var(--primary-red) !important;
}

.btn-outline-primary:hover {
    background-color: var(--primary-red) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.btn-primary {
    background-color: var(--primary-red) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.btn-primary:hover {
    background-color: #c82333 !important;
    border-color: #c82333 !important;
}

.btn-default {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.btn-default:hover {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-color: var(--primary-red) !important;
}

/* Search Input */
.input-group .form-control {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.input-group-text {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Fix input group prepend/append borders */
.input-group-prepend .btn,
.input-group-append .btn {
    border-left: none !important;
}

.input-group-prepend + .form-control {
    border-left: none !important;
}

.input-group .form-control:not(:first-child) {
    border-left: none !important;
}

/* Action Icon Buttons */
.action-icon-btns a {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.action-icon-btns a:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
    color: var(--text-white) !important;
}

/* Text Colors */
.text-white {
    color: var(--text-white) !important;
}

.text-red {
    color: var(--primary-red) !important;
}

/* Sidebar */
.sidebar {
    background-color: transparent !important;
}

.sidebar .card-sidebar {
    background-color: transparent !important;
    border: 1px solid rgba(220, 53, 69, 0.2) !important;
}

.sidebar .card-header {
    background-color: transparent !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2) !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    color: var(--text-white) !important;
    padding: 0.75rem 1rem !important;
}

.sidebar .card-title {
    color: var(--text-white) !important;
    font-size: 1rem !important;
    font-weight: normal !important;
}

.sidebar .card-title i {
    color: var(--text-white) !important;
}

.sidebar .card-minimise {
    color: var(--text-white) !important;
}

.sidebar .list-group {
    background-color: transparent !important;
}

.sidebar .list-group-item {
    background-color: transparent !important;
    border: none !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
    box-shadow: none !important;
    outline: none !important;
}

.sidebar .list-group-item::before,
.sidebar .list-group-item::after {
    display: none !important;
    content: none !important;
}

.sidebar .list-group-item:hover {
    background-color: rgba(220, 53, 69, 0.1) !important;
    color: var(--text-white) !important;
    border: none !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2) !important;
    box-shadow: none !important;
    outline: none !important;
}

.sidebar .list-group-item:hover::before,
.sidebar .list-group-item:hover::after {
    display: none !important;
    content: none !important;
}

.sidebar .list-group-item.active {
    background-color: rgba(102, 26, 26, 0.8) !important;
    border: none !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
    box-shadow: none !important;
    outline: none !important;
}

.sidebar .list-group-item.active::before,
.sidebar .list-group-item.active::after {
    display: none !important;
    content: none !important;
}

.sidebar .list-group-item.active:hover {
    background-color: rgba(102, 26, 26, 0.9) !important;
    border: none !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2) !important;
    box-shadow: none !important;
    outline: none !important;
}

.sidebar .list-group-item.active:hover::before,
.sidebar .list-group-item.active:hover::after {
    display: none !important;
    content: none !important;
}

.sidebar .badge {
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* Fix ticket text overlay in sidebar */
.sidebar .list-group-item {
    overflow: hidden !important;
    word-wrap: break-word !important;
    max-width: 100% !important;
    padding-right: 0.75rem !important;
    padding-left: 0.75rem !important;
    position: relative !important;
    z-index: 1 !important;
}

.sidebar .list-group-item a {
    display: block !important;
    overflow: hidden !important;
    max-width: 100% !important;
    word-wrap: break-word !important;
}

.sidebar .list-group-item .ticket-number {
    display: inline-block !important;
    margin-right: 0.5rem !important;
    white-space: nowrap !important;
}

.sidebar .list-group-item .ticket-subject {
    display: inline-block !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    max-width: calc(100% - 100px) !important;
    vertical-align: top !important;
}

.sidebar .card-sidebar {
    overflow: visible !important;
    margin-bottom: 1.5rem !important;
    position: relative !important;
    z-index: 1 !important;
}

.sidebar .card-body {
    overflow: visible !important;
    padding: 0.75rem 1rem !important;
    position: relative !important;
}

.sidebar {
    position: relative !important;
    z-index: 1 !important;
}

.main-content {
    position: relative !important;
    z-index: 1 !important;
}

/* Fix ticket metadata text overflow */
.sidebar .list-group-item small,
.sidebar .list-group-item .text-muted,
.sidebar .list-group-item .text-gray {
    display: block !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    max-width: 100% !important;
    margin-top: 0.25rem !important;
    font-size: 0.875rem !important;
}

/* Ensure sidebar doesn't overflow into main content */
.sidebar {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

.sidebar * {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Alerts */
.alert {
    background-color: rgba(220, 53, 69, 0.15) !important;
    border: 1px solid rgba(220, 53, 69, 0.4) !important;
    color: var(--text-white) !important;
}

.alert-success {
    background-color: rgba(40, 167, 69, 0.15) !important;
    border-color: rgba(40, 167, 69, 0.4) !important;
    color: #90ee90 !important;
}

.alert-danger {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: rgba(220, 53, 69, 0.5) !important;
    color: #ff6b6b !important;
}

.alert-warning {
    background-color: rgba(255, 193, 7, 0.15) !important;
    border-color: rgba(255, 193, 7, 0.4) !important;
    color: #ffd700 !important;
}

.alert-info {
    background-color: rgba(23, 162, 184, 0.15) !important;
    border-color: rgba(23, 162, 184, 0.4) !important;
    color: #5dade2 !important;
}

/* Tables */
.table {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

.table thead th {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.table tbody td {
    background-color: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(255, 255, 255, 0.03) !important;
}

.table-hover tbody tr:hover {
    background-color: rgba(220, 53, 69, 0.1) !important;
}

/* Badges */
.badge {
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.badge-info {
    background-color: #17a2b8 !important;
}

.badge-success {
    background-color: #28a745 !important;
}

.badge-warning {
    background-color: #ffc107 !important;
    color: #000 !important;
}

.badge-danger {
    background-color: var(--primary-red) !important;
}

/* Dropdowns */
.dropdown-menu {
    background-color: var(--darker-bg) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.5) !important;
}

.dropdown-item {
    color: var(--text-white) !important;
    background-color: transparent !important;
    padding: 0.5rem 1rem !important;
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

.dropdown-item::before,
.dropdown-item::after {
    display: none !important;
    content: none !important;
}

.dropdown-item a,
.dropdown-item a:hover,
a.dropdown-item,
a.dropdown-item:hover {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    background-color: transparent !important;
    text-decoration: none !important;
}

.dropdown-item a::before,
.dropdown-item a::after,
a.dropdown-item::before,
a.dropdown-item::after {
    display: none !important;
    content: none !important;
}

.dropdown-item:hover a,
.dropdown-item:focus a {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: rgba(102, 26, 26, 0.8) !important;
    color: var(--text-white) !important;
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

.dropdown-item:hover::before,
.dropdown-item:hover::after,
.dropdown-item:focus::before,
.dropdown-item:focus::after {
    display: none !important;
    content: none !important;
}

.dropdown-item.active,
.dropdown-item:active {
    background-color: rgba(102, 26, 26, 0.8) !important;
    color: var(--text-white) !important;
    border: none !important;
}

.dropdown-divider {
    border-top-color: rgba(220, 53, 69, 0.2) !important;
    margin: 0.5rem 0 !important;
}

/* Dropdown Toggle */
.dropdown-toggle::after {
    border-top-color: var(--text-white) !important;
}

.dropdown-toggle:hover::after {
    border-top-color: var(--text-white) !important;
}

/* Account Dropdown in Header */
.header .dropdown-menu {
    margin-top: 0.5rem !important;
}

.header .dropdown-toggle {
    color: var(--text-white) !important;
  text-decoration: none;
}

.header .dropdown-toggle:hover {
    color: var(--text-white) !important;
}

/* Fix #order-standard_cart creating stacking context that traps modals */
#order-standard_cart,
#order-standard_cart .cart-body,
#order-standard_cart .cart-sidebar,
#order-standard_cart .secondary-cart-body,
#order-standard_cart .secondary-cart-sidebar {
    position: static !important;
}

/* Modals - Highest z-index to appear above everything */
.modal,
.modal.fade,
.modal.show,
.modal.in,
.modal-remove-item,
#modalRemoveItem,
#modalEmptyCart,
body > .modal,
body > form > .modal,
body > form > .modal-remove-item {
    z-index: 999999 !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    pointer-events: auto !important;
}

.modal-dialog,
.modal-remove-item .modal-dialog,
#modalRemoveItem .modal-dialog {
    z-index: 1000000 !important;
    position: relative !important;
    pointer-events: auto !important;
}

.modal-content,
.modal-remove-item .modal-content,
#modalRemoveItem .modal-content {
    background-color: var(--darker-bg) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
    pointer-events: auto !important;
    position: relative !important;
    z-index: 1000001 !important;
}

.modal-header {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.modal-body {
    background-color: var(--darker-bg) !important;
    color: var(--text-white) !important;
}

.modal-footer {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-top: 1px solid rgba(220, 53, 69, 0.2) !important;
    pointer-events: auto !important;
    z-index: 1000002 !important;
    position: relative !important;
}

.modal-footer button,
.modal-footer .btn,
.modal-footer input[type="submit"],
.modal-footer input[type="button"] {
    pointer-events: auto !important;
    z-index: 1000003 !important;
    position: relative !important;
}

.modal-backdrop,
.modal-backdrop.fade,
.modal-backdrop.show,
.modal-backdrop.in {
    background-color: rgba(0, 0, 0, 0.8) !important;
    z-index: 999998 !important;
}

.modal-title {
    color: var(--text-white) !important;
}

.modal .close {
    color: var(--text-white) !important;
    opacity: 0.8;
}

.modal .close:hover {
    opacity: 1;
    color: var(--primary-red) !important;
}

/* List Groups */
.list-group {
    background-color: transparent !important;
}

.list-group-item {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: none !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.list-group-item:hover {
    background-color: rgba(220, 53, 69, 0.1) !important;
    border: none !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2) !important;
}

.list-group-item.active {
    background-color: rgba(220, 53, 69, 0.3) !important;
    border: none !important;
    color: var(--text-white) !important;
}

.list-group-item.active:hover {
    border: none !important;
}

/* Pagination */
.pagination .page-link {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.pagination .page-link:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.pagination .page-item.active .page-link {
    background-color: var(--primary-red) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* Tabs */
.nav-tabs {
    border-bottom-color: rgba(220, 53, 69, 0.2) !important;
}

.nav-tabs .nav-link {
    color: var(--text-gray) !important;
    border-color: transparent !important;
}

.nav-tabs .nav-link:hover {
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.nav-tabs .nav-link.active {
    background-color: transparent !important;
    border-color: var(--primary-red) var(--primary-red) transparent !important;
    color: var(--primary-red) !important;
}

.tab-content {
    color: var(--text-white) !important;
}

/* Popover */
.popover {
    background-color: var(--darker-bg) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.popover-header {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-bottom-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.popover-body {
    color: var(--text-white) !important;
}

/* Tooltip */
.tooltip .tooltip-inner {
    background-color: var(--darker-bg) !important;
    color: var(--text-white) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

.tooltip .arrow::before {
    border-top-color: var(--darker-bg) !important;
}

/* Select/Dropdown */
select.form-control {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

select.form-control option {
    background-color: var(--darker-bg) !important;
    color: var(--text-white) !important;
}

/* Text */
.primary-content p,
.primary-content span:not(.badge):not(.text-red):not(.text-white),
.primary-content li,
.card-body p,
.card-body li {
    color: var(--text-white) !important;
}

.text-muted {
    color: var(--text-gray) !important;
}

.text-secondary {
    color: var(--text-gray) !important;
}

/* Ensure all text in main content is white */
.primary-content,
.primary-content *:not(.btn):not(.badge):not(.text-red):not(.text-muted):not(.text-secondary):not(a) {
    color: var(--text-white) !important;
}

/* Container */
.container, .container-fluid {
    background-color: transparent !important;
}

/* Shopping Cart */
.cart-btn {
    color: var(--text-white) !important;
}

/* Input Groups */
.input-group-prepend .btn,
.input-group-append .btn {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Labels */
label {
    color: var(--text-white) !important;
}

/* Checkboxes and Radios */
.form-check-label {
    color: var(--text-white) !important;
}

/* Code/Pre */
code, pre {
    background-color: rgba(255, 255, 255, 0.05) !important;
    color: var(--text-white) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
}

/* Blockquote */
blockquote {
    border-left-color: var(--primary-red) !important;
    color: var(--text-gray) !important;
}

/* HR */
hr {
    border-top-color: rgba(220, 53, 69, 0.2) !important;
}

/* Additional Global Overrides */
.row {
    background-color: transparent !important;
}

.col, .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12,
.col-sm, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12,
.col-md, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12,
.col-lg, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12,
.col-xl, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12 {
    background-color: transparent !important;
}

/* Panel (legacy WHMCS) */
.panel, .panel-default, .panel-primary, .panel-success, .panel-info, .panel-warning, .panel-danger {
    background-color: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.panel-heading {
    background-color: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
    box-shadow: none !important;
    outline: none !important;
}

.panel-title {
    background-color: transparent !important;
    background: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
    box-shadow: none !important;
    outline: none !important;
}

.panel-title::before,
.panel-title::after,
.panel-heading::before,
.panel-heading::after {
    display: none !important;
    content: none !important;
    background: none !important;
}

.panel-title:hover,
.panel-heading:hover {
    box-shadow: none !important;
    outline: none !important;
    border: none !important;
}

.panel-title:hover::before,
.panel-title:hover::after,
.panel-heading:hover::before,
.panel-heading:hover::after {
    display: none !important;
    content: none !important;
}

/* Card Title - Remove squares */
.card-title,
.panel-title,
h3.panel-title,
h3.card-title {
    box-shadow: none !important;
    outline: none !important;
    border: none !important;
}

.card-title::before,
.card-title::after,
h3.panel-title::before,
h3.panel-title::after,
h3.card-title::before,
h3.card-title::after {
    display: none !important;
    content: none !important;
    background: none !important;
}

.card-title:hover,
.panel-title:hover,
h3.panel-title:hover,
h3.card-title:hover {
    box-shadow: none !important;
    outline: none !important;
    border: none !important;
}

.card-title:hover::before,
.card-title:hover::after,
.panel-title:hover::before,
.panel-title:hover::after,
h3.panel-title:hover::before,
h3.panel-title:hover::after,
h3.card-title:hover::before,
h3.card-title:hover::after {
    display: none !important;
    content: none !important;
}

/* Remove squares from text within titles */
.panel-title *,
.card-title *,
h3.panel-title *,
h3.card-title * {
    box-shadow: none !important;
    outline: none !important;
    border: none !important;
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
}

.panel-title *::before,
.panel-title *::after,
.card-title *::before,
.card-title *::after {
    display: none !important;
    content: none !important;
    background: none !important;
    background-color: transparent !important;
}

/* Force remove any background from text nodes and inline elements */
.panel-title,
.card-title,
h3.panel-title,
h3.card-title {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
}

/* Remove backgrounds from all child elements including text nodes */
.panel-title span,
.panel-title i,
.panel-title a,
.card-title span,
.card-title i,
.card-title a,
h3.panel-title span,
h3.panel-title i,
h3.panel-title a {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
    box-shadow: none !important;
    outline: none !important;
    border: none !important;
}

.panel-body {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

.panel-footer {
    background-color: transparent !important;
    border-top-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Well (legacy Bootstrap) */
.well {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Jumbotron */
.jumbotron {
    background-color: rgba(255, 255, 255, 0.05) !important;
    color: var(--text-white) !important;
}

/* Progress Bars */
.progress {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

.progress-bar {
    background-color: var(--primary-red) !important;
}

/* Breadcrumbs */
.breadcrumb {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
    color: var(--text-gray) !important;
    position: relative;
    z-index: 1;
}

.breadcrumb *,
.breadcrumb-item,
.master-breadcrumb * {
    background-color: transparent !important;
    background: transparent !important;
}

.breadcrumb-item a {
    color: var(--text-gray) !important;
}

.breadcrumb-item.active {
    color: var(--text-white) !important;
}

.breadcrumb-item + .breadcrumb-item::before {
    color: var(--text-gray) !important;
}

/* Nav Pills */
.nav-pills .nav-link {
    color: var(--text-gray) !important;
}

.nav-pills .nav-link.active {
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* Accordion */
.accordion .card {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
}

.accordion .card-header {
    background-color: rgba(255, 255, 255, 0.08) !important;
    border-bottom-color: rgba(220, 53, 69, 0.2) !important;
}

/* Carousel */
.carousel {
    background-color: transparent !important;
}

.carousel-item {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
    filter: invert(1);
}

/* Spinner/Loader */
.spinner-border, .spinner-grow {
    color: var(--primary-red) !important;
}

/* Close Button */
.close {
    color: var(--text-white) !important;
    opacity: 0.8;
}

.close:hover {
    opacity: 1;
    color: var(--primary-red) !important;
}

/* Figure */
figure {
    background-color: transparent !important;
}

figcaption {
    color: var(--text-gray) !important;
}

/* Mark/Highlight */
mark {
    background-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Small text */
small, .small {
    color: var(--text-gray) !important;
}

/* Abbr */
abbr[title] {
    border-bottom-color: var(--primary-red) !important;
}

/* KBD */
kbd {
    background-color: var(--darker-bg) !important;
    color: var(--text-white) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
}

/* Sample */
samp {
    background-color: rgba(255, 255, 255, 0.05) !important;
    color: var(--text-white) !important;
}

/* Variable */
var {
    color: var(--primary-red) !important;
}

/* Address */
address {
    color: var(--text-white) !important;
}

/* Definition Lists */
dl, dt, dd {
    color: var(--text-white) !important;
}

/* Fieldset */
fieldset {
    border-color: rgba(220, 53, 69, 0.2) !important;
}

legend {
    color: var(--text-white) !important;
}

/* Summary */
summary {
    color: var(--text-white) !important;
}

/* Details */
details {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Output */
output {
    color: var(--text-white) !important;
}

/* Meter */
meter {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

meter::-webkit-meter-bar {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

meter::-webkit-meter-optimum-value {
    background-color: var(--primary-red) !important;
}

/* Progress (additional) */
progress {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

progress::-webkit-progress-bar {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

progress::-webkit-progress-value {
    background-color: var(--primary-red) !important;
}

/* WHMCS Specific Elements */
.client-alerts {
    background-color: var(--darker-bg) !important;
    color: var(--text-white) !important;
}

.client-alerts li {
    background-color: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.client-alerts li a {
    color: var(--text-white) !important;
}

/* Domain Search */
.domain-search-container {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
}

/* Product Cards */
.pricing-card-title {
    color: var(--text-white) !important;
}

/* Pricing boxes and product cards */
.pricing-box,
.pricing-item,
.plan,
.product-card,
.product-item {
    background-color: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.pricing-box *,
.pricing-item *,
.plan *,
.product-card *,
.product-item * {
    background-color: transparent !important;
}

.pricing-box .header,
.pricing-box .price,
.pricing-item .header,
.pricing-item .price,
.plan .plan-header,
.plan .plan-price {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

/* Product elements (store pages) */
.product {
    background-color: transparent !important;
    background: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.product * {
    background-color: transparent !important;
    background: transparent !important;
}

.product header,
.product .product-desc,
.product footer,
.product .product-pricing,
.product .price {
    background-color: transparent !important;
    background: transparent !important;
    color: var(--text-white) !important;
}

.product ul,
.product li {
    background-color: transparent !important;
    background: transparent !important;
    color: var(--text-white) !important;
}

.product .feature-value {
    background-color: transparent !important;
    background: transparent !important;
    color: var(--text-white) !important;
}

/* Action Icon Buttons (homepage) */
.card-accent-teal,
.card-accent-pomegranate,
.card-accent-sun-flower,
.card-accent-asbestos,
.card-accent-green,
.card-accent-midnight-blue {
    background-color: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.card-accent-teal:hover,
.card-accent-pomegranate:hover,
.card-accent-sun-flower:hover,
.card-accent-asbestos:hover,
.card-accent-green:hover,
.card-accent-midnight-blue:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
}

/* Network Issues Alert */
.network-issue-alert {
    background-color: rgba(255, 193, 7, 0.15) !important;
    border-color: rgba(255, 193, 7, 0.4) !important;
    color: #ffd700 !important;
}

.network-issue-alert .alert-link {
    color: #ffd700 !important;
}

/* Invoice Elements */
.invoice-summary-table {
    background-color: transparent !important;
}

.invoice-summary-table td,
.invoice-summary-table th {
    background-color: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Ticket System */
.ticket-reply {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Knowledge Base */
.kb-category,
.kb-article-item {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.kb-article-item:hover {
    background-color: rgba(220, 53, 69, 0.1) !important;
}

/* Announcements */
.announcement {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Domain Pricing */
.domain-pricing,
.featured-tlds-container,
.featured-tld {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Store Elements */
.store-order-container {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Credit Card Form */
.credit-card {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Promo Banners */
.promo-banner,
.promo-container {
    background-color: rgba(255, 255, 255, 0.05) !important;
    color: var(--text-white) !important;
}

/* Verification Banner */
.verification-banner {
    background-color: rgba(255, 255, 255, 0.08) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Social Login Buttons */
.social-signin-btns .btn,
.btn-social {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Two-Factor Auth */
.twofa-setup,
.twofa-module {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Loading Overlay */
#fullpage-overlay {
    background-color: rgba(0, 0, 0, 0.9) !important;
    color: var(--text-white) !important;
}

/* System Modal */
.system-modal .modal-content {
    background-color: var(--darker-bg) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Language/Currency Modal */
.modal-localisation .modal-content {
    background-color: var(--darker-bg) !important;
    color: var(--text-white) !important;
}

.modal-localisation .item-selector .item {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.modal-localisation .item-selector .item:hover,
.modal-localisation .item-selector .item.active {
    background-color: rgba(220, 53, 69, 0.3) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* Return to Admin Button */
.btn-return-to-admin {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Active Client Display */
.active-client .input-group-text {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.btn-active-client {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Cart Badge */
#cartItemCount {
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* Notification Popover */
#accountNotificationsContent {
    background-color: var(--darker-bg) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#accountNotificationsContent .client-alerts {
    background-color: var(--darker-bg) !important;
    color: var(--text-white) !important;
}

#accountNotificationsContent .client-alerts li {
    background-color: transparent !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

#accountNotificationsContent .client-alerts li:last-child {
    border-bottom: none !important;
}

#accountNotificationsContent .client-alerts li a {
    background-color: transparent !important;
    color: var(--text-white) !important;
    padding: 0.75rem 1rem !important;
    display: block !important;
}

#accountNotificationsContent .client-alerts li a:hover {
    background-color: rgba(220, 53, 69, 0.1) !important;
    color: var(--text-white) !important;
}

#accountNotificationsContent .client-alerts li a .message {
    color: var(--text-white) !important;
}

#accountNotificationsContent .client-alerts li a i {
    color: var(--text-white) !important;
}

/* Remove white overlays from notifications */
#accountNotificationsContent .client-alerts li::before,
#accountNotificationsContent .client-alerts li::after,
#accountNotificationsContent .client-alerts li a::before,
#accountNotificationsContent .client-alerts li a::after {
    display: none !important;
    content: none !important;
    background: none !important;
}

/* Popover styling */
.popover,
.popover-content {
    background-color: var(--darker-bg) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.popover .popover-header {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-bottom-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.popover .popover-body {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

.popover .arrow::before,
.popover .arrow::after {
    border-color: rgba(220, 53, 69, 0.3) !important;
}

/* Remove any white backgrounds from popover */
.popover * {
    background-color: transparent !important;
}

.popover .client-alerts {
    background-color: transparent !important;
}

/* Force remove white overlays from notification items */
#accountNotificationsContent .client-alerts li,
#accountNotificationsContent .client-alerts li a,
.popover .client-alerts li,
.popover .client-alerts li a {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
}

#accountNotificationsContent .client-alerts li:hover,
#accountNotificationsContent .client-alerts li a:hover,
.popover .client-alerts li:hover,
.popover .client-alerts li a:hover {
    background-color: rgba(220, 53, 69, 0.1) !important;
    background: rgba(220, 53, 69, 0.1) !important;
}

/* Remove any overlay divs */
#accountNotificationsContent .client-alerts li > div,
.popover .client-alerts li > div {
    background-color: transparent !important;
    background: transparent !important;
}

/* Notification icons */
#accountNotificationsContent .client-alerts li a i.fa-info-circle,
#accountNotificationsContent .client-alerts li a i.fa-exclamation-triangle,
#accountNotificationsContent .client-alerts li a i.fa-exclamation-circle,
#accountNotificationsContent .client-alerts li a i.fa-check-circle {
    color: var(--text-white) !important;
}

/* Any remaining white backgrounds */
[style*="background-color: white"],
[style*="background-color: #fff"],
[style*="background-color: #ffffff"],
[style*="background: white"],
[style*="background: #fff"],
[style*="background: #ffffff"] {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

/* Any remaining light backgrounds */
[style*="background-color: #f"],
[style*="background: #f"] {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

/* Sub-heading (Section Headers) */
.sub-heading {
    height: 0 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.2) !important;
    text-align: center !important;
    margin-top: 20px !important;
    margin-bottom: 30px !important;
    background-color: transparent !important;
}

.sub-heading span {
    display: inline-block !important;
  position: relative !important;
    padding: 0 17px !important;
    top: -11px !important;
  font-size: 16px !important;
    color: var(--text-white) !important;
    background-color: var(--dark-bg) !important;
}

.sub-heading-borderless {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

/* Primary BG Color Override */
.primary-bg-color {
    background-color: var(--dark-bg) !important;
    color: var(--text-white) !important;
}

/* Range Slider Styling */
input[type="range"],
.custom-range,
.form-control-range {
    background-color: transparent !important;
}

/* Webkit (Chrome, Safari, Edge) */
.custom-range::-webkit-slider-runnable-track {
    background-color: rgba(255, 255, 255, 0.2) !important;
    height: 0.5rem !important;
    border-radius: 1rem !important;
}

.custom-range::-webkit-slider-thumb {
    width: 1.2rem !important;
    height: 1.2rem !important;
    background-color: var(--text-white) !important;
    border: 2px solid var(--primary-red) !important;
    border-radius: 50% !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    cursor: pointer !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
}

.custom-range::-webkit-slider-thumb:active {
    background-color: var(--primary-red) !important;
    border-color: var(--text-white) !important;
}

.custom-range:focus::-webkit-slider-thumb {
    box-shadow: 0 0 0 1px var(--text-white), 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
}

/* Firefox */
.custom-range::-moz-range-track {
    background-color: rgba(255, 255, 255, 0.2) !important;
    height: 0.5rem !important;
    border-radius: 1rem !important;
    border: none !important;
}

.custom-range::-moz-range-progress {
    background-color: var(--primary-red) !important;
    height: 0.5rem !important;
    border-radius: 1rem !important;
}

.custom-range::-moz-range-thumb {
    width: 1.2rem !important;
    height: 1.2rem !important;
    background-color: var(--text-white) !important;
    border: 2px solid var(--primary-red) !important;
    border-radius: 50% !important;
    -moz-appearance: none !important;
    appearance: none !important;
    cursor: pointer !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
}

.custom-range::-moz-range-thumb:active {
    background-color: var(--primary-red) !important;
    border-color: var(--text-white) !important;
}

/* IE/Edge */
.custom-range::-ms-track {
    background-color: rgba(255, 255, 255, 0.2) !important;
    height: 0.5rem !important;
    border-radius: 1rem !important;
    border: none !important;
    color: transparent !important;
}

.custom-range::-ms-fill-lower {
    background-color: var(--primary-red) !important;
    border-radius: 1rem !important;
}

.custom-range::-ms-fill-upper {
    background-color: rgba(255, 255, 255, 0.2) !important;
    border-radius: 1rem !important;
}

.custom-range::-ms-thumb {
    width: 1.2rem !important;
    height: 1.2rem !important;
    background-color: var(--text-white) !important;
    border: 2px solid var(--primary-red) !important;
    border-radius: 50% !important;
    appearance: none !important;
    cursor: pointer !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
}

.custom-range::-ms-thumb:active {
    background-color: var(--primary-red) !important;
    border-color: var(--text-white) !important;
}

/* Range Slider Labels/Value Boxes */
.range-slider-label,
.range-value-box,
.irs-min,
.irs-max {
    background-color: rgba(255, 255, 255, 0.1) !important;
    color: var(--text-white) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    border-radius: 4px !important;
}

/* Range Slider Value Indicator/Tooltip */
.irs-handle,
.irs-handle-single {
    background-color: var(--text-white) !important;
    border: 2px solid var(--primary-red) !important;
}

.irs-bar,
.irs-bar-edge {
    background-color: var(--primary-red) !important;
    background: var(--primary-red) !important;
}

.irs-bar,
.irs-bar-edge,
.irs-bar-mid {
    background: var(--primary-red) !important;
    background-color: var(--primary-red) !important;
    background-image: none !important;
}

/* Remove any green colors from sliders */
.irs-bar[style*="green"],
.irs-bar[style*="Green"],
.irs-bar[style*="#28a745"],
.irs-bar[style*="#28A745"] {
    background-color: var(--primary-red) !important;
    background: var(--primary-red) !important;
}

.irs-line {
    background-color: rgba(255, 255, 255, 0.2) !important;
}

.irs-from,
.irs-to,
.irs-single {
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.irs-grid-pol {
    background-color: rgba(255, 255, 255, 0.3) !important;
}

.irs-grid-text {
    color: var(--text-white) !important;
}

/* Configurable Options Range Slider */
.configoption-range-wrapper,
.configoption-range {
    background-color: transparent !important;
}

.configoption-range-label {
    color: var(--text-white) !important;
}

.configoption-range-value {
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    border: none !important;
}

/* Ion Range Slider Library Styling */
.irs {
    background-color: transparent !important;
}

.irs-line {
    background-color: rgba(255, 255, 255, 0.2) !important;
    border: none !important;
    height: 0.5rem !important;
}

.irs-bar {
    background-color: var(--primary-red) !important;
    background: var(--primary-red) !important;
    background-image: none !important;
    height: 0.5rem !important;
}

.irs-bar-edge {
    background-color: var(--primary-red) !important;
    background: var(--primary-red) !important;
    background-image: none !important;
    border: none !important;
}

/* Force remove any gradient or green colors from slider bar */
.irs-bar,
.irs-bar-edge,
.irs-bar-mid,
.irs-bar[class*="bar"],
.irs-bar[style*="gradient"],
.irs-bar[style*="green"],
.irs-bar[style*="#28a745"],
.irs-bar[style*="#28A745"] {
    background: var(--primary-red) !important;
    background-color: var(--primary-red) !important;
    background-image: none !important;
    background-image: linear-gradient(to bottom, var(--primary-red), var(--primary-red)) !important;
}

/* Override any inline styles that might add green */
.irs-bar::before,
.irs-bar::after,
.irs-bar-edge::before,
.irs-bar-edge::after {
    display: none !important;
}

.irs-handle {
    background-color: var(--text-white) !important;
    border: 2px solid var(--primary-red) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
    width: 20px !important;
    height: 20px !important;
    top: 18px !important;
}

.irs-handle:hover {
    background-color: var(--primary-red) !important;
    border-color: var(--text-white) !important;
}

.irs-handle.state_hover,
.irs-handle.state_hover:hover {
    background-color: var(--primary-red) !important;
}

.irs-from,
.irs-to,
.irs-single {
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    border: none !important;
}

.irs-from:after,
.irs-to:after,
.irs-single:after {
    border-top-color: var(--primary-red) !important;
}

.irs-min,
.irs-max {
    background-color: rgba(255, 255, 255, 0.1) !important;
    color: var(--text-white) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    border-radius: 4px !important;
    padding: 2px 8px !important;
}

.irs-grid-pol {
    background-color: rgba(255, 255, 255, 0.3) !important;
}

.irs-grid-text {
    color: var(--text-white) !important;
}

/* Range Input Fill (for browsers that support it) */
input[type="range"]::-webkit-slider-runnable-track {
    background: linear-gradient(to right, var(--primary-red) 0%, var(--primary-red) var(--value, 0%), rgba(255, 255, 255, 0.2) var(--value, 0%), rgba(255, 255, 255, 0.2) 100%) !important;
}

/* Promo Code Section */
.view-cart-tabs {
    background-color: transparent !important;
}

.view-cart-tabs .nav-tabs {
    border-bottom-color: rgba(220, 53, 69, 0.3) !important;
}

.view-cart-tabs .nav-link {
    color: var(--text-white) !important;
    background-color: transparent !important;
    border-color: transparent !important;
}

.view-cart-tabs .nav-link:hover,
.view-cart-tabs .nav-link:focus {
    color: var(--primary-red) !important;
    background-color: rgba(220, 53, 69, 0.1) !important;
    border-color: transparent transparent rgba(220, 53, 69, 0.3) !important;
}

.view-cart-tabs .nav-link.active {
    color: var(--primary-red) !important;
    background-color: transparent !important;
    border-color: transparent transparent var(--primary-red) !important;
    border-bottom-width: 2px !important;
}

.view-cart-tabs .tab-content {
    background-color: transparent !important;
}

.view-cart-tabs .tab-pane {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

/* Promo Code Input Field */
#inputPromotionCode,
input[name="promocode"],
.view-cart-tabs input[type="text"].form-control,
.view-cart-tabs .field.form-control {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#inputPromotionCode::placeholder,
input[name="promocode"]::placeholder,
.view-cart-tabs input[type="text"].form-control::placeholder,
.view-cart-tabs .field.form-control::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
}

#inputPromotionCode:focus,
input[name="promocode"]:focus,
.view-cart-tabs input[type="text"].form-control:focus,
.view-cart-tabs .field.form-control:focus {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
}

/* Promo Code Button */
.view-cart-tabs button[name="validatepromo"],
.view-cart-tabs .btn-default,
.view-cart-tabs .btn-block {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.view-cart-tabs button[name="validatepromo"]:hover,
.view-cart-tabs .btn-default:hover,
.view-cart-tabs .btn-block:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* Applied Promo Code Display */
.view-cart-promotion-code {
    background-color: rgba(220, 53, 69, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
    padding: 0.75rem !important;
    border-radius: 4px !important;
    margin-bottom: 1rem !important;
}

/* Promo Code Form Group */
.view-cart-tabs .form-group,
.view-cart-tabs .prepend-icon {
    background-color: transparent !important;
}

.view-cart-tabs .field-icon {
    color: var(--text-white) !important;
}

.view-cart-tabs .field-icon i {
    color: rgba(255, 255, 255, 0.7) !important;
}

/* Checkout Form Styling - Dark Theme */
#order-standard_cart .field,
#order-standard_cart input[type="text"],
#order-standard_cart input[type="email"],
#order-standard_cart input[type="tel"],
#order-standard_cart input[type="password"],
#order-standard_cart input[type="number"],
#order-standard_cart textarea,
#order-standard_cart select,
#order-standard_cart .form-control {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#order-standard_cart .field::placeholder,
#order-standard_cart input[type="text"]::placeholder,
#order-standard_cart input[type="email"]::placeholder,
#order-standard_cart input[type="tel"]::placeholder,
#order-standard_cart input[type="password"]::placeholder,
#order-standard_cart input[type="number"]::placeholder,
#order-standard_cart textarea::placeholder,
#order-standard_cart .form-control::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
}

#order-standard_cart .field:focus,
#order-standard_cart input[type="text"]:focus,
#order-standard_cart input[type="email"]:focus,
#order-standard_cart input[type="tel"]:focus,
#order-standard_cart input[type="password"]:focus,
#order-standard_cart input[type="number"]:focus,
#order-standard_cart textarea:focus,
#order-standard_cart select:focus,
#order-standard_cart .form-control:focus {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
    outline: none !important;
}

/* Select Dropdowns */
#order-standard_cart select,
#order-standard_cart select.form-control,
#order-standard_cart select.field {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 0.75rem center !important;
    background-size: 12px !important;
    color: var(--text-white) !important;
    padding-right: 2.5rem !important;
}

#order-standard_cart select option {
    background-color: var(--dark-bg) !important;
    color: var(--text-white) !important;
}

/* Field Icons */
#order-standard_cart .field-icon,
#order-standard_cart .field-icon i,
#order-standard_cart .prepend-icon .field-icon {
    color: rgba(255, 255, 255, 0.7) !important;
}

/* Form Groups */
#order-standard_cart .form-group {
    background-color: transparent !important;
}

#order-standard_cart .prepend-icon {
    background-color: transparent !important;
}

/* Buttons */
#order-standard_cart .btn-info,
#order-standard_cart .btn-warning,
#order-standard_cart .btn-primary,
#order-standard_cart .btn-default,
#order-standard_cart .btn-success {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#order-standard_cart .btn-info:hover,
#order-standard_cart .btn-warning:hover,
#order-standard_cart .btn-primary:hover,
#order-standard_cart .btn-default:hover,
#order-standard_cart .btn-success:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

#order-standard_cart .btn-primary {
    background-color: var(--primary-red) !important;
    border-color: var(--primary-red) !important;
}

#order-standard_cart .btn-primary:hover {
    background-color: rgba(220, 53, 69, 0.8) !important;
    border-color: rgba(220, 53, 69, 0.8) !important;
}

/* Radio Buttons and Checkboxes */
#order-standard_cart input[type="radio"],
#order-standard_cart input[type="checkbox"] {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

#order-standard_cart input[type="radio"]:checked,
#order-standard_cart input[type="checkbox"]:checked {
    background-color: var(--primary-red) !important;
    border-color: var(--primary-red) !important;
}

/* Labels */
#order-standard_cart label,
#order-standard_cart .control-label,
#order-standard_cart .col-form-label {
    color: var(--text-white) !important;
}

/* Text Muted */
#order-standard_cart .text-muted,
#order-standard_cart .small.text-muted {
    color: rgba(255, 255, 255, 0.6) !important;
}

/* Account Select Cards */
#order-standard_cart .account {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#order-standard_cart .account.active {
    border-color: var(--primary-red) !important;
    background-color: rgba(220, 53, 69, 0.1) !important;
}

#order-standard_cart .account .address {
    color: var(--text-white) !important;
}

/* Sub Headings */
#order-standard_cart .sub-heading {
    color: var(--text-white) !important;
}

#order-standard_cart .sub-heading span {
    color: var(--text-white) !important;
    background-color: var(--dark-bg) !important;
}

/* Alerts */
#order-standard_cart .alert {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#order-standard_cart .alert-danger {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
}

#order-standard_cart .alert-success {
    background-color: rgba(40, 167, 69, 0.2) !important;
    border-color: rgba(40, 167, 69, 0.5) !important;
}

#order-standard_cart .alert-info {
    background-color: rgba(23, 162, 184, 0.2) !important;
    border-color: rgba(23, 162, 184, 0.5) !important;
}

/* Input Groups */
#order-standard_cart .input-group .form-control,
#order-standard_cart .input-group .field {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#order-standard_cart .input-group-btn .btn,
#order-standard_cart .input-group-append .btn {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Progress Bars */
#order-standard_cart .progress {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

#order-standard_cart .progress-bar {
    background-color: var(--primary-red) !important;
}

/* Dropdown Menus */
#order-standard_cart .dropdown-menu {
    background-color: var(--darker-bg) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
}

#order-standard_cart .dropdown-item {
    color: var(--text-white) !important;
}

#order-standard_cart .dropdown-item:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

/* Register Page Form Styling - Dark Theme */
#registration .field,
#registration input[type="text"],
#registration input[type="email"],
#registration input[type="tel"],
#registration input[type="password"],
#registration input[type="number"],
#registration textarea,
#registration select,
#registration .form-control {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#registration .field::placeholder,
#registration input[type="text"]::placeholder,
#registration input[type="email"]::placeholder,
#registration input[type="tel"]::placeholder,
#registration input[type="password"]::placeholder,
#registration input[type="number"]::placeholder,
#registration textarea::placeholder,
#registration .form-control::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
}

#registration .field:focus,
#registration input[type="text"]:focus,
#registration input[type="email"]:focus,
#registration input[type="tel"]:focus,
#registration input[type="password"]:focus,
#registration input[type="number"]:focus,
#registration textarea:focus,
#registration select:focus,
#registration .form-control:focus {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
    outline: none !important;
}

/* Select Dropdowns */
#registration select,
#registration select.form-control,
#registration select.field {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 0.75rem center !important;
    background-size: 12px !important;
    color: var(--text-white) !important;
    padding-right: 2.5rem !important;
}

#registration select option {
    background-color: var(--dark-bg) !important;
    color: var(--text-white) !important;
}

/* Field Icons */
#registration .field-icon,
#registration .field-icon i,
#registration .prepend-icon .field-icon {
    color: rgba(255, 255, 255, 0.7) !important;
}

/* Form Groups */
#registration .form-group {
    background-color: transparent !important;
}

#registration .prepend-icon {
    background-color: transparent !important;
}

/* Cards */
#registration .card {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

#registration .card-body {
    background-color: transparent !important;
}

#registration .card-title {
    color: var(--text-white) !important;
}

/* Buttons */
#registration .btn-primary,
#registration .btn-default,
#registration .btn-success {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#registration .btn-primary:hover,
#registration .btn-default:hover,
#registration .btn-success:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

#registration .btn-primary {
    background-color: var(--primary-red) !important;
    border-color: var(--primary-red) !important;
}

#registration .btn-primary:hover {
    background-color: rgba(220, 53, 69, 0.8) !important;
    border-color: rgba(220, 53, 69, 0.8) !important;
}

/* Radio Buttons and Checkboxes */
#registration input[type="radio"],
#registration input[type="checkbox"],
#registration .form-check-input {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

#registration input[type="radio"]:checked,
#registration input[type="checkbox"]:checked,
#registration .form-check-input:checked {
    background-color: var(--primary-red) !important;
    border-color: var(--primary-red) !important;
}

/* Labels */
#registration label,
#registration .control-label,
#registration .col-form-label,
#registration .form-check label {
    color: var(--text-white) !important;
}

/* Text Muted */
#registration .text-muted,
#registration .small.text-muted {
    color: rgba(255, 255, 255, 0.6) !important;
}

/* Alerts */
#registration .alert {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

#registration .alert-danger {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
}

#registration .alert-success {
    background-color: rgba(40, 167, 69, 0.2) !important;
    border-color: rgba(40, 167, 69, 0.5) !important;
}

#registration .alert-info {
    background-color: rgba(23, 162, 184, 0.2) !important;
    border-color: rgba(23, 162, 184, 0.5) !important;
}

/* Progress Bars */
#registration .progress {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

#registration .progress-bar {
    background-color: var(--primary-red) !important;
}

#registration .bg-success {
    background-color: var(--primary-red) !important;
}

/* Field Help Text */
#registration .field-help-text {
    color: rgba(255, 255, 255, 0.6) !important;
}

/* Links */
#registration a {
    color: var(--primary-red) !important;
}

#registration a:hover {
    color: rgba(220, 53, 69, 0.8) !important;
}

/* Client Area Tiles (Summary Boxes) */
.tiles .tile {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.tiles .tile:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.tiles .tile i {
    color: var(--text-white) !important;
}

.tiles .tile .stat {
    color: var(--text-white) !important;
}

.tiles .tile .title {
    color: rgba(255, 255, 255, 0.8) !important;
}

.tiles .tile .highlight {
    background-color: var(--primary-red) !important;
}

.tiles .tile .bg-color-blue,
.tiles .tile .bg-color-green,
.tiles .tile .bg-color-red,
.tiles .tile .bg-color-gold {
    background-color: var(--primary-red) !important;
}

/* Client Area Buttons */
.btn-success {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.btn-success:hover,
.btn-success:focus {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.btn-success i,
.btn-success .fa,
.btn-success .fas,
.btn-success .far {
    color: var(--text-white) !important;
}

.btn-success:hover i,
.btn-success:hover .fa,
.btn-success:hover .fas,
.btn-success:hover .far {
    color: var(--text-white) !important;
}

/* Client Area Cards */
.client-home-cards .card {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

.client-home-cards .card-header {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.3) !important;
}

.client-home-cards .card-title {
    color: var(--text-white) !important;
}

.client-home-cards .card-body {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

.client-home-cards .card-footer {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-top: 1px solid rgba(220, 53, 69, 0.3) !important;
}

/* Sidebar Cards */
.card-sidebar {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

.card-sidebar .card-header {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-bottom: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.card-sidebar .card-title {
    color: var(--text-white) !important;
}

.card-sidebar .card-body {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

/* Sidebar Buttons */
.card-sidebar .btn,
.card-sidebar .btn-success,
.card-sidebar .btn-default {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.card-sidebar .btn:hover,
.card-sidebar .btn-success:hover,
.card-sidebar .btn-default:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.card-sidebar .btn i,
.card-sidebar .btn-success i,
.card-sidebar .btn-default i {
    color: var(--text-white) !important;
}

/* List Group Items in Sidebar */
.card-sidebar .list-group-item {
    background-color: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.card-sidebar .list-group-item:hover {
    background-color: rgba(220, 53, 69, 0.1) !important;
    color: var(--text-white) !important;
}

.card-sidebar .list-group-item.active {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* DataTables Search Input */
.dataTables_wrapper .dataTables_filter input,
.dataTables_filter input,
input[type="search"],
.dataTables_wrapper input[type="search"] {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
    padding: 0.375rem 0.75rem !important;
}

/* Input Group - Search Icon Background */
.dataTables_wrapper .input-group-prepend,
.dataTables_wrapper .input-group-append,
.dataTables_wrapper .input-group-text,
.input-group-prepend,
.input-group-append,
.input-group-text {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.dataTables_wrapper .input-group-prepend .input-group-text,
.dataTables_wrapper .input-group-append .input-group-text,
.input-group-prepend .input-group-text,
.input-group-append .input-group-text {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.dataTables_wrapper .input-group-prepend .input-group-text i,
.dataTables_wrapper .input-group-append .input-group-text i,
.input-group-prepend .input-group-text i,
.input-group-append .input-group-text i {
    color: var(--text-white) !important;
}

/* Ensure search input groups are dark */
.dataTables_wrapper .input-group .form-control:first-child,
.dataTables_wrapper .input-group .form-control:not(:first-child):not(:last-child),
.dataTables_wrapper .input-group .form-control:last-child {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Input Group Container */
.dataTables_wrapper .input-group,
.input-group {
    background-color: transparent !important;
}

/* Override any white backgrounds on input-group elements */
.dataTables_wrapper .input-group > *,
.input-group > * {
    background-color: transparent !important;
}

.dataTables_wrapper .input-group-prepend,
.dataTables_wrapper .input-group-append {
    background-color: transparent !important;
}

/* Force dark background on input-group-text specifically */
.dataTables_wrapper .input-group-text,
.input-group-text,
.dataTables_wrapper .input-group-prepend .input-group-text,
.dataTables_wrapper .input-group-append .input-group-text,
.input-group-prepend .input-group-text,
.input-group-append .input-group-text {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Override any white backgrounds with more specificity */
.dataTables_wrapper .dataTables_filter .input-group-text,
.dataTables_filter .input-group-text,
.dataTables_wrapper .input-group .input-group-text,
.input-group .input-group-text {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
}

/* Target the icon container specifically */
.dataTables_wrapper .input-group-prepend,
.dataTables_wrapper .input-group-append,
.input-group-prepend,
.input-group-append {
    background-color: transparent !important;
    background: transparent !important;
}

.dataTables_wrapper .input-group-prepend > *,
.dataTables_wrapper .input-group-append > *,
.input-group-prepend > *,
.input-group-append > * {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
}

/* Override Bootstrap's default white background */
.input-group-text[class*="bg-"],
.input-group-text.bg-white,
.input-group-text.bg-light {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
}

/* Nuclear option - target ALL possible white backgrounds */
* .input-group-text,
* .input-group-prepend,
* .input-group-append,
* .input-group-prepend *,
* .input-group-append *,
* .input-group-text * {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
}

/* Specifically target DataTables filter wrapper */
.dataTables_wrapper .dataTables_filter,
.dataTables_filter {
    background-color: transparent !important;
}

.dataTables_wrapper .dataTables_filter .input-group,
.dataTables_filter .input-group {
    background-color: transparent !important;
}

.dataTables_wrapper .dataTables_filter .input-group-prepend,
.dataTables_wrapper .dataTables_filter .input-group-append,
.dataTables_filter .input-group-prepend,
.dataTables_filter .input-group-append {
    background-color: transparent !important;
}

.dataTables_wrapper .dataTables_filter .input-group-prepend *:not(input):not(select):not(textarea),
.dataTables_wrapper .dataTables_filter .input-group-append *:not(input):not(select):not(textarea),
.dataTables_filter .input-group-prepend *:not(input):not(select):not(textarea),
.dataTables_filter .input-group-append *:not(input):not(select):not(textarea) {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
}

.dataTables_wrapper .dataTables_filter .input-group-text,
.dataTables_filter .input-group-text {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
}

/* Target label elements containing search inputs */
.dataTables_wrapper .dataTables_filter label,
.dataTables_filter label,
label:has(input[type="search"]),
label:has(.form-control[type="search"]) {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
}

/* Target the label wrapper specifically */
.dataTables_wrapper .dataTables_filter label input,
.dataTables_filter label input,
label input[type="search"] {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Remove any white backgrounds from label children except the input */
.dataTables_wrapper .dataTables_filter label > *:not(input):not(select):not(textarea),
.dataTables_filter label > *:not(input):not(select):not(textarea) {
    background-color: transparent !important;
    background: transparent !important;
}

/* Ensure the input itself has dark background */
.dataTables_wrapper .dataTables_filter label input[type="search"],
.dataTables_filter label input[type="search"],
label input[type="search"].form-control,
label input[type="search"].form-control-sm {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

/* Target any span or div inside input-group-prepend/append */
.input-group-prepend span,
.input-group-prepend div,
.input-group-append span,
.input-group-append div,
.dataTables_wrapper .input-group-prepend span,
.dataTables_wrapper .input-group-prepend div,
.dataTables_wrapper .input-group-append span,
.dataTables_wrapper .input-group-append div {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
}

/* Target pseudo-elements that might have white backgrounds */
.input-group-text::before,
.input-group-text::after,
.input-group-prepend::before,
.input-group-prepend::after,
.input-group-append::before,
.input-group-append::after,
.dataTables_wrapper .input-group-text::before,
.dataTables_wrapper .input-group-text::after {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
}

/* Remove any background images from icon containers */
.input-group-text i,
.input-group-text .fa,
.input-group-text .fas,
.input-group-text .far,
.input-group-prepend i,
.input-group-prepend .fa,
.input-group-prepend .fas,
.input-group-prepend .far,
.input-group-append i,
.input-group-append .fa,
.input-group-append .fas,
.input-group-append .far {
    background-color: transparent !important;
    background: transparent !important;
    background-image: none !important;
}

/* Target the parent of icons specifically */
.input-group-text:has(i),
.input-group-text:has(.fa),
.input-group-prepend:has(i),
.input-group-prepend:has(.fa),
.input-group-append:has(i),
.input-group-append:has(.fa) {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
}

/* Force all children of input-group-text to have transparent backgrounds except the container itself */
.input-group-text > * {
    background-color: transparent !important;
    background: transparent !important;
}

.input-group-text {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
}

.dataTables_wrapper .dataTables_filter input:focus,
.dataTables_filter input:focus,
input[type="search"]:focus,
.dataTables_wrapper input[type="search"]:focus {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
    outline: none !important;
}

.dataTables_wrapper .dataTables_filter input::placeholder,
.dataTables_filter input::placeholder,
input[type="search"]::placeholder,
.dataTables_wrapper input[type="search"]::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
}

/* DataTables Length Select */
.dataTables_wrapper .dataTables_length select,
.dataTables_length select {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.dataTables_wrapper .dataTables_length select:focus,
.dataTables_length select:focus {
    background-color: rgba(255, 255, 255, 0.15) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

/* Badge Styling - Override Green Paid Badges */
.badge-success,
.badge-paid,
.badge[class*="paid"],
.badge[class*="success"] {
    background-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
    border: 1px solid var(--primary-red) !important;
}

.badge-danger,
.badge-unpaid,
.badge[class*="unpaid"],
.badge[class*="danger"] {
    background-color: var(--primary-red) !important;
    color: var(--text-white) !important;
    border: 1px solid var(--primary-red) !important;
}

.badge-info,
.badge-warning,
.badge-secondary {
    background-color: rgba(255, 255, 255, 0.1) !important;
    color: var(--text-white) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

/* DataTables Table Styling */
.dataTables_wrapper .table {
    background-color: transparent !important;
    color: var(--text-white) !important;
}

.dataTables_wrapper .table thead th {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.dataTables_wrapper .table tbody td {
    background-color: transparent !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: var(--text-white) !important;
}

.dataTables_wrapper .table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(255, 255, 255, 0.03) !important;
}

.dataTables_wrapper .table-hover tbody tr:hover {
    background-color: rgba(220, 53, 69, 0.1) !important;
}

/* DataTables Pagination */
.dataTables_wrapper .dataTables_paginate .paginate_button {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    color: var(--text-white) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
    background-color: rgba(220, 53, 69, 0.2) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.current {
    background-color: var(--primary-red) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-white) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(220, 53, 69, 0.2) !important;
    color: rgba(255, 255, 255, 0.4) !important;
}

/* DataTables Info Text */
.dataTables_wrapper .dataTables_info {
    color: var(--text-white) !important;
}

/* DataTables Length Label */
.dataTables_wrapper .dataTables_length label {
    color: var(--text-white) !important;
}

.dataTables_wrapper .dataTables_length label select {
    color: var(--text-white) !important;
}

/* Responsive */
@media (max-width: 768px) {
    .hero-title {
        font-size: 2.5rem;
    }
    
    .hero-description {
        font-size: 1rem;
    }
    
    .section-title {
        font-size: 2rem;
    }
}
