/* FlexyNode WHMCS Custom Styles */

:root {
    --accent-start: #266AF2;
    --accent-end: #4E14E0;
    --bg-main: #0A0A0F;
    --bg-card: #11111A;
    --text-light: #E0E0E0;
    --text-muted: #9ca3af;
}

/* ========================================================================
   ORDERFORM SPECIFIC STYLING - BLACK TEXT ON WHITE BACKGROUND
   ======================================================================== */

/* Default: Force black text for main content areas in orderform */
body.cart-view .primary-content,
body.cart-view .card-body,
body.cart-view p,
body.cart-view label,
body.cart-view .form-label,
body.cart-view h1,
body.cart-view h2,
body.cart-view h3,
body.cart-view h4,
body.cart-view h5,
body.cart-view h6,
body.cart-view td,
body.cart-view th,
body.cart-view li,
body.cart-view span:not(.btn span):not(.badge span),
body.orderforms-view .primary-content,
body.orderforms-view .card-body,
body.orderforms-view p,
body.orderforms-view label,
body.orderforms-view .form-label,
body.orderforms-view h1,
body.orderforms-view h2,
body.orderforms-view h3,
body.orderforms-view h4,
body.orderforms-view h5,
body.orderforms-view h6,
body.orderforms-view td,
body.orderforms-view th,
body.orderforms-view li,
body.orderforms-view span:not(.btn span):not(.badge span),
#order-standard_cart .primary-content,
#order-standard_cart .card-body,
#order-standard_cart p,
#order-standard_cart label,
#order-standard_cart .form-label,
#order-standard_cart h1,
#order-standard_cart h2,
#order-standard_cart h3,
#order-standard_cart h4,
#order-standard_cart h5,
#order-standard_cart h6,
#order-standard_cart td,
#order-standard_cart th,
#order-standard_cart li,
#order-standard_cart span:not(.btn span):not(.badge span) {
    color: #000000 !important;
}

/* Exception: White text for secondary-cart-body (has dark background) */
body.cart-view .secondary-cart-body,
body.cart-view .secondary-cart-body p,
body.cart-view .secondary-cart-body label,
body.cart-view .secondary-cart-body span,
body.cart-view .secondary-cart-body input,
body.cart-view .secondary-cart-body select,
body.cart-view .secondary-cart-body textarea,
body.orderforms-view .secondary-cart-body,
body.orderforms-view .secondary-cart-body p,
body.orderforms-view .secondary-cart-body label,
body.orderforms-view .secondary-cart-body span,
body.orderforms-view .secondary-cart-body input,
body.orderforms-view .secondary-cart-body select,
body.orderforms-view .secondary-cart-body textarea,
#order-standard_cart .secondary-cart-body,
#order-standard_cart .secondary-cart-body p,
#order-standard_cart .secondary-cart-body label,
#order-standard_cart .secondary-cart-body span,
#order-standard_cart .secondary-cart-body input,
#order-standard_cart .secondary-cart-body select,
#order-standard_cart .secondary-cart-body textarea {
    color: #ffffff !important;
}

/* Exception within exception: product-title should be BLACK */
body.cart-view .secondary-cart-body .product-title,
body.orderforms-view .secondary-cart-body .product-title,
#order-standard_cart .secondary-cart-body .product-title {
    color: #000000 !important;
}

/* Header-lined and its h1 should be WHITE */
body.cart-view .header-lined,
body.cart-view .header-lined h1,
body.orderforms-view .header-lined,
body.orderforms-view .header-lined h1,
#order-standard_cart .header-lined,
#order-standard_cart .header-lined h1 {
    color: #ffffff !important;
}

/* Domain description paragraph should be WHITE */
body.cart-view p[style*="text-align"],
body.cart-view .domain-checker-container p,
body.cart-view .domain-lookup-container p,
body.orderforms-view p[style*="text-align"],
body.orderforms-view .domain-checker-container p,
body.orderforms-view .domain-lookup-container p {
    color: #ffffff !important;
}

/* Domain transfer input placeholders should be WHITE */
#inputTransferDomain,
#inputTransferDomain::placeholder,
#inputAuthCode,
#inputAuthCode::placeholder {
    color: #ffffff !important;
    opacity: 1 !important;
}

#inputTransferDomain::-webkit-input-placeholder,
#inputAuthCode::-webkit-input-placeholder {
    color: #ffffff !important;
    opacity: 0.7 !important;
}

#inputTransferDomain::-moz-placeholder,
#inputAuthCode::-moz-placeholder {
    color: #ffffff !important;
    opacity: 0.7 !important;
}

#inputTransferDomain:-ms-input-placeholder,
#inputAuthCode:-ms-input-placeholder {
    color: #ffffff !important;
    opacity: 0.7 !important;
}

#inputTransferDomain::-webkit-text-fill-color,
#inputAuthCode::-webkit-text-fill-color {
    color: #ffffff !important;
}

/* Override any inline styles on domain transfer inputs */
input#inputTransferDomain[style],
input#inputAuthCode[style] {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

/* Exception: White text for elements with dark backgrounds */
body.cart-view [class*="bg-dark"],
body.cart-view [class*="bg-dark"] *,
body.cart-view [class*="alert-"],
body.cart-view [class*="alert-"] *,
body.cart-view [class*="text-bg-"],
body.cart-view [class*="text-bg-"] *,
body.cart-view .panel-heading,
body.cart-view .panel-heading *,
body.cart-view .panel-footer,
body.cart-view .panel-footer *,
body.cart-view .well,
body.cart-view .well *,
body.cart-view .sub-heading,
body.cart-view .sub-heading *,
body.orderforms-view [class*="bg-dark"],
body.orderforms-view [class*="bg-dark"] *,
body.orderforms-view [class*="alert-"],
body.orderforms-view [class*="alert-"] *,
body.orderforms-view [class*="text-bg-"],
body.orderforms-view [class*="text-bg-"] *,
body.orderforms-view .panel-heading,
body.orderforms-view .panel-heading *,
body.orderforms-view .panel-footer,
body.orderforms-view .panel-footer *,
body.orderforms-view .well,
body.orderforms-view .well *,
body.orderforms-view .sub-heading,
body.orderforms-view .sub-heading *,
#order-standard_cart [class*="bg-dark"],
#order-standard_cart [class*="bg-dark"] *,
#order-standard_cart [class*="alert-"],
#order-standard_cart [class*="alert-"] *,
#order-standard_cart [class*="text-bg-"],
#order-standard_cart [class*="text-bg-"] *,
#order-standard_cart .panel-heading,
#order-standard_cart .panel-heading *,
#order-standard_cart .panel-footer,
#order-standard_cart .panel-footer *,
#order-standard_cart .well,
#order-standard_cart .well *,
#order-standard_cart .sub-heading,
#order-standard_cart .sub-heading * {
    color: #ffffff !important;
}

/* Specific: Elements that commonly have dark backgrounds */
body.cart-view .alert-info,
body.cart-view .alert-info *,
body.cart-view .alert-warning,
body.cart-view .alert-warning *,
body.cart-view .alert-dark,
body.cart-view .alert-dark *,
body.cart-view .bg-primary,
body.cart-view .bg-primary *,
body.cart-view .bg-secondary,
body.cart-view .bg-secondary *,
body.cart-view .bg-info,
body.cart-view .bg-info *,
body.cart-view .bg-warning,
body.cart-view .bg-warning *,
body.cart-view .bg-dark,
body.cart-view .bg-dark *,
body.orderforms-view .alert-info,
body.orderforms-view .alert-info *,
body.orderforms-view .alert-warning,
body.orderforms-view .alert-warning *,
body.orderforms-view .alert-dark,
body.orderforms-view .alert-dark *,
body.orderforms-view .bg-primary,
body.orderforms-view .bg-primary *,
body.orderforms-view .bg-secondary,
body.orderforms-view .bg-secondary *,
body.orderforms-view .bg-info,
body.orderforms-view .bg-info *,
body.orderforms-view .bg-warning,
body.orderforms-view .bg-warning *,
body.orderforms-view .bg-dark,
body.orderforms-view .bg-dark *,
#order-standard_cart .alert-info,
#order-standard_cart .alert-info *,
#order-standard_cart .alert-warning,
#order-standard_cart .alert-warning *,
#order-standard_cart .alert-dark,
#order-standard_cart .alert-dark *,
#order-standard_cart .bg-primary,
#order-standard_cart .bg-primary *,
#order-standard_cart .bg-secondary,
#order-standard_cart .bg-secondary *,
#order-standard_cart .bg-info,
#order-standard_cart .bg-info *,
#order-standard_cart .bg-warning,
#order-standard_cart .bg-warning *,
#order-standard_cart .bg-dark,
#order-standard_cart .bg-dark * {
    color: #ffffff !important;
}

/* Ensure form controls have WHITE text (they have dark backgrounds) */
body.cart-view input:not(#inputDomain):not([name="domain"]):not([placeholder*="domain" i]),
body.cart-view select,
body.cart-view textarea,
body.cart-view .form-control:not(#inputDomain),
body.orderforms-view input:not(#inputDomain):not([name="domain"]):not([placeholder*="domain" i]),
body.orderforms-view select,
body.orderforms-view textarea,
body.orderforms-view .form-control:not(#inputDomain),
#order-standard_cart input:not(#inputDomain):not([name="domain"]):not([placeholder*="domain" i]),
#order-standard_cart select,
#order-standard_cart textarea,
#order-standard_cart .form-control:not(#inputDomain),
#inputTransferDomain,
#inputAuthCode {
    color: #ffffff !important;
}

/* Exception: Domain pages should have BLACK input text - MUST BE AFTER WHITE RULE */
body.cart-view.domain-checker input,
body.cart-view.domain-checker select,
body.cart-view.domain-checker textarea,
body.cart-view.domain-checker .form-control,
body[class*="domain"] input,
body[class*="domain"] select,
body[class*="domain"] textarea,
body[class*="domain"] .form-control,
body.cart-view #inputDomain,
body.orderforms-view #inputDomain,
body.cart-view input[name="domain"],
body.orderforms-view input[name="domain"],
body.cart-view input[placeholder*="domain" i],
body.orderforms-view input[placeholder*="domain" i],
body.cart-view input[placeholder*="Domain" i],
body.orderforms-view input[placeholder*="Domain" i],
.domain-check-availability-container input,
.domain-check-availability-container select,
.domain-check-availability-container textarea,
.domain-check-availability-container .form-control,
#inputDomain,
input[name="domain"],
input[placeholder*="domain" i],
input[placeholder*="Domain" i] {
    color: #000000 !important;
    -webkit-text-fill-color: #000000 !important;
}

/* Links in orderform should be blue/clickable looking (but not in buttons) */
body.cart-view a:not(.btn),
body.orderforms-view a:not(.btn),
#order-standard_cart a:not(.btn) {
    color: #266AF2 !important;
}

body.cart-view a:not(.btn):hover,
body.orderforms-view a:not(.btn):hover,
#order-standard_cart a:not(.btn):hover {
    color: #266AF2 !important;
}

/* Keep white text for buttons with colored backgrounds */
body.cart-view .btn,
body.cart-view .btn *,
body.orderforms-view .btn,
body.orderforms-view .btn *,
#order-standard_cart .btn,
#order-standard_cart .btn * {
    color: #ffffff !important;
}

/* Calc Taxes tab lives in the dark secondary column but uses a light panel,
   so force its text, controls, and buttons back to black for readability. */
body.cart-view #calcTaxes,
body.cart-view #calcTaxes *,
body.orderforms-view #calcTaxes,
body.orderforms-view #calcTaxes *,
#order-standard_cart #calcTaxes,
#order-standard_cart #calcTaxes * {
    color: #000000 !important;
}

/* Keep appropriate colors for alerts and badges */
body.cart-view .alert,
body.cart-view .badge,
body.orderforms-view .alert,
body.orderforms-view .badge,
#order-standard_cart .alert,
#order-standard_cart .badge {
    color: inherit !important;
}

/* ======================================================================== */

/* CRITICAL: Override Bootstrap's .form-control color on select elements */
select.form-control {
    height: 38px !important;
    line-height: 38px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    font-size: 15px !important;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* === MINIMAL TRANSITIONS === */
/* Let Tailwind handle all button animations via inline classes */

/* Only style form controls and cards, NOT buttons or links */

/* Form controls */
input,
select,
textarea,
.form-control {
    transition: border-color 0.15s ease-in-out, 
                box-shadow 0.15s ease-in-out !important;
}

/* Cards and containers */
.card,
.stat-card {
    transition: box-shadow 0.15s ease-in-out, 
                transform 0.15s ease-in-out !important;
}

/* List items */
.list-group-item,
.dropdown-item {
    transition: color 0.15s ease-in-out, 
                background-color 0.15s ease-in-out !important;
}

html {
    scroll-behavior: smooth;
    background-color: var(--bg-main) !important;
}

body {
    background-color: var(--bg-main) !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
    line-height: 1.6;
}

.w-hidden {
    display: none;
}

/* Force shopping cart to be visible */
a[href*="cart.php"] .fa-shopping-cart {
    display: inline-block !important;
}

a[href*="cart.php?a=view"] {
    display: flex !important;
}

a,
a:visited {
    text-decoration: none !important;
}

/* Hide WHMCS loading/processing elements */
#fullpage-overlay,
.provisioningmodule-loader,
.processing-overlay,
.loader-container,
.provisioningmodule-loadermessage,
#loading,
.loading-spinner {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
}

/* Hide language selector completely */
.modal-localisation,
#modalChooseLanguage,
.language-chooser,
[data-target="#modalChooseLanguage"],
button[data-target="#modalChooseLanguage"] {
    display: none !important;
}

/* Remove WHMCS default margins */
.container-fluid,
.container {
    background-color: transparent !important;
}

/* Primary content area */
.primary-content,
section {
    background-color: transparent !important;
}

/* Cards */
.card,
.panel,
.panel-default {
    background-color: var(--bg-card) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 1rem !important;
}

.card-header,
.panel-heading {
    background: linear-gradient(145deg, rgba(18, 18, 26, 0.8), rgba(11, 11, 18, 0.8)) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.card-body,
.panel-body {
    background-color: var(--bg-card) !important;
}

/* Domain Search Buttons - Flexy Style */
.domain-action-btn,
button.domain-action-btn,
.btn.domain-action-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem !important;
    padding: 0.85rem 1.75rem !important;
    border: none !important;
    border-radius: 0.75rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.01em !important;
    text-transform: none !important;
    background-size: 200% 200% !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background-position 0.5s ease !important;
    cursor: pointer !important;
    font-size: 15px !important;
}

.domain-action-btn--primary,
button.domain-action-btn--primary,
.btn.domain-action-btn--primary {
    background: linear-gradient(135deg, #266AF2, #4E14E0) !important;
    background-image: linear-gradient(135deg, #266AF2, #4E14E0) !important;
    box-shadow: 0 8px 20px rgba(38, 106, 242, 0.3) !important;
}

.domain-action-btn--primary:hover,
.domain-action-btn--primary:focus,
button.domain-action-btn--primary:hover,
button.domain-action-btn--primary:focus {
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 28px rgba(38, 106, 242, 0.4) !important;
    background-position: 100% 0 !important;
}

.domain-action-btn--transfer,
button.domain-action-btn--transfer,
.btn.domain-action-btn--transfer {
    background: linear-gradient(135deg, #34D399, #06B6D4) !important;
    background-image: linear-gradient(135deg, #34D399, #06B6D4) !important;
    box-shadow: 0 8px 20px rgba(52, 211, 153, 0.3) !important;
}

.domain-action-btn--transfer:hover,
.domain-action-btn--transfer:focus,
button.domain-action-btn--transfer:hover,
button.domain-action-btn--transfer:focus {
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 28px rgba(6, 182, 212, 0.4) !important;
    background-position: 100% 0 !important;
}

.domain-action-btn:focus,
button.domain-action-btn:focus {
    outline: none !important;
}

.domain-action-btn.btn-block,
button.domain-action-btn.btn-block {
    width: 100% !important;
}

/* Domain Search - Add margin-top to input-group */
.home-domain-search .input-group,
form#frmDomainHomepage .input-group,
.input-group.margin-10 {
    margin-top: 1.5rem !important;
}

/* Make domain input bigger */
.input-group.margin-10 input[type="text"],
.input-group.margin-10 input[name="domain"] {
    padding: 1.1rem 1.5rem !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
}

/* Domain Search Input Field - Bigger */
.home-domain-search input[type="text"].form-control,
.home-domain-search input[name="domain"],
.home-domain-search input[type="text"],
.home-domain-search .form-control,
.home-domain-search .input-group input,
form#frmDomainHomepage input[name="domain"],
form#frmDomainHomepage input[type="text"] {
    padding: 1.1rem 1.5rem !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
}

/* Align buttons with bigger input */
.home-domain-search .input-group-append,
.home-domain-search .input-group-btn {
    align-items: stretch !important;
}

/* Domain Search Input Group Buttons - Register & Transfer */
.input-group-btn input[type="submit"],
.input-group-append input[type="submit"],
.home-domain-search input[type="submit"].btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: none !important;
    border-radius: 0.75rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.01em !important;
    text-transform: none !important;
    background-size: 200% 200% !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background-position 0.5s ease !important;
    cursor: pointer !important;
    margin-left: 0.5rem !important;
}

/* Register Button - Blue Gradient (Smaller) */
.input-group-btn input[type="submit"].btn-success,
.input-group-append input[type="submit"].btn-success,
.home-domain-search input[type="submit"][value="Register"] {
    background: linear-gradient(135deg, #266AF2, #4E14E0) !important;
    background-image: linear-gradient(135deg, #266AF2, #4E14E0) !important;
    background-color: #266AF2 !important;
    box-shadow: 0 6px 16px rgba(38, 106, 242, 0.3) !important;
    border-color: transparent !important;
    padding: 0.65rem 1.4rem !important;
    font-size: 14px !important;
}

.input-group-btn input[type="submit"].btn-success:hover,
.input-group-btn input[type="submit"].btn-success:focus,
.input-group-append input[type="submit"].btn-success:hover,
.input-group-append input[type="submit"].btn-success:focus,
.home-domain-search input[type="submit"][value="Register"]:hover,
.home-domain-search input[type="submit"][value="Register"]:focus {
    transform: translateY(-2px) !important;
    box-shadow: 0 10px 24px rgba(38, 106, 242, 0.4) !important;
    background-position: 100% 0 !important;
    background: linear-gradient(135deg, #266AF2, #4E14E0) !important;
}

/* Transfer Button - Outlined Style (Much Smaller) */
.input-group-btn input[type="submit"].btn-default,
.input-group-append input[type="submit"].btn-default,
.home-domain-search input[type="submit"][value="Transfer"],
.input-group-btn input[type="submit"][name="transfer"],
.input-group-append input[type="submit"][name="transfer"] {
    background: transparent !important;
    background-image: none !important;
    background-color: transparent !important;
    box-shadow: none !important;
    border: 2px solid rgba(255, 255, 255, 0.2) !important;
    padding: 0.5rem 1rem !important;
    font-size: 13px !important;
}

.input-group-btn input[type="submit"].btn-default:hover,
.input-group-btn input[type="submit"].btn-default:focus,
.input-group-append input[type="submit"].btn-default:hover,
.input-group-append input[type="submit"].btn-default:focus,
.home-domain-search input[type="submit"][value="Transfer"]:hover,
.home-domain-search input[type="submit"][value="Transfer"]:focus,
.input-group-btn input[type="submit"][name="transfer"]:hover,
.input-group-btn input[type="submit"][name="transfer"]:focus {
    transform: translateY(-1px) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(255, 255, 255, 0.4) !important;
    box-shadow: 0 4px 12px rgba(255, 255, 255, 0.1) !important;
}

.domain-pricing {
    color: black !important;
}

/* Tables */
.table {
    background-color: transparent !important;
}

.table thead th {
    background: linear-gradient(145deg, rgba(18, 18, 26, 0.8), rgba(11, 11, 18, 0.8)) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
}

.table tbody tr {
    border-color: rgba(255, 255, 255, 0.05) !important;
}

.table tbody tr:hover {
    background-color: rgba(255, 255, 255, 0.02) !important;
}

.table td,
.table th {
    border-color: rgba(255, 255, 255, 0.1) !important;
}

.listtable .dataTables_length select,
.listtable .dataTables_filter input {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 0.5rem !important;
    padding: 0.4rem 0.75rem !important;
}

.listtable .dataTables_filter input:focus,
.listtable .dataTables_length select:focus {
    border-color: var(--accent-start) !important;
    box-shadow: 0 0 0 3px rgba(38, 106, 242, 0.15) !important;
}

.dataTables_paginate .paginate_button {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 0.5rem !important;
    margin: 0 0.2rem !important;
    padding: 0.35rem 0.75rem !important;
}

.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button:hover {
    background: linear-gradient(90deg, var(--accent-start), var(--accent-end)) !important;
    border-color: transparent !important;
}

.label.status {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.85rem;
    border-radius: 999px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.65rem;
    border: none !important;
}

.ticket-subject.unread {
    font-weight: 600;
}

/* Forms */
.form-control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
textarea,
select {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 0.5rem !important;
}

.form-control:focus,
input:focus,
textarea:focus,
select:focus {
    background-color: rgba(255, 255, 255, 0.08) !important;
    border-color: var(--accent-start) !important;
    box-shadow: 0 0 0 3px rgba(38, 106, 242, 0.15) !important;
}

/* Labels */
label,
.control-label {
    font-weight: 500 !important;
}

/* Alerts */
.alert {
    border-radius: 0.75rem !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.alert-success {
    background-color: rgba(16, 185, 129, 0.1) !important;
    border-color: rgba(16, 185, 129, 0.3) !important;
    color: #10b981 !important;
}

.alert-info {
    background-color: rgba(59, 130, 246, 0.1) !important;
    border-color: rgba(59, 130, 246, 0.3) !important;
    color: #3b82f6 !important;
}

.alert-warning {
    background-color: rgba(245, 158, 11, 0.1) !important;
    border-color: rgba(245, 158, 11, 0.3) !important;
    color: #f59e0b !important;
}

.alert-danger,
.alert-error {
    background-color: rgba(239, 68, 68, 0.1) !important;
    border-color: rgba(239, 68, 68, 0.3) !important;
    color: #ef4444 !important;
}

/* Badges */
.badge {
    border-radius: 0.5rem !important;
    padding: 0.25rem 0.75rem !important;
}

.badge-success,
.label-success {
    background-color: #10b981 !important;
}

.badge-info,
.label-info {
    background-color: #3b82f6 !important;
}

.badge-warning,
.label-warning {
    background-color: #f59e0b !important;
}

.badge-danger,
.label-danger {
    background-color: #ef4444 !important;
}

a,
a:visited {
    text-decoration: none !important;
}

/* NO blue hover on buttons/card elements - NUCLEAR FORCE WHITE */
.card-header a,
.card-header a:hover,
.card-header a:focus,
.card-header a:active,
a.inline-flex,
a.inline-flex:link,
a.inline-flex:visited,
a.inline-flex:hover,
a.inline-flex:focus,
a.inline-flex:active,
.inline-flex,
.inline-flex:hover,
.inline-flex:focus,
.inline-flex:active,
.inline-flex *,
.inline-flex:hover *,
.inline-flex:focus *,
.inline-flex:active *,
a.inline-flex *,
a.inline-flex:hover *,
a.inline-flex:focus *,
a.inline-flex:active * {
    text-decoration: none !important;
}

/* Modals */
.modal-content {
    background-color: var(--bg-card) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 1rem !important;
}

.modal-header {
    background: linear-gradient(145deg, rgba(18, 18, 26, 0.8), rgba(11, 11, 18, 0.8)) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.modal-footer {
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

/* Breadcrumbs */
.breadcrumb {
    background-color: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Hide duplicate breadcrumbs - only show first one */
.breadcrumb:nth-of-type(2),
.breadcrumb:nth-of-type(n+2) {
    display: none !important;
}

/* Nav Tabs */
.nav-tabs {
    border-bottom: 2px solid rgba(255, 255, 255, 0.1) !important;
}

.nav-tabs .nav-link {
    border: none !important;
    border-bottom: 2px solid transparent !important;
    background-color: transparent !important;
}

.nav-tabs .nav-link.active {
    background-color: transparent !important;
    border-bottom-color: var(--accent-start) !important;
}

/* Progress Bars */
.progress {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-radius: 0.5rem !important;
}

.progress-bar {
    background: linear-gradient(90deg, var(--accent-start), var(--accent-end)) !important;
}

/* List Groups */
.list-group-item {
    background-color: transparent !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    transition: background-color 0.2s ease-out, border-color 0.2s ease-out, color 0.2s ease-out !important;
    will-change: background-color;
}

.list-group-item:hover {
    background-color: rgba(38, 106, 242, 0.15) !important;
    border-color: rgba(38, 106, 242, 0.3) !important;
}

/* Pagination */
.pagination .page-link {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

.pagination .page-link:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-color: var(--accent-start) !important;
}

.pagination .page-item.active .page-link {
    background: linear-gradient(90deg, var(--accent-start), var(--accent-end)) !important;
    border-color: var(--accent-start) !important;
}

/* Custom FlexyNode Product Cards */
.product-card {
    position: relative;
    background-color: var(--bg-card) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 1rem !important;
    padding: 1.5rem !important;
    transition: all 0.3s ease !important;
}

.product-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 10px 30px rgba(78, 20, 224, 0.25) !important;
    border-color: rgba(38, 106, 242, 0.4) !important;
}

/* Dashboard Stats Cards */
.stat-card {
    background: linear-gradient(145deg, rgba(18, 18, 26, 0.8), rgba(11, 11, 18, 0.8)) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 1rem !important;
    padding: 1.5rem !important;
    transition: all 0.3s ease !important;
}

/* Stat card hover - FlexyNode blue border with lift */
.stat-card:hover {
    border-color: rgba(38, 106, 242, 0.4) !important;
    transform: translateY(-2px) !important;
}

/* Prevent color change on hover for stat cards */
.stat-card,
.stat-card:hover,
.stat-card:focus,
.stat-card:active,
.stat-card:visited {
    text-decoration: none !important;
}

/* Keep stat card icons their original color and add animation */
.stat-card i,
.stat-card:hover i {
    transition: transform 0.3s ease !important;
}

.stat-card:hover i {
    transform: scale(1.05) !important;
}

/* Stat card numbers (h3) - FORCE WHITE, NO hover color change */
.stat-card h3,
.stat-card:hover h3,
.stat-card:focus h3,
.stat-card:active h3,
a.stat-card h3,
a.stat-card:hover h3 {
    font-size: 2rem !important;
    font-weight: bold !important;
    color: #ffffff !important;
}

.stat-card p,
.stat-card:hover p {
    font-size: 0.875rem !important;
    color: rgba(255, 255, 255, 0.6) !important;
}

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

.sidebar .panel {
    margin-bottom: 1.5rem !important;
}

/* Dropdowns */
.dropdown-menu {
    background-color: var(--bg-card) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 0.75rem !important;
}

.dropdown-item:hover {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

/* Tooltips */
.tooltip-inner {
    background-color: var(--bg-card) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

/* Loading Spinner */
.spinner-border {
    border-color: rgba(38, 106, 242, 0.3) !important;
    border-right-color: var(--accent-start) !important;
}

/* Client Alerts */
.client-alerts li a {
    display: flex !important;
    align-items: center !important;
    padding: 0.75rem !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
}

.client-alerts li a:hover {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

/* Status Labels */
.label-active,
.status-active {
    background-color: #10b981 !important;
}

.label-pending,
.status-pending {
    background-color: #f59e0b !important;
}

.label-suspended,
.status-suspended {
    background-color: #ef4444 !important;
}

/* WHMCS Specific Overrides */
.header {
    background: transparent !important;
    border: none !important;
}

.topbar {
    background: rgba(17, 17, 26, 0.5) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
}

/* Hide default WHMCS elements that conflict */
.navbar.main-navbar-wrapper {
    display: none !important;
}

/* Client alerts styling */
.popover {
    background-color: var(--bg-card) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.popover-body {
    background-color: var(--bg-card) !important;
}

/* Fix for WHMCS tiles */
.tiles .tile {
    background: linear-gradient(145deg, rgba(18, 18, 26, 0.8), rgba(11, 11, 18, 0.8)) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    transition: all 0.3s ease !important;
}

.tiles .tile:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 10px 30px rgba(78, 20, 224, 0.25) !important;
    border-color: rgba(38, 106, 242, 0.4) !important;
}

.tiles .tile .stat {
    font-size: 2rem !important;
    font-weight: bold !important;
}

/* Image placeholders */
img[src*="placeholder"] {
    border-radius: 0.5rem;
}

/* Responsive */
@media (max-width: 768px) {
    .product-card {
        padding: 1rem !important;
    }
    
    .stat-card {
        padding: 1rem !important;
    }
    
    /* Mobile nav spacing */
    body {
        padding-top: 80px !important;
    }
}

@media (min-width: 769px) {
    body {
        padding-top: 80px !important;
    }
}

/* Smooth scrolling */
html {
    scroll-padding-top: 100px;
}

/* ========================================
   CARD HEADER BUTTONS - Use Tailwind classes in templates
   No custom CSS needed, pure Tailwind for smooth animations
   ======================================== */

/* Ensure card header links don't turn blue */
.card-header a,
.card-header a:hover,
.card-header a:focus {
    text-decoration: none !important;
}

/* Hero buttons container */
.fn-hero-buttons {
    display: flex !important;
    gap: 15px !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    margin-top: 20px !important;
}

/* Base button style - FORCE OVERRIDE BOOTSTRAP */
a.fn-btn,
a.fn-btn:link,
a.fn-btn:visited,
button.fn-btn {
    display: inline-block !important;
    padding: 14px 32px !important;
    border-radius: 8px !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    text-decoration: none !important;
    text-align: center !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    border: none !important;
    line-height: 1.5 !important;
    background-image: none !important;
    box-shadow: none !important;
}

/* Primary button - Gradient FlexyNode style */
a.fn-btn.fn-btn-primary,
a.fn-btn-primary:link,
a.fn-btn-primary:visited {
    background: linear-gradient(135deg, #266AF2 0%, #4E14E0 100%) !important;
    box-shadow: 0 4px 15px rgba(78, 20, 224, 0.3) !important;
    border: none !important;
}

a.fn-btn.fn-btn-primary:hover,
a.fn-btn-primary:hover {
    background: linear-gradient(135deg, #1a5dd8 0%, #3d0fc7 100%) !important;
    box-shadow: 0 6px 25px rgba(78, 20, 224, 0.5) !important;
    transform: translateY(-2px) !important;
    text-decoration: none !important;
}

a.fn-btn.fn-btn-primary:active,
a.fn-btn-primary:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 10px rgba(78, 20, 224, 0.4) !important;
}

/* Secondary button - Outlined style */
a.fn-btn.fn-btn-secondary,
a.fn-btn-secondary:link,
a.fn-btn-secondary:visited {
    background: transparent !important;
    border: 2px solid #266AF2 !important;
    box-shadow: none !important;
}

a.fn-btn.fn-btn-secondary:hover,
a.fn-btn-secondary:hover {
    background: rgba(38, 106, 242, 0.1) !important;
    border-color: #266AF2 !important;
    box-shadow: 0 4px 15px rgba(78, 20, 224, 0.2) !important;
    transform: translateY(-2px) !important;
    text-decoration: none !important;
}

a.fn-btn.fn-btn-secondary:active,
a.fn-btn-secondary:active {
    transform: translateY(0) !important;
    background: rgba(38, 106, 242, 0.15) !important;
}

/* Mobile responsive */
@media (max-width: 768px) {
    .fn-hero-buttons {
        flex-direction: column !important;
        align-items: center !important;
    }
    
    .fn-btn {
        width: 100% !important;
        max-width: 300px !important;
    }
}

#main-nav a:hover {
    color: #266AF2 !important;
}

/* Ensure button text stays white even on hover (e.g., Get Started) */
.glow-btn,
.glow-btn *,
.glow-btn:hover,
.glow-btn:hover * {
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Homepage hero CTA buttons - forced override */
.hero-section .hero-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 1rem !important;
    justify-content: center !important;
}

.hero-section .hero-button {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.55rem !important;
    padding: 1rem 2.5rem !important;
    border-radius: 0.9rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.01em !important;
    text-decoration: none !important;
    text-transform: none !important;
    border: none !important;
    transition: transform 0.25s ease, box-shadow 0.3s ease, background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease !important;
    box-shadow: 0 14px 32px rgba(12, 16, 32, 0.45) !important;
    color: inherit !important;
}

.hero-section .hero-button--primary {
    background: #ffffff !important;
    color: #0a0a0f !important;
    box-shadow: 0 22px 48px rgba(38, 106, 242, 0.38) !important;
}

.hero-section .hero-button--primary::before {
    content: "" !important;
    position: absolute !important;
    inset: -4px !important;
    border-radius: inherit !important;
    background: linear-gradient(130deg, var(--accent-start), var(--accent-end)) !important;
    opacity: 0.45 !important;
    filter: blur(18px) !important;
    z-index: -1 !important;
    transition: opacity 0.3s ease !important;
}

.hero-section .hero-button--primary:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 28px 58px rgba(38, 106, 242, 0.46) !important;
}

.hero-section .hero-button--primary:hover::before {
    opacity: 0.75 !important;
}

.hero-section .hero-button--secondary {
    background: rgba(255, 255, 255, 0.93) !important;
    color: #131422 !important;
    border: 1.5px solid rgba(255, 255, 255, 0.65) !important;
    box-shadow: 0 18px 40px rgba(13, 18, 33, 0.4) !important;
}

.hero-section .hero-button--secondary:hover {
    transform: translateY(-3px) !important;
    background: #ffffff !important;
    border-color: transparent !important;
    box-shadow: 0 26px 52px rgba(38, 106, 242, 0.32) !important;
}

/* Select dropdown styling for dark theme */
select.form-control option {
    background-color: #11111A !important;
    padding: 8px;
}

select.form-control optgroup {
    background-color: #0A0A0F !important;
    color: #266AF2 !important;
    font-weight: 600;
}

/* Textarea styling */
textarea.form-control {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px;
    padding: 12px;
}

textarea.form-control:focus {
    border-color: #266AF2 !important;
    outline: none;
    box-shadow: 0 0 0 3px rgba(38, 106, 242, 0.1);
}

/* Custom file input styling */
.custom-file-label {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

.custom-file-input:focus ~ .custom-file-label {
    border-color: #266AF2 !important;
    box-shadow: 0 0 0 3px rgba(38, 106, 242, 0.1);
}

.markdown-content p {
    margin-bottom: 1em;
}

.markdown-content br {
    display: block;
    content: "";
    margin-top: 0.5em;
}

.markdown-content {
    white-space: normal;
}

.markdown-content p + p {
    margin-top: 1em;
}

/* Badge styling for ticket status */
.badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 9999px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ========================================
   SMOOTH BUTTON TRANSITIONS - FORCE OVERRIDE
   Bootstrap often sets transition: none in media queries
   This override ensures smooth transitions everywhere
   ======================================== */

/* Base button transitions - highest specificity */
button.btn,
a.btn,
input[type="submit"].btn,
input[type="button"].btn,
.btn.btn-primary,
.btn.btn-secondary,
.btn.btn-default,
.btn.btn-success,
.btn.btn-danger,
.btn.btn-warning,
.btn.btn-info {
    transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                border-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Ensure hover states are smooth */
button.btn:hover,
a.btn:hover,
input[type="submit"].btn:hover,
input[type="button"].btn:hover,
.btn.btn-primary:hover,
.btn.btn-secondary:hover,
.btn.btn-default:hover,
.btn.btn-success:hover,
.btn.btn-danger:hover,
.btn.btn-warning:hover,
.btn.btn-info:hover {
    transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                border-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Media query override - force transitions on all screen sizes */
@media (max-width: 1200px) {
    button.btn,
    a.btn,
    .btn {
        transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                    color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                    border-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                    box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                    transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    }
}

@media (max-width: 768px) {
    button.btn,
    a.btn,
    .btn {
        transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                    color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                    border-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                    box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                    transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    }
}

/* Override any prefers-reduced-motion that might disable transitions */
@media (prefers-reduced-motion: reduce) {
    button.btn,
    a.btn,
    .btn {
        transition: background-color 0.2s ease, 
                    color 0.2s ease, 
                    border-color 0.2s ease !important;
    }
}

/* Specific button variant smooth transitions */
.btn-primary {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.btn-primary:hover,
.btn-primary:focus {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.btn-default {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.btn-default:hover,
.btn-default:focus {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.btn-success {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.btn-success:hover,
.btn-success:focus {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.btn-danger {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.btn-danger:hover,
.btn-danger:focus {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* ========================================
   TICKET FORM FIXES - ALL INPUTS SAME COLOR AS SUBJECT
   Use lighter gray instead of pure black
   ======================================== */

/* ALL form inputs - same lighter color */
input.form-control,
textarea.form-control,
select.form-control,
#inputName,
#inputEmail,
#inputSubject,
#inputMessage,
#inputDepartment,
#inputPriority,
#inputRelatedService,
.markdown-editor,
textarea.markdown-editor {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

/* Override any Bootstrap default */
.form-control:disabled,
.form-control[readonly] {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

/* Focus states for all inputs */
input.form-control:focus,
textarea.form-control:focus,
select.form-control:focus,
#inputName:focus,
#inputEmail:focus,
#inputSubject:focus,
#inputMessage:focus,
#inputDepartment:focus,
#inputPriority:focus,
#inputRelatedService:focus,
.markdown-editor:focus,
textarea.markdown-editor:focus {
    background-color: rgba(255, 255, 255, 0.08) !important;
    border-color: var(--accent-start) !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(38, 106, 242, 0.2) !important;
}

/* Markdown editor specific - override EasyMDE/SimpleMDE */
.CodeMirror,
.CodeMirror-scroll,
.CodeMirror-code,
.cm-s-easymde .CodeMirror-scroll,
.EasyMDEContainer .CodeMirror {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

.CodeMirror-gutter,
.CodeMirror-gutters {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
}

.editor-toolbar {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-left: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-right: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15) !important;
    opacity: 1 !important;
}

/* Extra specific selectors for markdown editor toolbar */
.EasyMDEContainer .editor-toolbar,
textarea.markdown-editor + .editor-toolbar,
#inputMessage + .editor-toolbar,
[data-auto-save-name] + .editor-toolbar {
    background-color: rgba(255, 255, 255, 0.05) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
}

.editor-toolbar button {
    border: none !important;
    background: transparent !important;
}

.editor-toolbar button:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border: none !important;
}

.editor-toolbar i.separator {
    border-left: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-right: 1px solid rgba(255, 255, 255, 0.15) !important;
}

.editor-toolbar.fullscreen {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

.editor-toolbar.disabled-for-preview button:not(.no-disable) {
    opacity: 0.6 !important;
    background: transparent !important;
}

/* Force override any inline styles */
.editor-toolbar[style] {
    background-color: rgba(255, 255, 255, 0.05) !important;
    background: rgba(255, 255, 255, 0.05) !important;
}

.editor-preview,
.editor-preview-side,
.editor-preview-active {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

.editor-statusbar {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-left: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-right: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15) !important;
}

/* Container for markdown editor */
.EasyMDEContainer,
.CodeMirror-wrap {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

/* Select dropdowns - same styling as other inputs */
select.form-control,
#inputDepartment,
#inputPriority,
#inputRelatedService {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !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 12px center !important;
    padding-right: 40px !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

/* For MS browsers */
select.form-control::-ms-value,
#inputDepartment::-ms-value,
#inputPriority::-ms-value,
#inputRelatedService::-ms-value {
    background-color: transparent !important;
}

/* Select dropdown options - white background with dark text for readability */
select.form-control option,
#inputDepartment option,
#inputPriority option,
#inputRelatedService option,
select option {
    background-color: #FFFFFF !important;
    color: #11111A !important;
    padding: 8px !important;
    font-size: 14px !important;
}

/* Selected option styling in dropdown */
select option:checked,
select option[selected] {
    background-color: rgba(38, 106, 242, 0.3) !important;
    color: #11111A !important;
    font-weight: bold !important;
}

/* ========================================
   ULTIMATE MARKDOWN EDITOR OVERRIDE
   Bootstrap Markdown Editor (not EasyMDE)
   Must be at the absolute end to override everything
   ======================================== */

/* Bootstrap Markdown Editor - md-header is the toolbar */
.md-editor,
body .md-editor,
html body .md-editor {
    background-color: transparent !important;
    border: none !important;
}

.md-header,
.md-header.btn-toolbar,
body .md-header,
body .md-header.btn-toolbar,
html body .md-header {
    background-color: rgba(255, 255, 255, 0.05) !important;
    background-image: none !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px 8px 0 0 !important;
    padding: 8px !important;
}

.md-footer,
body .md-footer,
html body .md-footer {
    background-color: rgba(255, 255, 255, 0.05) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-top: none !important;
    border-radius: 0 0 8px 8px !important;
    padding: 8px !important;
}

/* Buttons in markdown toolbar */
.md-header .btn,
.md-header button,
body .md-header .btn,
body .md-header button {
    background-color: transparent !important;
    background-image: none !important;
    background: transparent !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

.md-header .btn:hover,
.md-header button:hover,
body .md-header .btn:hover,
body .md-header button:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(255, 255, 255, 0.25) !important;
}

.md-header .btn-primary,
body .md-header .btn-primary {
    background: linear-gradient(90deg, var(--accent-start), var(--accent-end)) !important;
    border-color: transparent !important;
}

.md-header .btn-primary:hover,
body .md-header .btn-primary:hover {
    opacity: 0.9 !important;
}

.md-header .btn-primary.active,
.md-header .btn-primary:active,
body .md-header .btn-primary.active,
body .md-header .btn-primary:active {
    background: white !important;
    color: #0A0A0F !important;
    border-color: rgba(255, 255, 255, 0.25) !important;
}

/* Preview content styling */
.md-preview,
.md-editor.active .md-preview,
body .md-preview {
    background-color: white !important;
    color: #0A0A0F !important;
    padding: 1rem !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px !important;
}

.md-editor.active textarea,
body .md-editor.active textarea {
    color: #0A0A0F !important;
}

/* Markdown Guide Modal Styling */
.modal-content h4,
.markdown-guide h4,
body .modal-content h4 {
    margin-top: 1.5rem !important;
    margin-bottom: 0.75rem !important;
}

.modal-content pre,
.markdown-guide pre,
body .modal-content pre {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px !important;
    padding: 1rem !important;
}

.modal-content code,
.markdown-guide code,
body .modal-content code {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

/* Rounded corners for markdown editor */
.md-editor,
body .md-editor {
    border-radius: 8px !important;
    overflow: hidden !important;
}

.md-input,
textarea.markdown-editor,
body .md-input,
body textarea.markdown-editor {
    border-radius: 0 !important;
}

/* Fullscreen controls */
.md-fullscreen-controls,
body .md-fullscreen-controls {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

.md-controls,
.md-control-fullscreen,
body .md-controls,
body .md-control-fullscreen {
    display: none !important;
}

.md-controls a:hover,
body .md-controls a:hover {
    color: var(--accent-start) !important;
}

/* Legacy EasyMDE support (keep for backward compatibility) */
body .editor-toolbar,
body .EasyMDEContainer .editor-toolbar,
body textarea.markdown-editor + .editor-toolbar,
body #inputMessage + .editor-toolbar,
html body .editor-toolbar {
    background-color: rgba(255, 255, 255, 0.05) !important;
    background-image: none !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
}

body .editor-toolbar::before,
body .editor-toolbar::after {
    background: rgba(255, 255, 255, 0.05) !important;
}

body .editor-statusbar,
html body .editor-statusbar {
    background-color: rgba(255, 255, 255, 0.05) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
}

/* ===================================
   DataTables Support Tickets List Override
   =================================== */

/* Remove ALL table borders */
#tableTicketsList,
table#tableTicketsList,
body #tableTicketsList,
.table-container table,
.card .table {
    background-color: #11111A !important;
    border: none !important;
    border-collapse: collapse !important;
}

/* Table wrapper - remove border from card */
.card.bg-\[#11111A\],
.table-container,
body .table-container {
    border: none !important;
}

/* Table body background */
#tableTicketsList tbody,
table#tableTicketsList tbody,
body #tableTicketsList tbody {
    background-color: #11111A !important;
    border: none !important;
}

/* Table head */
#tableTicketsList thead,
table#tableTicketsList thead,
body #tableTicketsList thead {
    background: linear-gradient(to right, #14141d, #0c0c12) !important;
    border: none !important;
}

/* All table cells - NO BORDERS */
#tableTicketsList td,
#tableTicketsList th,
table#tableTicketsList td,
table#tableTicketsList th,
body #tableTicketsList td,
body #tableTicketsList th,
.table td,
.table th {
    background-color: #11111A !important;
    border: none !important;
    border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
    border-left: none !important;
    border-right: none !important;
    border-bottom: none !important;
}

/* First row - remove top border */
#tableTicketsList tbody tr:first-child td,
table#tableTicketsList tbody tr:first-child td {
    border-top: none !important;
}

/* Table rows */
#tableTicketsList tbody tr,
table#tableTicketsList tbody tr,
body #tableTicketsList tbody tr {
    background-color: #11111A !important;
    border: none !important;
}

/* Hover state */
#tableTicketsList tbody tr:hover,
table#tableTicketsList tbody tr:hover,
body #tableTicketsList tbody tr:hover {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

#tableTicketsList a:hover,
table#tableTicketsList a:hover,
body #tableTicketsList a:hover {
    color: var(--accent-start) !important;
}

/* DataTables wrapper - remove all borders */
.dataTables_wrapper,
body .dataTables_wrapper,
.dataTables_wrapper .table,
body .dataTables_wrapper .table {
    background-color: transparent !important;
    border: none !important;
    padding: 0 24px 24px 24px !important;
}

.dataTables_info,
body .dataTables_info {
    padding: 16px 0 !important;
}

/* DataTables search input - styled search box */
.dataTables_filter,
body .dataTables_filter {
    padding: 16px 0 !important;
}

.dataTables_filter label,
body .dataTables_filter label {
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
    margin: 0 !important;
}

/* Hide the default "Search:" text */
.dataTables_filter label::before,
body .dataTables_filter label::before {
    content: none !important;
}

.dataTables_filter input,
body .dataTables_filter input {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    padding: 10px 16px 10px 40px !important;
    border-radius: 8px !important;
    transition: all 0.3s ease !important;
    width: 280px !important;
    margin-left: 0 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='rgba(255,255,255,0.4)'%3E%3Cpath d='M416 208c0 45.9-14.9 88.3-40 122.7L502.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L330.7 376c-34.4 25.2-76.8 40-122.7 40C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208zM208 352a144 144 0 1 0 0-288 144 144 0 1 0 0 288z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: 12px center !important;
    background-size: 16px !important;
}

.dataTables_filter input:focus,
body .dataTables_filter input:focus {
    outline: none !important;
    border-color: var(--accent-start) !important;
    box-shadow: 0 0 0 3px rgba(38, 106, 242, 0.1) !important;
}

/* DataTables length select */
.dataTables_length,
body .dataTables_length {
    padding: 16px 0 !important;
}

.dataTables_length label,
body .dataTables_length label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.dataTables_length select,
body .dataTables_length select {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    padding: 6px 32px 6px 12px !important;
    border-radius: 8px !important;
    margin: 0 8px !important;
}

/* DataTables pagination buttons - completely redesigned */
.dataTables_paginate,
body .dataTables_paginate {
    padding: 16px 0 !important;
    display: flex !important;
    gap: 8px !important;
    justify-content: flex-end !important;
    align-items: center !important;
}

/* Remove default paginate_button styling */
.dataTables_paginate .paginate_button,
body .dataTables_paginate .paginate_button {
    background: rgba(255, 255, 255, 0.05) !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    background-image: none !important;
    border: none !important;
    padding: 10px 16px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    transition: all 0.3s ease !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 44px !important;
    cursor: pointer !important;
    box-shadow: none !important;
    text-decoration: none !important;
    font-weight: 500 !important;
}

.dataTables_paginate .paginate_button:hover,
body .dataTables_paginate .paginate_button:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    background-color: rgba(255, 255, 255, 0.1) !important;
    background-image: none !important;
    border: none !important;
    box-shadow: none !important;
}

.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button.current:hover,
body .dataTables_paginate .paginate_button.current,
body .dataTables_paginate .paginate_button.current:hover {
    background: linear-gradient(135deg, var(--accent-start), var(--accent-end)) !important;
    background-color: var(--accent-start) !important;
    background-image: linear-gradient(135deg, var(--accent-start), var(--accent-end)) !important;
    border: none !important;
    font-weight: 600 !important;
    box-shadow: 0 4px 12px rgba(38, 106, 242, 0.3) !important;
}

.dataTables_paginate .paginate_button.disabled,
.dataTables_paginate .paginate_button.disabled:hover,
body .dataTables_paginate .paginate_button.disabled,
body .dataTables_paginate .paginate_button.disabled:hover {
    opacity: 0.3 !important;
    cursor: not-allowed !important;
    background: rgba(255, 255, 255, 0.05) !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    background-image: none !important;
    border: none !important;
    box-shadow: none !important;
}

/* Fix pagination wrapper layout */
.dataTables_wrapper .dataTables_paginate,
body .dataTables_wrapper .dataTables_paginate {
    text-align: right !important;
}

/* Remove any ellipsis spans styling */
.dataTables_paginate span,
body .dataTables_paginate span {
    display: inline-flex !important;
    gap: 8px !important;
    align-items: center !important;
}

/* Style Previous/Next text buttons */
.dataTables_paginate .previous,
.dataTables_paginate .next,
body .dataTables_paginate .previous,
body .dataTables_paginate .next {
    font-weight: 500 !important;
    min-width: 90px !important;
}

/* Sorting arrows */
#tableTicketsList thead th,
table#tableTicketsList thead th,
body #tableTicketsList thead th {
    border: none !important;
}

/* Remove Bootstrap table borders globally for dark theme */
.table,
.table-bordered,
body .table,
body .table-bordered {
    border-collapse: collapse !important;
}

.table thead th,
.table tbody td,
body .table thead th,
body .table tbody td {
    border-color: rgba(255, 255, 255, 0.05) !important;
}

/* Remove outer table border completely */
.table,
body .table {
    border: none !important;
}

/* ===================================
   iCheck plugin Square skin, blue - EXACT COPY FROM TWENTY-ONE
   =================================== */
.icheckbox_square-blue,
.iradio_square-blue {
    display: inline-block;
    display: inline;
    vertical-align: middle;
    margin: 0;
    padding: 0;
    width: 22px;
    height: 22px;
    background: url(blue.png) no-repeat;
    border: none;
    cursor: pointer;
}

.icheckbox_square-blue {
    background-position: 0 0;
}
    .icheckbox_square-blue.hover {
        background-position: -24px 0;
    }
    .icheckbox_square-blue.checked {
        background-position: -48px 0;
    }
    .icheckbox_square-blue.disabled {
        background-position: -72px 0;
        cursor: default;
    }
    .icheckbox_square-blue.checked.disabled {
        background-position: -96px 0;
    }

.iradio_square-blue {
    background-position: -120px 0;
}
    .iradio_square-blue.hover {
        background-position: -144px 0;
    }
    .iradio_square-blue.checked {
        background-position: -168px 0;
    }
    .iradio_square-blue.disabled {
        background-position: -192px 0;
        cursor: default;
    }
    .iradio_square-blue.checked.disabled {
        background-position: -216px 0;
    }

/* HiDPI support */
@media (-o-min-device-pixel-ratio: 5/4), (-webkit-min-device-pixel-ratio: 1.25), (min-resolution: 120dpi), (min-resolution: 1.25dppx) {
    .icheckbox_square-blue,
    .iradio_square-blue {
        background-image: url(blue@2x.png);
        -webkit-background-size: 240px 24px;
        background-size: 240px 24px;
    }
}

/* ===================================
   View Details Button Styling - Clean White Text Only
   =================================== */
.btn-view-details,
button.btn-view-details,
.btn-default.btn-view-details,
.btn-sm.btn-view-details,
.btn.btn-view-details {
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    border-color: transparent !important;
    padding: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: color 0.3s ease !important;
}

.btn-view-details:hover,
button.btn-view-details:hover,
.btn-default.btn-view-details:hover,
.btn-sm.btn-view-details:hover,
.btn.btn-view-details:hover {
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    border-color: transparent !important;
    color: #266AF2 !important;
    transform: none !important;
    box-shadow: none !important;
    text-shadow: none !important;
}

.btn-view-details:active,
.btn-view-details:focus,
button.btn-view-details:active,
button.btn-view-details:focus,
.btn-sm.btn-view-details:active,
.btn-sm.btn-view-details:focus {
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    border-color: transparent !important;
    box-shadow: none !important;
    text-shadow: none !important;
    outline: none !important;
}

/* Ensure icon and text stay clean */
.btn-view-details i,
.btn-view-details span,
button.btn-view-details i,
button.btn-view-details span {
    color: inherit !important;
}

/* ===================================
   Product Status Styling - FlexyNode Dark Theme
   =================================== */
.product-status {
    background: linear-gradient(135deg, #11111A, #14141d) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    padding: 24px !important;
}

/* Product Icon - Remove white/gray background */
div.product-details div.product-icon,
.product-details .product-icon,
.product-status .product-icon {
    background-color: transparent !important;
    background: none !important;
    background-image: none !important;
    border: none !important;
    padding: 20px !important;
}

/* Active Status - Green */
.product-status-active .product-icon .fa-stack-2x {
    color: #10b981 !important;
}

.product-status-active .product-status-text {
    color: #ffffff !important;
}

/* Pending Status - Orange */
.product-status-pending .product-icon .fa-stack-2x {
    color: #f59e0b !important;
}

.product-status-pending .product-status-text {
    color: #ffffff !important;
}

/* Suspended Status - Blue */
.product-status-suspended .product-icon .fa-stack-2x {
    color: #3b82f6 !important;
}

.product-status-suspended .product-status-text {
    color: #ffffff !important;
}

/* Terminated/Cancelled Status - Red */
.product-status-terminated .product-icon .fa-stack-2x,
.product-status-cancelled .product-icon .fa-stack-2x {
    color: #ef4444 !important;
}

.product-status-terminated .product-status-text,
.product-status-cancelled .product-status-text {
    color: #ffffff !important;
}

/* Fraud Status - Dark Red */
.product-status-fraud .product-icon .fa-stack-2x {
    color: #991b1b !important;
}

.product-status-fraud .product-status-text {
    color: #ffffff !important;
}

/* Default icon and text styling */
.product-status .product-icon .fa-stack-2x {
    color: #266AF2 !important;
}

.product-status .product-status-text {
    color: #ffffff !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-top: 12px !important;
}

/* ===================================
   Product Status Card & Icon - Override Theme Colors
   =================================== */
.product-status,
.product-status-active,
.product-status-pending,
.product-status-suspended,
.product-status-terminated,
.product-status-cancelled,
.product-status-fraud {
    background: linear-gradient(135deg, #11111A, #14141d) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    padding: 24px !important;
}

div.product-details div.product-icon,
.product-details .product-icon,
.product-status .product-icon {
    background: linear-gradient(135deg, #11111A, #14141d) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    padding: 30px !important;
}

/* Status Badge Styling */
.product-status-text {
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    padding: 4px 12px !important;
    border-radius: 16px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 8px auto 0 auto !important;
}

.product-status-active .product-status-text {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3) !important;
}

.product-status-pending .product-status-text {
    background: linear-gradient(135deg, #f59e0b, #d97706) !important;
    box-shadow: 0 2px 8px rgba(245, 158, 11, 0.3) !important;
}

.product-status-suspended .product-status-text {
    background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.3) !important;
}

.product-status-terminated .product-status-text,
.product-status-cancelled .product-status-text {
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
    box-shadow: 0 2px 8px rgba(239, 68, 68, 0.3) !important;
}

.product-status-fraud .product-status-text {
    background: linear-gradient(135deg, #991b1b, #7f1d1d) !important;
    box-shadow: 0 2px 8px rgba(153, 27, 27, 0.3) !important;
}

/* Product title and category sizes */
.product-icon h3 {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
}

.product-icon h4 {
    font-size: 1rem !important;
    font-weight: 500 !important;
}

/* Product Details Tab Container */
.product-details-tab-container,
div.product-details-tab-container {
    background-color: transparent !important;
    background: none !important;
}

/* Unpaid Invoice Alert Button */
#alertUnpaidInvoice .float-right,
#alertOverdueInvoice .float-right {
    margin-top: -4px !important;
}

/* ===================================
   GRADIENT BUTTON HOVER - KEEP TEXT WHITE
   =================================== */

/* Gradient buttons should keep white text on hover */
a.bg-gradient-to-r,
a[class*="bg-gradient"],
.bg-gradient-to-r a,
a.inline-flex.bg-gradient-to-r {
    color: #ffffff !important;
}

a.bg-gradient-to-r:hover,
a[class*="bg-gradient"]:hover,
.bg-gradient-to-r a:hover,
a.inline-flex.bg-gradient-to-r:hover {
    color: #ffffff !important;
    text-decoration: none !important;
}

/* ============================================
   PHONE NUMBER INPUT & COUNTRY SELECTOR STYLING
   ============================================ */

/* Country dropdown list - keep default white background with black text */
.intl-tel-input .country-list {
    background-color: #ffffff !important;
    border: 1px solid #ccc !important;
    box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.2) !important;
}

/* Individual country items - black text */
.intl-tel-input .country-list .country {
    color: #000000 !important;
    padding: 8px 10px !important;
}

/* Country name text - black */
.intl-tel-input .country-list .country .country-name {
    color: #000000 !important;
}

/* Dial code text - dark gray */
.intl-tel-input .country-list .country .dial-code {
    color: #666666 !important;
}

/* Hover state for country items */
.intl-tel-input .country-list .country.highlight,
.intl-tel-input .country-list .country:hover {
    background-color: rgba(0, 0, 0, 0.05) !important;
    color: #000000 !important;
}

/* Selected country flag button */
.intl-tel-input .selected-flag {
    background-color: transparent !important;
}

.intl-tel-input .selected-flag:hover {
    background-color: rgba(38, 106, 242, 0.1) !important;
}

/* Phone number input field - shift placeholder text far to the right to show dial code */
.intl-tel-input input[type="tel"],
.intl-tel-input input[type="text"] {
    padding-left: 85px !important; /* Much more space to show +31 before placeholder */
    background-color: #11111A !important;
    color: #ffffff !important;
    border: 1px solid #266AF2 !important;
}

/* Placeholder text color and positioning */
.intl-tel-input input[type="tel"]::placeholder,
.intl-tel-input input[type="text"]::placeholder {
    color: #6B7280 !important;
}

/* Flag container positioning */
.intl-tel-input .flag-container {
    right: auto !important;
    left: 0 !important;
}

/* Divider line in dropdown */
.intl-tel-input .country-list .divider {
    border-bottom: 1px solid #ccc !important;
}

/* Arrow icon color */
.intl-tel-input .selected-flag .iti-arrow {
    border-top-color: #555 !important;
}

.intl-tel-input .selected-flag .iti-arrow.up {
    border-bottom-color: #555 !important;
}

/* ============================================
   EMAIL VIEWER (viewemail.tpl) STYLING
   ============================================ */

/* Email content styling */
.email-content {
    color: #ffffff !important;
    line-height: 1.7;
}

.email-content p {
    color: #ffffff !important;
    margin-bottom: 1em;
}

.email-content a {
    color: #266AF2 !important;
    text-decoration: underline;
}

.email-content a:hover {
    color: #4E14E0 !important;
}

.email-content strong,
.email-content b {
    color: #ffffff !important;
    font-weight: 600;
}

.email-content table {
    color: #ffffff !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
}

.email-content td,
.email-content th {
    color: #ffffff !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
}

.email-content ul,
.email-content ol {
    color: #ffffff !important;
    margin-left: 1.5em;
}

.email-content li {
    color: #ffffff !important;
    margin-bottom: 0.5em;
}

/* Ensure all text inside email body is white */
.email-content * {
    color: #ffffff !important;
}

.email-content a * {
    color: #266AF2 !important;
}

/* ============================================
   REMOVE UGLY #204060 TURQUOISE HOVER COLOR
   Override Bootstrap's default link hover colors
   ============================================ */

/* Override Bootstrap link hover colors - keep original color */
a:hover,
a:focus,
a:active {
    color: inherit !important;
    text-decoration: none !important;
}

/* Button link - no color change */
.btn-link:hover,
.btn-link:focus,
.btn-link:active {
    text-decoration: none !important;
}

/* Pagination link - no ugly blue */
.page-link:hover,
.page-link:focus,
.page-link:active {
    text-decoration: none !important;
}

/* Remove the ugly #204060 and #369 colors completely */
*[style*="#204060"],
*[style*="#369"] {
    color: #ffffff !important;
}
