/* ============================================
   DESIGN SYSTEM - Aligned with HostHavoc Nuxt App
   ============================================ */

:root {
    /* ---- Brand Colors (from Nuxt app) ---- */
    --main-color: #0096FF;
    --main-color-hover: #3BAEFF;
    --blue: #0096FF;
    --blue-hover: #3BAEFF;
    --blue-subtle: rgba(0, 150, 255, 0.1);
    --blue-glow: rgba(0, 150, 255, 0.25);

    --red: #E40000;
    --red-hover: #FF1616;
    --red-subtle: rgba(228, 0, 0, 0.1);

    --green: #6AEB34;
    --green-hover: #85FE53;
    --green-subtle: rgba(106, 235, 52, 0.1);

    --gold: #f59e0b;
    --gold-hover: #fbbf24;
    --gold-subtle: rgba(245, 158, 11, 0.1);

    --orange: #ff8e2b;

    /* ---- Background Layers (from Nuxt app) ---- */
    --body-bg: #15161E;
    --surface-1: #1a1b23;
    --surface-2: #1f2028;
    --surface-3: #23242B;
    --surface-4: #2a2b33;
    --light-bg: #23242B;
    --lighter-bg: #3d3f49;

    /* ---- Text Colors (from Nuxt app) ---- */
    --text-primary: #ffffff;
    --text-secondary: #BBBBC5;
    --text-tertiary: #8a8a96;
    --text-muted: #6a6a76;
    --main-header-color: #ffffff;
    --main-text-color: #BBBBC5;
    --strong-color: #ffffff;

    /* ---- Border & Dividers (from Nuxt app) ---- */
    --border-color: #30303A;
    --border-subtle: rgba(255, 255, 255, 0.06);
    --border-hover: rgba(255, 255, 255, 0.12);
    --divider: rgba(255, 255, 255, 0.06);

    /* ---- Shadows ---- */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.25);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.3);
    --shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.4);
    --shadow-glow: 0 0 40px rgba(0, 150, 255, 0.15);
    --shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.03);

    /* ---- Typography ---- */
    --font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-mono: 'JetBrains Mono', 'Fira Code', monospace;

    --text-xs: 0.75rem;
    --text-sm: 0.8125rem;
    --text-base: 0.9375rem;
    --text-lg: 1.0625rem;
    --text-xl: 1.25rem;
    --text-2xl: 1.5rem;
    --text-3xl: 1.875rem;

    /* ---- Spacing ---- */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;

    /* ---- Border Radius ---- */
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 14px;
    --radius-xl: 18px;
    --radius-full: 9999px;

    /* ---- Transitions ---- */
    --transition-fast: 0.15s ease;
    --transition-base: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 0.4s cubic-bezier(0.4, 0, 0.2, 1);

    /* ---- Glass Effect ---- */
    --glass-bg: linear-gradient(145deg, rgba(35, 36, 43, 0.85) 0%, rgba(26, 27, 35, 0.95) 100%);
    --glass-border: rgba(255, 255, 255, 0.06);
    --glass-shine: linear-gradient(180deg, rgba(255, 255, 255, 0.03) 0%, transparent 50%);
}

/* ============================================
   GLOBAL TYPOGRAPHY & BASE STYLES
   ============================================ */

body {
    font-family: var(--font-sans);
    font-size: var(--text-base);
    line-height: 1.6;
    color: var(--text-secondary);
    background-color: var(--body-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--font-sans);
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.3;
    letter-spacing: -0.01em;
}

h1, .h1 { font-size: var(--text-3xl); font-weight: 700; }
h2, .h2 { font-size: var(--text-2xl); }
h3, .h3 { font-size: var(--text-xl); }
h4, .h4 { font-size: var(--text-lg); }

a {
    color: var(--blue);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--blue-hover);
    text-decoration: none;
}

/* Selection styling */
::selection {
    background: var(--blue);
    color: white;
}

/* Smooth scrolling */
html {
    scroll-behavior: smooth;
}

/* ============================================
   GLOBAL FORM STYLING - Dark Theme Inputs
   ============================================ */

/* Base input styles */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="url"],
input[type="search"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
.form-control,
.field {
    background: #1b1c24 !important;
    border: none !important;
    border-radius: 8px !important;
    color: #fff !important;
    height: 46px !important;
    line-height: 46px !important;
    font-size: 16px !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

/* Textarea - needs different height handling */
textarea,
textarea.form-control,
textarea.field {
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    color: #fff !important;
    padding: 14px 16px !important;
    height: auto !important;
    line-height: 1.5 !important;
    font-size: 16px !important;
    min-height: 100px !important;
    resize: vertical !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

/* Select base */
select,
select.form-control,
select.field {
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    color: #fff !important;
    font-size: 16px !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

/* Focus states for standalone inputs */
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="date"]:focus,
input[type="time"]:focus,
input[type="datetime-local"]:focus,
textarea:focus,
select:focus,
.form-control:focus,
.field:focus {
    outline: none !important;
    border-color: var(--blue) !important;
    box-shadow: none !important;
}

/* Remove glow for inputs inside containers (container handles the glow) */
.input-group input:focus,
.input-group .form-control:focus,
.login-input-group input:focus,
.prepend-icon input:focus,
.prepend-icon .form-control:focus {
    border-color: transparent !important;
    box-shadow: none !important;
}

input::placeholder,
textarea::placeholder,
.form-control::placeholder,
.field::placeholder {
    color: #6b7280 !important;
}

/* Select dropdown arrow */
select,
select.form-control,
select.field {
    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='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    padding: 0 36px 0 16px !important;
    height: 46px !important;
    line-height: 46px !important;
    cursor: pointer !important;
}

select option,
select.form-control option,
select.field option {
    background: #1b1c24 !important;
    color: #fff !important;
    padding: 10px !important;
}

/* Markdown Editor (Support Tickets) */
.md-editor {
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
}

.md-editor .md-header {
    background: #23242b !important;
    border-bottom: 1px solid var(--border-color) !important;
    padding: 8px !important;
}

.md-editor .md-header .btn,
.md-editor .md-header .btn-default {
    background: #2d2e36 !important;
    border: 1px solid var(--border-color) !important;
    color: #bbbbc5 !important;
    padding: 6px 10px !important;
    height: auto !important;
    line-height: 1.4 !important;
}

.md-editor .md-header .btn:hover,
.md-editor .md-header .btn-default:hover {
    background: #3d3e46 !important;
    color: #fff !important;
}

.md-editor .md-header .btn.btn-primary {
    background: var(--blue) !important;
    border-color: var(--blue) !important;
    color: #fff !important;
}

.md-editor .md-header .btn.btn-primary:hover {
    background: var(--blue-hover) !important;
}

.md-editor textarea,
.md-editor .md-input,
.md-editor textarea.form-control,
.md-editor textarea.markdown-editor,
textarea.markdown-editor,
textarea.md-input,
.markdown-editor.md-input,
#inputMessage,
textarea#inputMessage {
    background: #1b1c24 !important;
    background-color: #1b1c24 !important;
    border: none !important;
    border-radius: 0 !important;
    color: #fff !important;
    padding: 14px 16px !important;
    min-height: 200px !important;
    caret-color: #fff !important;
    -webkit-text-fill-color: #fff !important;
}

.md-editor .md-footer {
    background: #23242b !important;
    border-top: 1px solid var(--border-color) !important;
    padding: 8px 12px !important;
    color: #6b7280 !important;
}

.md-editor .md-footer .markdown-editor-status,
.md-editor .md-footer .small-font {
    color: #6b7280 !important;
}

.md-editor .md-controls a,
.md-editor .md-fullscreen-controls a {
    color: #6b7280 !important;
}

.md-editor .md-controls a:hover,
.md-editor .md-fullscreen-controls a:hover {
    color: #fff !important;
}

/* Custom File Upload */
.custom-file {
    position: relative !important;
    height: 46px !important;
}

.custom-file-label {
    background: #1b1c24 !important;
    background-color: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    color: #bbbbc5 !important;
    height: 46px !important;
    line-height: 32px !important;
    padding: 7px 16px !important;
    margin: 0 !important;
}

.custom-file-label::after {
    background: #2d2e36 !important;
    border: none !important;
    border-left: 1px solid var(--border-color) !important;
    border-radius: 0 7px 7px 0 !important;
    color: #fff !important;
    height: 100% !important;
    line-height: 32px !important;
    padding: 6px 16px !important;
    top: 0 !important;
    bottom: 0 !important;
    transition: background 0.2s ease !important;
    cursor: pointer !important;
}

.custom-file-label,
.custom-file-input {
    cursor: pointer !important;
}

.custom-file:hover .custom-file-label::after,
.custom-file-input:hover ~ .custom-file-label::after {
    background: #3d3e46 !important;
}

/* Override input-group rounding on custom-file */
.input-group .custom-file-label::after,
.input-group > .custom-file:not(:last-child) .custom-file-label::after,
.attachment-group .custom-file-label::after {
    border-radius: 0 !important;
}

.custom-file-input:focus ~ .custom-file-label {
    border-color: var(--blue) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15) !important;
}

.attachment-group .input-group-append .btn,
.attachment-group .btn-default,
#btnTicketAttachmentsAdd {
    background: #2d2e36 !important;
    border: 1px solid var(--border-color) !important;
    color: #fff !important;
    height: 46px !important;
}

.attachment-group .input-group-append .btn:hover,
.attachment-group .btn-default:hover,
#btnTicketAttachmentsAdd:hover {
    background: #3d3e46 !important;
}

/* Markdown Editor Fullscreen Mode */
.md-editor.md-fullscreen-mode {
    background: #23242b !important;
    background-color: #23242b !important;
}

.md-editor.md-fullscreen-mode textarea,
.md-editor.md-fullscreen-mode .md-input {
    background: #1b1c24 !important;
    background-color: #1b1c24 !important;
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
}

/* Labels */
label,
.form-group label,
.control-label,
.col-form-label {
    color: #fff !important;
    font-weight: 500 !important;
    font-size: 15px !important;
    margin-bottom: 8px !important;
    display: block !important;
}

/* Form groups */
.form-group {
    margin-bottom: 20px !important;
}

/* Input groups (Bootstrap) */
.input-group {
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
}

.input-group:focus-within {
    border-color: var(--blue) !important;
    box-shadow: none !important;
}

.input-group .form-control,
.input-group .field,
.input-group input,
.input-group input[type="text"],
.input-group input[type="email"],
.input-group input[type="password"] {
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
}

.input-group .form-control:focus,
.input-group .field:focus,
.input-group input:focus {
    box-shadow: none !important;
    border: none !important;
    outline: none !important;
}

/* Login form input groups */
.login-input-group {
    display: flex;
    align-items: center;
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    padding: 0 12px !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

.login-input-group:focus-within {
    border-color: var(--blue) !important;
    box-shadow: none !important;
}

.login-input-group .login-input-icon {
    color: #6b7280 !important;
    margin-right: 10px;
}

.login-input-group .login-input {
    flex: 1;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    height: 46px !important;
    line-height: 46px !important;
    outline: none !important;
}

.login-input-group .login-input:focus {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

.login-input-group .login-reveal-btn {
    background: transparent !important;
    border: none !important;
    color: #6b7280 !important;
    padding: 0 4px !important;
    cursor: pointer;
}

.login-input-group .login-reveal-btn:hover {
    color: #fff !important;
}

/* Login remember me checkbox */
.login-remember {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.login-remember input[type="checkbox"] {
    margin: 0 !important;
}

/* Domain Register panel on homepage */
#registerDomainPanel .input-group {
    background: transparent !important;
    border: none !important;
}

#registerDomainPanel .input-group .form-control {
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px 0 0 8px !important;
    height: 46px !important;
}

#registerDomainPanel .input-group-btn,
#registerDomainPanel .input-group-append {
    display: flex !important;
}

#registerDomainPanel .input-group-btn .btn,
#registerDomainPanel .input-group-append .btn {
    border-radius: 0 !important;
    height: 46px !important;
    background: #2a2b36 !important;
    border: 1px solid var(--border-color) !important;
    border-left: none !important;
    color: #fff !important;
    padding: 0 16px !important;
    font-weight: 500 !important;
    transition: all 0.2s ease !important;
}

#registerDomainPanel .input-group-btn .btn:hover,
#registerDomainPanel .input-group-append .btn:hover {
    background: #3a3b46 !important;
}

#registerDomainPanel .input-group-btn .btn:focus,
#registerDomainPanel .input-group-append .btn:focus,
#registerDomainPanel .input-group-btn .btn:active,
#registerDomainPanel .input-group-append .btn:active {
    background: #3a3b46 !important;
    box-shadow: none !important;
    outline: none !important;
}

#registerDomainPanel .input-group-btn .btn:last-child,
#registerDomainPanel .input-group-append .btn:last-child {
    border-radius: 0 8px 8px 0 !important;
}

#registerDomainPanel .input-group:focus-within {
    border-color: var(--border-color) !important;
    box-shadow: none !important;
}

#registerDomainPanel .input-group .form-control:focus {
    border: 1px solid var(--blue) !important;
    box-shadow: 0 0 0 3px rgba(0, 150, 255, 0.25) !important;
    border-radius: 8px 0 0 8px !important;
    outline: none !important;
}

/* Homepage Recent Support Tickets - inline labels */
#ticketsPanel .list-group-item .label {
    display: inline !important;
    padding: 3px 8px !important;
    border-radius: 4px !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    margin-left: 6px !important;
}

.input-group-prepend,
.input-group-append {
    background: transparent !important;
    border: none !important;
}

.input-group-text {
    background: transparent !important;
    border: none !important;
    color: #6b7280 !important;
    padding: 0 12px !important;
}

/* Prepend icon style (WHMCS) */
.prepend-icon {
    position: relative !important;
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

.prepend-icon:focus-within {
    border-color: var(--blue) !important;
    box-shadow: none !important;
}

.prepend-icon .field-icon {
    position: absolute !important;
    left: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    color: #6b7280 !important;
    z-index: 2 !important;
    pointer-events: none !important;
}

.prepend-icon input,
.prepend-icon select,
.prepend-icon .form-control,
.prepend-icon .field,
.prepend-icon input[type="text"],
.prepend-icon input[type="email"],
.prepend-icon input[type="password"],
.prepend-icon input[type="tel"],
.prepend-icon input[type="number"],
.prepend-icon input.form-control,
.prepend-icon input.field {
    padding-left: 40px !important;
    border: none !important;
    border-width: 0 !important;
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.prepend-icon input:focus,
.prepend-icon select:focus,
.prepend-icon .form-control:focus,
.prepend-icon .field:focus,
.prepend-icon input[type="text"]:focus,
.prepend-icon input[type="email"]:focus,
.prepend-icon input[type="password"]:focus {
    border: none !important;
    border-width: 0 !important;
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Checkbox and radio */
input[type="checkbox"],
input[type="radio"] {
    width: 18px !important;
    height: 18px !important;
    accent-color: var(--blue) !important;
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    padding: 0 !important;
    cursor: pointer !important;
}

/* Disabled inputs */
input:disabled,
textarea:disabled,
select:disabled,
.form-control:disabled,
.field:disabled,
input[readonly],
textarea[readonly],
.form-control[readonly] {
    background: #1a1a22 !important;
    color: #6b7280 !important;
    cursor: not-allowed !important;
    opacity: 0.7 !important;
}

/* Card styling for form containers */
.card,
.panel {
    background: #23242b !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}

.card-header,
.panel-heading {
    background: transparent !important;
    border-bottom: 1px solid var(--border-color) !important;
    color: #fff !important;
    font-weight: 600 !important;
}

.card-body,
.panel-body {
    padding: 24px !important;
}

.card-footer,
.panel-footer {
    background: transparent !important;
    border-top: 1px solid var(--border-color) !important;
}

.card-title,
.panel-title {
    color: #fff !important;
    font-weight: 600 !important;
}

/* Help text */
.help-block,
.form-text,
.field-help-text,
small.text-muted {
    color: var(--main-text-color) !important;
    font-size: 12px !important;
    margin-top: 4px !important;
}

/* Validation states */
.has-error .form-control,
.has-error .field,
.is-invalid,
input.error,
select.error,
textarea.error {
    border-color: var(--red) !important;
}

.has-error .form-control:focus,
.has-error .field:focus,
.is-invalid:focus {
    box-shadow: 0 0 0 3px rgba(228, 0, 0, 0.15) !important;
}

.has-success .form-control,
.has-success .field,
.is-valid {
    border-color: var(--green) !important;
}

.error-message,
.help-block.text-danger,
.invalid-feedback {
    color: var(--red) !important;
    font-size: 12px !important;
    margin-top: 4px !important;
}

/* Buttons in forms */
.btn-primary {
    background: var(--blue) !important;
    border-color: var(--blue) !important;
    color: #fff !important;
}

.btn-primary:hover,
.btn-primary:focus {
    background: var(--blue-hover) !important;
    border-color: var(--blue-hover) !important;
}

.btn-default,
.btn-secondary {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    color: #fff !important;
}

.btn-default:hover,
.btn-default:focus,
.btn-secondary:hover,
.btn-secondary:focus {
    background: var(--lighter-bg) !important;
    border-color: var(--blue) !important;
}

/* Alert boxes */
.alert {
    border-radius: 8px !important;
    border: 1px solid !important;
}

.alert-info {
    background: rgba(0, 150, 255, 0.1) !important;
    border-color: var(--blue) !important;
    color: var(--blue) !important;
}

.alert-success {
    background: rgba(106, 235, 52, 0.08) !important;
    border-color: rgba(106, 235, 52, 0.4) !important;
    color: #a8f587 !important;
}

.alert-success a,
.alert-success a:hover {
    color: #6AEB34 !important;
    text-decoration: underline !important;
}

.alert-danger,
.alert-error {
    background: rgba(228, 0, 0, 0.1) !important;
    border-color: var(--red) !important;
    color: var(--red) !important;
}

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

/* Tables */
.table {
    color: #fff !important;
}

.table thead th {
    background: var(--light-bg) !important;
    border-color: var(--border-color) !important;
    color: #fff !important;
    font-weight: 600 !important;
}

.table td,
.table th {
    border-color: var(--border-color) !important;
    padding: 12px 16px !important;
}

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

.table-hover tbody tr:hover {
    background: rgba(0, 150, 255, 0.05) !important;
}

/* ============================================
   END GLOBAL FORM STYLING
   ============================================ */

  /* Proxima Nova */
  
  @font-face {
      font-family: 'Proxima Nova';
      src: url('../webfonts/ProximaNova-Light.woff2') format('woff2'),
          url('../webfonts/ProximaNova-Light.woff') format('woff');
      font-weight: 100;
      font-style: normal;
      font-display: swap;
  }
  
  
  @font-face {
      font-family: 'Proxima Nova';
      src: url('../webfonts/ProximaNova-Regular.woff2') format('woff2'),
          url('../webfonts/ProximaNova-Regular.woff') format('woff');
      font-weight: 300;
      font-style: normal;
      font-display: swap;
  }
  
  
  @font-face {
      font-family: 'Proxima Nova';
      src: url('../webfonts/ProximaNova-Regular.woff2') format('woff2'),
          url('../webfonts/ProximaNova-Regular.woff') format('woff');
      font-weight: 300;
      font-weight: normal;
      font-style: normal;
      font-display: swap;
  }
  
  @font-face {
      font-family: 'Proxima Nova';
      src: url('../webfonts/ProximaNova-Semibold.woff2') format('woff2'),
          url('../webfonts/ProximaNova-Semibold.woff') format('woff');
      font-weight: 500;
      font-style: normal;
      font-display: swap;
  }
  
  
  @font-face {
      font-family: 'Proxima Nova';
      src: url('../webfonts/ProximaNova-Bold.woff2') format('woff2'),
          url('../webfonts/ProximaNova-Bold.woff') format('woff');
      font-weight: 600;
      font-style: normal;
      font-display: swap;
  }
  @font-face {
      font-family: 'Proxima Nova';
      src: url('../webfonts/ProximaNova-Extrabld.woff2') format('woff2'),
          url('../webfonts/ProximaNova-Extrabld.woff') format('woff');
      font-weight: 700;
      font-style: normal;
      font-display: swap;
  }
  @font-face {
      font-family: 'Proxima Nova';
      src: url('../webfonts/ProximaNova-Black.woff2') format('woff2'),
          url('../webfonts/ProximaNova-Black.woff') format('woff');
      font-weight: 900;
      font-style: normal;
      font-display: swap;
  }
  
  
  
  /* Eric Meyer's CSS Reset */
  html, body, div, span, applet, object, iframe,
  h1, h2, h3, h4, h5, h6, p, blockquote, pre,
  a, abbr, acronym, address, big, cite, code,
  del, dfn, em, img, ins, kbd, q, s, samp,
  small, strike, strong, sub, sup, tt, var,
  b, u, i, center,
  dl, dt, dd, ol, ul, li,
  fieldset, form, label, legend,
  table, caption, tbody, tfoot, thead, tr, th, td,
  article, aside, canvas, details, embed,
  figure, figcaption, footer, header, hgroup,
  menu, nav, output, ruby, section, summary,
  time, mark, audio, video {
      margin: 0;
      padding: 0;
      border: 0;
      font-size: 100%;
      font: inherit;
      vertical-align: baseline;
  }
  /* HTML5 display-role reset for older browsers */
  article, aside, details, figcaption, figure,
  footer, header, hgroup, menu, nav, section {
      display: block;
  }
  body {
      line-height: 1;
  }
  ol, ul {
      list-style: none;
  }
  blockquote, q {
      quotes: none;
  }
  blockquote:before, blockquote:after,
  q:before, q:after {
      content: '';
      content: none;
  }
  table {
      border-collapse: collapse;
      border-spacing: 0;
  }
  /* End of Eric Meyer's CSS Reset */
  
  article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {
      display: block;
  }
  
  
  body {
      font-family: 'Proxima Nova', 'Titilium Web', 'Roboto', Verdana, Arial, Helvetica, sans-serif;
      font-size: 16px;
      line-height: 24px;
      color:var(--main-text-color);
      font-weight: 300;
      background:var(--body-bg);
  }
  
  h1,
  h2,
  h3,
  h4,
  h5 {
      color: #fff;
      font-weight: 500;
      font-family:"Proxima Nova", "Roboto", sans-serif;
  }
  
  img {
      line-height: 1;
      vertical-align: bottom;
  }
  
  h1 {
      font-size:36px;
      line-height: 42px;
      font-weight: 600;
  }
  
  h2 {
      font-size: 30px;
      line-height: 38px;
  }
  
  h3 {
      font-size: 24px;
      line-height: 32px;
  }
  
  h4 {
      font-size: 20px;
      line-height: 30px;
  }
  
  h5 {
      font-size: 16px;
      line-height: 28px;
  }
  
  .blue {
      color: var(--blue);
  }
  
  .red {
      color: var(--red);
  }
  
  .green {
      color: var(--green);
  }
  
  .white {
      color:#fff;
  }
  
  a {
      color: var(--main-color);
      font-weight: 500;
      text-decoration: none;
  }
  
  
  a:hover,
  a:active,
  a:focus {
      color: var(--main-color-hover);
      text-decoration: none;
  }
  
  
  .font-300 {
      font-weight:300;
    }
  
  a.underline {
      text-decoration: underline;
  }
  
  .semibold {
    font-weight:500;
  }
  
  .bold {
    font-weight:600;
  }
  
  .extrabold {
    font-weight:700;
  }
  
  .italic {
      font-style:italic;
  }
  
  .black {
    font-weight:900;
  }
  
  
  #topbar .greenlabel, .greenlabel.sm {
      height:18px;
      border-radius:3px;
      line-height:18px;
      font-size:12px;
  }
  
  * {
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
  }
  
  .clearfix:after,
  .container:after,
  .half-list:after {
      visibility: hidden;
      display: block;
      font-size: 0;
      content: " ";
      clear: both;
      height: 0
  }
  
  .container {
      max-width: 1320px;
      width: 100%;
      margin: 0 auto;
      padding-left: var(--bs-gutter-x, .75rem);
      padding-right: var(--bs-gutter-x, .75rem);
  }
  
  strong {
      font-weight: 500;
  }
  
  *:hover {
      -webkit-transition: all .2s ease-in-out;
      -moz-transition: all .2s ease-in-out;
      transition: all .2s ease-in-out;
  }
  
  p {
      padding-bottom: 20px;
  }
  
  .red {color:var(--red)}
  .green {color:var(--green)}
  
  
  
  .button {
      padding: 0px 25px;
      display: inline-block;
      height: 48px;
      line-height: 46px;
      color: #fff !important;
      background: var(--main-color);
      font-size: 16px;
      font-weight: 600;
      border: 1px solid rgba(255,255,255,0.20);
      box-shadow: 0 2px 3px 0 rgba(0,0,0,0.25);
      border-radius: 6px;
  }
  
  .button:hover {
      color: #fff !important;
      text-decoration: none;
      background: var(--main-color-hover);
  }
  
  .button:focus {
      transform: scale(0.97);
      outline: none;
  }
  
  .button:hover .fa-arrow-right-long {
      margin-right:-3px;
      -webkit-transition: all .2s ease-in-out;
      -moz-transition: all .2s ease-in-out;
      transition: all .2s ease-in-out;
  }
  
  .button.outline {
      background: transparent;
      box-shadow: none;
      border: 1px solid #fff;
      color: #fff !important;
  }
  
  .button.outline:hover {
      border-color: var(--main-color);
      color: var(--main-color) !important;
      box-shadow: none;
  }
  
  .button.outline.fullhover:hover {
      background:#fff;
      border-color:#fff;
      color:var(--main-color);
  }
  
  .dark-button {
      background:rgba(0,0,0,0.6);
      box-shadow:unset;
      border: 1px solid rgba(255,255,255,0.03);
  }
  .dark-button:hover {
      background:rgba(0,0,0,0.54);
      border: 1px solid rgba(255,255,255,0.03) !important;
  }
  
  
  .button.lg {
      height: 52px;
      line-height: 50px;
      padding:0px 36px;
      font-size:18px;
  }
  
  .button.red {
      background:var(--red);
  }
  
  .button.red:hover, #topbar .button.red:hover {
      background:var(--red-hover);
  }
  
  .button.secondary {
    background:var(--secondary-color);
  }
  
  .button.secondary:hover {
    background:var(--secondary-color-hover);
  }
  
  .button.disabled {
      cursor: not-allowed;
      opacity: 0.5;
  }
  
  .button.disabled:hover {
    opacity:0.7;
  }
  
  .text-center {
      text-align: center;
  }
  
  .text-lg {
      font-size:1.25rem;
      line-height:1.75rem;
  }
  
  .text-md {
      font-size:1.125rem;
      line-height:1.5rem;
  }
  
  .width-60 {
      width:60%;
  }
  
  .width-75 {
      width:75%;
  }
  
  .pull-left-img {
      float:left;
      margin-right:2rem;
  }
  
  .text-left {
      text-align:left;
  }
  
  .inline-block {
      display:inline-block;
  }
  
  .block {
      display:block;
  }
  
  .mt-8 {
      margin-top:8rem;
  }
  
  .mt-7 {
      margin-top:7rem;
  }
  
  .mt-6 {
      margin-top:6.25rem;
  }
  
  .text-sm {
      font-size:0.75rem;
  }
  
  .mute {
      opacity:0.75;
  }
  
  .va-sub {
      vertical-align: sub;
  }
  
  .va-mid {
      vertical-align: middle;
  }
  
  .va-top {
      vertical-align: top;
  }
  
  .va-base {
    vertical-align:baseline;
  }
  
  .va-bot {
    vertical-align: bottom;
  }
  
  .ml-auto {
      margin-left:auto;
  }
  
  .pull-right{float:right;}
  .pull-left{float:left;}
  
  .header {
    padding:35px 0px 35px 0px;
  }

  .header a {
    color: var(--main-text-color);
    font-style:normal;
  }
  
  .header a:hover {
    color:var(--main-color);
  }
  
  #main-navigation li {
    float:left;
    line-height:44px;
  }
  
  #main-navigation li a, #main-navigation li a.button {
    font-weight:500;
    color:#fff;
    display:block;
  }
  
  #main-navigation li a:hover {
    color:var(--main-color);
  }
  
  #topbar {
      background:var(--light-bg);
      line-height:44px;
      font-size:14px;
  }
  
  #topbar ul li a {
      line-height:44px;
      display:block;
      padding:0px 12px;
      color:#fff;
  }
  
  #topbar ul li a:hover {
      background:#1A1B25;
      color:var(--main-color);
  }

  #topbar .header-locale-btn {
      background: transparent;
      border: 1px solid var(--border-color);
      color: #fff;
      font-size: 13px;
      font-weight: 500;
      padding: 6px 14px;
      border-radius: 6px;
      line-height: 1;
      margin: 0 12px 0 0;
      vertical-align: middle;
      display: inline-flex;
      align-items: center;
      height: 32px;
  }

  #topbar .header-locale-btn:hover {
      border-color: var(--blue);
      color: var(--blue);
  }

  #topbar .header-locale-btn i {
      font-size: 10px;
      opacity: 0.7;
  }

  #topbar ul li:has(.header-locale-btn) {
      display: inline-flex;
      align-items: center;
      height: 44px;
  }

  #topbar ul li .header-locale-btn {
      line-height: 1;
      margin-top: 0;
  }
  
  #topbar .button.red:hover {
      background:var(--red-hover) !important;
  }
  
  #topbar .button.red {
      line-height:46px !important;
  }
  
  
  
  .white-link {
      color:#fff;
  }
  
  .white-link:hover {
      color:var(--blue);
  }
  
  
  .overflow-right {
      position: absolute;
      width:66.6667%;
      top:0px;
      right:0px;
      padding:0px 30px;
      max-width:1600px;
  }
  
  .relative {
      position: relative;
  }
  
  .opacity-50 {
      opacity:0.50;
  }
  
  .opacity-766{
      opacity:0.66;
  }
  
  .opacity-75 {
      opacity:0.75;
  }
  
  .blog-thumbnail {
      border-radius:6px;
      max-width:100%;
  }
  
  .footer {
      padding:90px 0px 30px 0px;
      background:rgba(0,0,0,0.33);
  }
  
  .footer ul li a {
      color:var(--main-text-color);
      font-weight:300;
      display:block;
      padding:2px 0px;
  }
  
  .footer ul li a:hover {
      color:var(--blue);
      padding-left:3px;
  }
  
  .light-bg {
      background:var(--light-bg);
  }
  
  
  
  .py-88 {
      padding:88px 0px;
  }
  
  .py-68 {
      padding:68px 0px;
  }
  
  .py-48{
      padding:48px 0px;
  }
  
  
  .select-list, .select {
      height:56px;
      line-height:54px;
      border-radius:5px;
      border:1px solid rgba(255,255,255,0.16);
      background:url('../images/select-down.svg') center right 20px no-repeat;
      padding-right:60px; 
  }
  
  .select {
      font-family:"Proxima Nova",sans-serif;
      color:#fff;
      font-size:16px;
      -webkit-appearance:none;
      -moz-appearance:none;
      appearance:none;
  }
  
  .select:focus {
      outline:none;
      border:0px;
  }
  
  
  .blue-bg {
      background:var(--blue);
      color:#fff;
  }
  
  .blue-bg a {
      color:#fff;
  }
  
  .blue-bg a:hover {
      color:#fff;
      border-bottom:1px solid #fff;
  }
  
  .px-60 {
      padding-left:60px;
      padding-right:60px;
  }
  
  .fa-arrow-right-long {
      padding-bottom:1px;
  }
  
  
  .input, .textarea, .select {
      background: rgba(255,255,255,0.01);
      border: 1px solid rgba(151,151,151,0.12);
      border-radius: 5px;
      height:58px;
      width:100%;
      display:block;
      padding:0px 20px 0px 48px;
      font-family:"Proxima Nova",sans-serif;
      font-size:16px;
      color:#CFCFD5;
      position: relative;
  }
  
  .textarea {
      height:220px;
      padding:18px 20px 20px 20px;
  }
  
  .input::placeholder, .textarea::placeholder {
      color:rgba(207,207,213,0.66);
  }
  
  .select {
      background:url('../images/select-down.svg') center right 20px no-repeat rgba(255,255,255,0.01);
      -webkit-appearance:none;
      -moz-appearance:none;
      appearance:none;
      color:#fff;
      font-weight:500;
      padding-left:20px;
  }
  
  .select:focus {
      border: 1px solid rgba(151,151,151,0.12);
  }
  
  .input:hover, .textarea:hover, .select:hover {
      background: rgba(255,255,255,0.02);
      border: 1px solid rgba(151,151,151,0.16);
  }
  
  .select:hover {
      background:url('../images/select-down.svg') center right 20px no-repeat rgba(255,255,255,0.02);
  }
  
  .input-group-label {
      float:left;
      display:inline-block;
      width:20%;
      border-radius:5px 0px 0px 5px;
      background: rgba(255,255,255,0.01);
      border: 1px solid rgba(151,151,151,0.12);
      border-right:0px;
      color:rgba(207,207,213,0.66);
      height:58px;
      line-height:56px;
      padding-left:48px;
      position: relative;
  }
  
  
  .input-group-select {
      width:80%;
      float:left;
      display:inline-block;
      border-radius:0px 5px 5px 0px;
  }
  
  .input:focus, .textarea:focus, .select:focus {
      outline:none;
      border-color:var(--blue);
      background: rgba(255,255,255,0.03);
  }
  
  .select:focus {
      background:url('../images/select-down.svg') center right 20px no-repeat rgba(255,255,255,0.03);
  }
  
  .dedi-toggle:nth-last-child(1) {
      margin-bottom:0px;
  }
  
  
  .row-mods {
      padding:0px 5px;
  }
  
  .row-mods .col {
      padding:0px 10px;
  }
  
  .dropdown-style {
      position: absolute;
      top:60px;
      right:50%;
      background:var(--light-bg);
      min-width:260px;
      transform: translateX(50%); 
      padding:6px;
      border-radius:6px;
      z-index:1001;
      box-shadow: 0 2px 8px 1px rgba(0,0,0,0.22);
      font-size:16px;
  }
  
  
  .dropdown-style:before {
      width:20px;
      height:20px;
      transform:rotate(45deg);
      background:var(--light-bg);
      border-radius:3px;
      content:" ";
      position: absolute;
      left:50%;
      margin-left:-10px;
      top:-3px;
      z-index:-999;
  }
  
  .account-top {
      padding:18px 18px 6px 18px;
  }
  
  .account-bottom {
      background:#2E2F39;
      border-radius:0px 0px 6px 6px;
      padding:6px 0px 6px 0px;
  }
  
  .account-top ul li a {
      padding-left:0px !important;
      padding-right:0px !important;
  }
  
  .account-bottom ul li a {
      padding-left:18px !important;
      padding-right:18px !important;
  }
  
  
  .dropdown-style ul li a:hover {
      background:rgba(255,255,255,0.0) !important;
  }
  
  .dropdown-style .account-bottom ul li a:hover {
      background:rgba(255,255,255,0.02) !important;
  }
  
  .dropdown-style ul li a i {
      padding-bottom:1px;
  }
  
  #main-navigation .dropdown-style {
      padding:6px;
      top:44px;
      display:none;
  }
  
  
  #main-navigation li:hover .dropdown-style {
      display:block !important;
  }
  
  
  #main-navigation li:hover a.dropdown-link {
      color:var(--blue);
  }
  
  
  #main-navigation .dropdown-style li,
  .dropdown-style li {
      padding: 0 !important;
      margin: 0 !important;
      background: transparent !important;
      display: block;
      width: 100%;
  }

  #main-navigation .dropdown-style li:hover,
  .dropdown-style li:hover {
      background: transparent !important;
  }
  
  #main-navigation .dropdown-style li a {
      padding:2px 18px !important;
      display:block;
      position: relative;
  }
  
  #main-navigation .dropdown-style li a:hover {
      background:rgba(255,255,255,0.04) !important;
      border-radius:6px;
  }
  
  #main-navigation .dropdown-style li a i {
      width:18px;
      text-align:center;
  }
  
  #topbar  .dropdown-style {
      display:none;
  }
  
  #topbar li:hover .dropdown-style {
      display:block !important;
  }
  
  #topbar li:hover .dropdown-link {
      background: #1A1B25;
      color: var(--main-color);
  }
  
  #topbar li.drop-li {    
      height: 44px;
  }
  
  .game-server-promo span.font-14{
      margin-top:-2px;
  }
  
  .footer span.semibold {
      color:#fff;
  }
  
  
  
  ::-webkit-scrollbar {
      width: 12px;
    }
    
    ::-webkit-scrollbar-thumb {
      background-image: linear-gradient(180deg, #1692E9 0%, #40CFFF 100%);
      border: 3px solid #101119;
      border-radius: 6px;
      background-clip: padding-box;
    }
    
    ::-webkit-scrollbar-track {
      background-color: #101119;
      border-radius: 18px;
      width:18px;
      border:3px solid #151721;
  
    }
    
  
    .header {
      position: relative;
    }
  
    .button_container {
      display:none;
      position: absolute;
      top:28px;
      width:60px;
      text-align:right;
      right:0px;
    }

    .button_container:hover a {
        cursor: pointer;
    }
  
    .button_container a {
      color:white;
    }
  
    .button_container a:hover {
      color:var(--blue);
    }
  
    .header .main-nav-col.active {
      display:block;
      background: var(--light-bg);
      margin-bottom:15px;
    }
  
    .header .main-nav-col.active li:hover .dropdown-style {
      position: relative;
      display:none;
      top: unset !important;
      right:unset;
      transform:unset;
      min-width:100%;
    }
  
    .header .main-nav-col li {
      text-align:center;
    }
    .header .main-nav-col.active li,   .header .main-nav-col.active #main-navigation {
      width:100%;
      display:block;
      text-align:center;
    }
    
    .header .main-nav-col.active #main-navigation li {
      float:none !important;
    }
  
    #main-navigation li .dropdown-style li {
      float:none;
      text-align:left;
    }
  
    .header .main-nav-col.active #main-navigation li .dropdown-style li {
      text-align:center;
    }
  
    .header .main-nav-col.active {
      padding:12px 12px !important;
    }
  
    .header .main-nav-col.active .dropdown-style  {
      background:var(--lighter-bg);
      box-shadow:unset;
      margin-top:10px;
    }
    .header .main-nav-col.active .dropdown-style:before {
      background:var(--lighter-bg);
    }
  
    .button_container.active a {
      color:var(--blue);
    }
    .button_container.active a:hover {
      color:var(--blue-hover);
    }
  
  
    .button_container .fa-xmark-large {
      display:none;
    }
  
    .button_container.active .fa-bars {
      display:none;
    }
  
    .button_container.active .fa-xmark-large {
      display:block;
    }
  
  
    .showmobile {
      display:none;
    }
  
  
  html, body {
      overflow-x:hidden;
    }
  
    .overflow-fix {
      overflow-x:unset;
    }
  
    @media only screen and (max-width: 1600px) and (min-width: 1320px)  {    

      
      .overflow-right {
          width:68.5%;
      }
      #topbar .dropdown-style {
        right: 0;
        unset: 0;
        transform: unset;
        top: 52px;
      }
      
      #topbar .dropdown-style:before {
        right: 5px;
        left: unset;
      }
    }
  
  
    ::selection {
      background: rgba(0,150,255,0.86);
      color: #fff;
    }
  
/* WHMCS CSS */


.btn{
    font-family:"Proxima Nova", sans-serif !important;
    font-weight:600!important;
    border-radius:0!important;
    border-radius:5px!important;
    font-size:16px;
    padding:5px 18px
}
.btn-primary{
    color:#fff;
    background-color:var(--blue);
    border-color:var(--blue);
}
.btn-primary:hover,.btn-primary:focus,.btn-primary:active{
    color:#fff;
    background-color:var(--blue-hover);
    border-color:var(--blue-hover);
    box-shadow:none
}
.btn-primary.active.focus,.btn-primary.active:focus,.btn-primary.active:hover,.btn-primary:active.focus,.btn-primary:active:focus,.btn-primary:active:hover,.open>.dropdown-toggle.btn-primary.focus,.open>.dropdown-toggle.btn-primary:focus,.open>.dropdown-toggle.btn-primary:hover{
    background-color:#158ee4;
    border-color:#158ee4;
    box-shadow:none
}
.navbar-main .navbar-nav>.active>a,.navbar-main .navbar-nav>.active>a:focus,.navbar-main .navbar-nav>.active>a:hover,.navbar-main .navbar-nav>.open>a,.navbar-main .navbar-nav>.open>a:focus,.navbar-main .navbar-nav>.open>a:hover,.navbar-main .navbar-nav>li>a:focus,.navbar-main .navbar-nav>li>a:hover{
    background-color:#0f7fce
}
.btn-warning,.label-warning{
    color:#fff;
    background-color:var(--red);
    border-color:var(--red);
    box-shadow:none
}
.btn-warning:hover,.btn-warning.active.focus,.btn-warning.active:focus,.btn-warning.active:hover,.btn-warning:active.focus,.btn-warning:active:focus,.btn-warning:active:hover,.open>.dropdown-toggle.btn-warning.focus,.open>.dropdown-toggle.btn-warning:focus,.open>.dropdown-toggle.btn-warning:hover,.label-warning:hover,.label-warning[href]:focus,.label-warning[href]:hover{
    background-color:var(--red-hover);
    border-color:var(--red-hover);
    box-shadow:none;
    color:#fff !important;
}
.btn-success{
    background-color:var(--green);
    border-color:var(--green);
    box-shadow:none;
    color:#000;
}
.btn-success.focus,.btn-success:focus,.btn-success.active.focus,.btn-success.active:focus,.btn-success.active:hover,.btn-success:active.focus,.btn-success:active:focus,.btn-success:active:hover,.open>.dropdown-toggle.btn-success.focus,.open>.dropdown-toggle.btn-success:focus,.open>.dropdown-toggle.btn-success:hover,.btn-success:hover{
    color:#fff;
    background-color:var(--green-hover);
    border-color:var(--green-hover);
    box-shadow:none;
    color:#000;
}

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

.account-top .button {
    width:100%;
    text-align:center;
}

#signup-login .dropdown-style li a {

    display: block;
    padding: 2px 18px !important;
    position: relative;
}

#signup-login li .dropdown-style li {
    float: none;
    text-align: left;
}

#signup-login .dropdown-style li a:hover {
    background: hsla(0,0%,100%,.04)!important;
    border-radius: 6px;
}

#signup-login .dropdown-style li a i {
    text-align: center;
    width: 18px;
}

#signup-login li {
    line-height: 44px;
}

header.header .search {
    width: 288px;
}

.card, .mc-promo-login, .mc-promo-manage {
    background:var(--light-bg);
}

.action-icon-btns a {
    background:var(--light-bg);
    color:#fff;
}

.master-breadcrumb {
    background:transparent;
}

.breadcrumb {
    background:transparent;
    border-radius:0px;
    border-top:1px solid rgba(255,255,255,0.12);
}

.breadcrumb-item.active {
    color:var(--main-text-color);
}

.list-group-item {
	color: #fff;
        background: var(--light-bg);
}

.list-group-item:hover {
    background:var(--lighter-bg);
}

.announcements .announcement article {
    color:var(--main-text-color);
    border-color:rgba(255,255,255,0.2);
    background:var(--lighter-bg);
}

.announcements .announcement article p,
.card-body p {
    font-family:"Proxima Nova",sans-serif !important;
    color:var(--main-text-color) !important;
    margin-top: 0.6em !important;
}

.btn-link {
    color:var(--blue);
}

.btn-link:hover {
    color:var(--blue-hover);
}


.btn-outline-primary {
    color:var(--blue);
    border-color:var(--blue);
    padding: 7px 18px 6px 18px;
}

.btn-outline-primary:hover {
    color:#fff;
    background:var(--blue-hover);
    border-color:var(--blue-hover);
}

.action-icon-btns a:hover {
    color:#fff;
}

.card-accent-midnight-blue {
    border-color:var(--blue);
}

.list-group-item-action {
    color:#fff;
}

.sidebar .list-group-item {
    border-color:rgba(255,255,255,0.12);
}

.sidebar .list-group-item:hover {
    color:var(--blue);
    background:rgba(255,255,255,0.03);
}

.sidebar .list-group-item.active, .sidebar .list-group-item.active:focus, .sidebar .list-group-item.active:hover {
    background:var(--blue);
    color:#fff;
    border-color:var(--blue);
}
.cart-sidebar .list-group-item.active, .cart-sidebar .list-group-item.active:focus, .cart-sidebar .list-group-item.active:hover {
    background:var(--blue);
    color:#fff;
    border-color:var(--blue);
}

.list-group-item-action:focus, .list-group-item-action:hover {
    color:var(--blue);
}

.sidebar .card-sidebar .card-minimise{
    padding:6px;
}

/* Sidebar Recent Tickets styling */
.recent-ticket small {
    display: flex !important;
    flex-direction: row-reverse !important;
    justify-content: flex-end !important;
    gap: 8px !important;
    margin-top: 4px !important;
}

.recent-ticket small .pull-right,
.recent-ticket small .float-right {
    float: none !important;
    order: 2 !important;
    color: var(--main-text-color) !important;
    opacity: 0.7 !important;
}

.recent-ticket small span:not(.pull-right):not(.float-right) {
    order: 1 !important;
}

.recent-ticket .truncate {
    margin-bottom: 2px !important;
}

.text-muted {
    color:var(--main-text-color) !important;
    opacity:0.75;
}

.announcements .announcement article {
    margin-top:20px;
}

.announcement h1, .card-body h1 {
    font-size:28px;
    line-height:38px;
    padding-bottom:6px;
}

.badge-info {
    background:var(--blue);
}
.badge-info:hover {
    background:var(--blue-hover);
}

.kb-category {
    border-radius:8px;
}

.kb-category a:hover {
    background:var(--lighter-bg);
}

.kb-article-item i, .h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {    
    color: #fff !important;
}

/* Dropdown styling moved to 2026 THEME MODERNIZATION section */

header.header .toolbar .nav-link {
    border-color:var(--blue);
    background:var(--blue);
    color:#fff;
    padding: 0.6rem 1rem 0.4rem 1rem;

}

header.header .toolbar .nav-link .badge {
    background:#fff;
    color:var(--blue);
}

header.header .toolbar .nav-link:hover {
    color:#fff !important;
    border-color:var(--blue-hover) !important;
    background:var(--blue-hover) !important;
}

footer.footer {
    margin-top:120px;
    font-size:16px;
    padding: 90px 0 30px;
    background: rgba(0,0,0,0.33) !important;
}

.greenlabel, .greenlabel-md {
    background: var(--green);
    border-radius: 4px;
    color: #000;
    display: inline-block;
    font-weight: 600;
    height: 24px;
    line-height: 24px;
    padding: 0 6px;
}

#topbar .greenlabel, .greenlabel.sm {
    border-radius: 3px;
    font-size: 12px;
    height: 18px;
    line-height: 18px;
}

.font-22 {
    font-size: 22px;
    line-height: 32px;
}

.button_container {
    color:#fff;
}

#order-standard_cart .products .product {
    background:var(--light-bg) !important;
    border: 1px solid rgba(255,255,255,0.05) !important;
}

#order-standard_cart .products .product header {
    background:var(--lighter-bg) !important;
    font-weight:600;
    color:#fff;
}

#order-standard_cart .products .product header span {
    color:#fff !important;
}

#order-standard_cart .products .product div.product-desc {
    font-size:14px !important;
    line-height:24px !important;
    padding-top:20px !important;
}


#order-standard_cart .products .product div.product-desc p {
    padding-bottom:0px !important;
}


#order-standard_cart .products .product div.product-pricing br {
    display:none;
}

#order-standard_cart .products .product div.product-pricing span.price {
    font-weight:600;
    color:#fff;
}

#order-standard_cart .domain-selection-options .option {
    background:var(--light-bg) !important;
    border: 1px solid rgba(255,255,255,0.05) !important;

}

#order-standard_cart label, #order-standard_cart p.domain-renewal-desc {
    color:var(--main-text-color) !important;
    font-size:14px !important;
}

#order-standard_cart .domain-selection-options .option-selected label {
    font-weight:600;
    color:#fff !important;
}

#order-standard_cart .font-size-36 {
    font-size: 28px;
} 

.form-group .text-right {
    text-align:left !important;
}

.client-home-cards .card-header {
    background:var(--light-bg) !important;
    border-bottom:1px solid rgba(255,255,255,0.06);
}


.client-home-cards .card-header .btn {
    font-size:12px !important;
    padding:3px 14px
}

/* ============================================
   DASHBOARD TILES - Premium Dark Glass Cards
   ============================================ */

.dashboard-tiles {
    --tile-blue: #0096FF;
    --tile-green: #10b981;
    --tile-red: #ef4444;
    --tile-gold: #f59e0b;
    margin-bottom: 1.5rem;
}

.tiles-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.dash-tile {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: linear-gradient(145deg, rgba(35, 36, 43, 0.95) 0%, rgba(27, 28, 36, 1) 100%);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 16px;
    padding: 28px 20px;
    min-height: 170px;
    text-decoration: none;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    animation: tileReveal 0.6s cubic-bezier(0.4, 0, 0.2, 1) backwards;
}

.dash-tile:nth-child(1) { animation-delay: 0s; }
.dash-tile:nth-child(2) { animation-delay: 0.08s; }
.dash-tile:nth-child(3) { animation-delay: 0.16s; }
.dash-tile:nth-child(4) { animation-delay: 0.24s; }

@keyframes tileReveal {
    from {
        opacity: 0;
        transform: translateY(20px) scale(0.96);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* Glass reflection effect */
.dash-tile::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 50%;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.03) 0%, transparent 100%);
    border-radius: 16px 16px 0 0;
    pointer-events: none;
}

/* Glow effect layer */
.dash-tile::after {
    content: '';
    position: absolute;
    inset: -1px;
    border-radius: 16px;
    opacity: 0;
    transition: opacity 0.4s ease;
    pointer-events: none;
    z-index: -1;
}

.dash-tile:hover {
    transform: translateY(-4px);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: 0 20px 40px -12px rgba(0, 0, 0, 0.5);
    text-decoration: none;
}

.dash-tile:hover::after {
    opacity: 1;
}

/* Icon container */
.dash-tile__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    margin-bottom: 16px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    transition: all 0.4s ease;
}

.dash-tile__icon i {
    font-size: 28px;
    transition: transform 0.4s ease;
}

.dash-tile:hover .dash-tile__icon {
    transform: scale(1.06);
}

/* Stat number - hero element */
.dash-tile__stat {
    font-size: 44px;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1;
    margin-bottom: 8px;
    color: #fff;
    transition: all 0.3s ease;
}

/* Label */
.dash-tile__label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.45);
    transition: all 0.3s ease;
}

.dash-tile:hover .dash-tile__label {
    color: rgba(255, 255, 255, 0.65);
}

/* ---- Color Variants ---- */

/* Blue - Services */
.dash-tile--blue .dash-tile__icon {
    color: var(--tile-blue);
    background: rgba(0, 150, 255, 0.12);
    box-shadow: 0 0 30px rgba(0, 150, 255, 0.2);
}

.dash-tile--blue::after {
    box-shadow: 0 0 50px 4px rgba(0, 150, 255, 0.15);
}

.dash-tile--blue:hover .dash-tile__stat {
    text-shadow: 0 0 40px rgba(0, 150, 255, 0.5);
}

/* Green - Domains */
.dash-tile--green .dash-tile__icon {
    color: var(--tile-green);
    background: rgba(16, 185, 129, 0.12);
    box-shadow: 0 0 30px rgba(16, 185, 129, 0.2);
}

.dash-tile--green::after {
    box-shadow: 0 0 50px 4px rgba(16, 185, 129, 0.15);
}

.dash-tile--green:hover .dash-tile__stat {
    text-shadow: 0 0 40px rgba(16, 185, 129, 0.5);
}

/* Red - Tickets */
.dash-tile--red .dash-tile__icon {
    color: var(--tile-red);
    background: rgba(239, 68, 68, 0.12);
    box-shadow: 0 0 30px rgba(239, 68, 68, 0.2);
}

.dash-tile--red::after {
    box-shadow: 0 0 50px 4px rgba(239, 68, 68, 0.15);
}

.dash-tile--red:hover .dash-tile__stat {
    text-shadow: 0 0 40px rgba(239, 68, 68, 0.5);
}

/* Gold - Invoices */
.dash-tile--gold .dash-tile__icon {
    color: var(--tile-gold);
    background: rgba(245, 158, 11, 0.12);
    box-shadow: 0 0 30px rgba(245, 158, 11, 0.2);
}

.dash-tile--gold::after {
    box-shadow: 0 0 50px 4px rgba(245, 158, 11, 0.15);
}

.dash-tile--gold:hover .dash-tile__stat {
    text-shadow: 0 0 40px rgba(245, 158, 11, 0.5);
}

/* Responsive */
@media (max-width: 991px) {
    .tiles-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }
}

@media (max-width: 575px) {
    .tiles-grid {
        gap: 10px;
    }

    .dash-tile {
        padding: 20px 16px;
        min-height: 140px;
        border-radius: 12px;
    }

    .dash-tile__icon {
        width: 52px;
        height: 52px;
        margin-bottom: 12px;
        border-radius: 10px;
    }

    .dash-tile__icon i {
        font-size: 22px;
    }

    .dash-tile__stat {
        font-size: 32px;
        margin-bottom: 4px;
    }

    .dash-tile__label {
        font-size: 10px;
    }
}

.dataTables_wrapper table.table-list {
    border-color:rgba(255,255,255,0.06);
}

.table-list>tbody>tr>td {
    background:var(--light-bg) !important;
}

.dataTables_wrapper table.table-list thead th {
    background:var(--light-bg) !important;
    color:#fff;
    border-color:rgba(255,255,255,0.06);
}

.dataTables_wrapper table.table-list thead th.sorting_asc, .dataTables_wrapper table.table-list thead th.sorting_desc {
    background:var(--lighter-bg) !important;
    color:#fff;
    border-color:rgba(255,255,255,0.06);
}

.sorting_disabled {
    cursor:not-allowed;
}

.dataTables_wrapper table.table-list thead th {
    border-color:rgba(255,255,255,0.06) !important;
}

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

.client-home-cards .list-group .list-group-item, .client-home-cards .list-group {
    border-color:rgba(255,255,255,0.06) !important;
}


.client-home-cards .list-group .list-group-item:hover {
    color:var(--blue) !important;
}

.client-home-cards .list-group .list-group-item .text-last-updated {
    color:var(--main-text-color);
}

.font-13 {
    font-size: 13px;
    line-height: 22px;
}

#order-standard_cart .default-captcha {
    background-color:var(--lighter-bg) !important;
    border-color:rgba(255,255,255,0.06) !important;
}

.domain-promo-box {
    background-color:var(--lighter-bg) !important;
    border-color:rgba(255,255,255,0.06) !important;
    color:var(--main-text-color) !important;
}

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

.domain-pricing .tld-pricing-header div:nth-child(odd) {
    background-color:var(--lighter-bg) !important;
    border-color:rgba(255,255,255,0.06) !important;
    color:var(--main-text-color) !important;
}

.domain-pricing .tld-pricing-header .col-sm-2, .domain-pricing .tld-pricing-header .col-sm-4, .domain-pricing .tld-pricing-header .col-xs-2, .domain-pricing .tld-pricing-header .col-xs-4 {
    background-color:rgba(255,255,255,0.05) !important;
    border-color:rgba(255,255,255,0.06) !important;
}

.domain-pricing .tld-row.highlighted {
    background-color:rgba(255,255,255,0.05) !important;
    border-color:rgba(255,255,255,0.06) !important;
}

.domain-pricing .two-row-center {
    border-color:rgba(255,255,255,0.06) !important;
}
.domain-pricing .tld-row {
    border-color:rgba(255,255,255,0.06) !important;
}


#order-standard_cart .view-cart-items-header {
    background-color:var(--blue) !important;
    color:#fff !important;
    font-weight:600 !important;
    font-size:16px !important;
}

.view-cart-items {
    border-color:rgba(255,255,255,0.06) !important;
}

#order-standard_cart .view-cart-items .item {
    background-color:var(--light-bg) !important;
}

#order-standard_cart .view-cart-items .item-title {
    font-weight:600;
    color:#fff;
}

#order-standard_cart .view-cart-items .item-domain {
    color:var(--blue) !important;
}

#order-standard_cart .btn-remove-from-cart {
    color:var(--red) !important;
    margin-right:12px;
}

#order-standard_cart .empty-cart .btn {
    background:var(--red) !important;
    font-size:12px;
    border-radius:0px 0px 5px 5px !important;
}

#order-standard_cart .view-cart-items {
    border-bottom:2px solid var(--red) !important;
}


#order-standard_cart .view-cart-tabs .tab-content {
    background-color:var(--light-bg) !important;
}

.view-cart-tabs .nav-tabs {
    border-color:rgba(255,255,255,0.06) !important;
}

#order-standard_cart .view-cart-tabs .nav-tabs a[aria-expanded=true], #order-standard_cart .view-cart-tabs .nav-tabs a[aria-selected=true] {
    color:#fff;
    font-size:14px;
    border-color:rgba(255,255,255,0.06) !important;
    background-color:var(--lighter-bg) !important;
    font-weight:600;
    padding: 0.3rem 1rem;
}

#order-standard_cart .summary-container {
    background-color:var(--light-bg) !important;
    font-size: .9rem !important;
}

#order-standard_cart .order-summary {
    background:var(--blue) !important;
    border-color:var(--blue) !important;
    color:#fff;
    font-weight:600;
}

#order-standard_cart .order-summary h2 {
    color:#fff !important; 
    font-weight:600 !important; 
}

#order-standard_cart .font-size-36 {
    font-size:28px !important;
    padding-bottom:8px !important;
}

h1, h2, h3, h4, h5 {
    font-family:"Proxima Nova",sans-serif !important;
}

#order-standard_cart .sub-heading span, #order-standard_cart .sub-heading-borderless span {
    color:var(--blue) !important;
    font-weight:600;
}

#order-standard_cart label, #order-standard_cart p.domain-renewal-desc {
    colro:var(--main-text-color) !important;
    font-weight:300 !important;
    font-family:"Proxima Nova",sans-serif !important;
}

#order-standard_cart label .iradio_square-blue {
    margin-right:6px !important;
}
.bootstrap-switch {
    border-color:rgba(255,255,255,0.125) !important;
}




.btn-return-to-admin {
    right:24px;
}


.navbar {
    background:var(--blue);
    padding: 0.75rem 1rem;
}


.navbar li a {
    display:block;
    color:rgba(255,255,255,0.88);
}

.navbar li a:hover {
    color:#fff;
}

/* navbar dropdown color - see 2026 THEME MODERNIZATION */

@media only screen and (max-width: 991px)  {    
    body {
        background-image:unset;
      }
      
      body, html {
        overflow-x:hidden;
      }
      
      .hidemobile {display:none;}
      
      .showmobile {display:inline-block;}
      
      section {
        padding: 68px 0px 72px 0px;
      }
      
      h1 {
        font-size: 28px;
        line-height: 36px;
      }
      
      h2 {
        font-size: 28px;
        line-height: 34px;
      }
      
      h3 {
        font-size: 22px;
        line-height: 32px;
      }
      
      .font-20 {
        font-size:18px;
        line-height: 28px;
      }
      
      .show-mobile {
        display:block;
      }
      
      .col:not(.kbsup-col):not(.notif-col):not(.lang-col) {
        width: 100% !important;
        flex-basis: 100% !important;
        text-align:center;
      }
      
      #topbar .col-auto,
      #topbar li {
        display:none;
      }
      
      #topbar li:nth-last-child(1), #topbar li:nth-last-child(2), #topbar .ml-auto {
        display:block;
      }
      
      #topbar li:nth-last-child(1) li{
        display:block;
      }
      
      #topbar .dropdown-style {
        right: 0;
        unset: 0;
        transform: unset;
        top: 52px;
      }
      
      #topbar .dropdown-style:before { 
        right: 5px;
        left: unset;
      }
      
      .lang-col {
	display: block !important;
	}      

      .logo {
        height:40px;
      }
      
      li.pull-left.knowledgebase {
        display: none !important;
      }

      .header {
        padding: 24px 0px 0 0;
      }
      
      .header-col-logo {
        margin-bottom:24px;
      }
      
      
      .header .col.col-auto {
        width:100%;
        flex-basis: 100% !important;
        text-align:left;
      }

      .button_container {
        display:block;
      }
      
      
      .header .col:nth-child(1) {
        display:block;
      }
      
      .banner-slide-nav {
        display:none;
      }
      
      .banner-slide-logo {
        height:64px;  
      }
      
      .banner-slide {
        height:auto;
        padding:60px 20px;
      }
      
      
      .mtfix {margin-top:0px !important;}
      .mbfix {margin-bottom:0px !important;}
      .mrfix {margin-right:0px !important;}
      .mlfix {margin-left:0px !important;}
      
      .ptfix {padding-top:0px !important;}
      .pbfix {padding-bottom:0px !important;}
      .prfix {padding-right:calc(var(--bs-gutter-x) * .575) !important;}
      .plfix {padding-left:calc(var(--bs-gutter-x) * .575) !important;}

      .button_container {
        right:20px;
        z-index:1009;
      }

      .header .main-nav-col.active #main-navigation li {
            display:block !important;
      }

      .header {
        position: relative;
      }

      #main-navigation li {
        display:none;
      }

      .header .col.ml-auto .navbar-nav li:nth-child(1),
      .header .col.ml-auto .navbar-nav li:nth-child(2) {
        display:none;
      }

      .header .col.ml-auto .navbar-nav .ml-3 {
        margin-left:0px !important;
        width:100%;
      }

      header.header .toolbar .nav-link {
        padding:0.6rem 1rem 0.6rem 1rem;
        width:100%;
        text-align:center;
      }
      
      .footer img.block {
        margin: 0 auto;
    }
    .footer .col-lg-8 {
        margin-top: 40px;
    }

    .footer .col-lg-8 h5 {
        display: block;
        padding: 10px 0;
    }
    .footer .col-lg-4 ul {
        display: none;
    }
    .footer .col-lg-4 h5:after {
        background: url(../images/select-down.svg) center bottom 1px no-repeat;
        background-size: 12px;
        content: " ";
        display: inline-block;
        height: 15px;
        margin-left: 8px;
        width: 13px;
    }
    .footer .col-lg-4 h5:hover {
        color: var(--blue) !important;
        cursor:pointer;
    }

    .footer .col-lg-4 h5:hover:after {
        background: url(../images/select-down-blue.svg) center bottom 1px no-repeat;
        background-size: 12px;
    }

    .navbar-nav li a {
        width:100%;
        display:block;
        text-align:center;
        padding:8px 20px !important;
    }

    .dropdown-menu .dropdown-item a {

        padding: 0rem !important;
    }

    .hideafter:after {
        display:none !important;
    }

    .navbar-expand-lg, .d-lg-none {
        display:block !important;
    }


.navbar {
    background:transparent;
    padding: 0.75rem 1rem;
}


.navbar li a {
    color:#fff;
}

.navbar li a:hover {
    color:var(--blue);
}

/* navbar dropdown color - see 2026 THEME MODERNIZATION */

}

@media screen and (min-width:448px) and (max-width:991px){
     li.pull-left.knowledgebase {
        display: block !important;
      }
}
 
@media screen and (min-width:595px) and (max-width:991px){
     .notif-col {
        display: block !important;
      }
}

 
.table{
    color: var(--main-text-color) !important;
}

.dropdown-toggle::after {
    vertical-align: 0.155em;
}

.text-domain{
    color: var(--main-text-color);
}

.font-weight-bold {
    font-weight: 500!important;
}

.input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle), .input-group>.input-group-append:last-child>.input-group-text:not(:last-child), .input-group>.input-group-append:not(:last-child)>.btn, .input-group>.input-group-append:not(:last-child)>.input-group-text, .input-group>.input-group-prepend>.btn, .input-group>.input-group-prepend>.input-group-text {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.input-group>.input-group-append>.btn, .input-group>.input-group-append>.input-group-text, .input-group>.input-group-prepend:first-child>.btn:not(:first-child), .input-group>.input-group-prepend:first-child>.input-group-text:not(:first-child), .input-group>.input-group-prepend:not(:first-child)>.btn, .input-group>.input-group-prepend:not(:first-child)>.input-group-text {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.btn-group>.btn-group:not(:last-child)>.btn, .btn-group>.btn:not(:last-child):not(.dropdown-toggle) {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.btn-group>.btn-group:not(:first-child)>.btn, .btn-group>.btn:not(:first-child) {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.list-group-item-action:active,.list-group-item-action:focus {
    color: #fff !important;
    background-color: var(--blue) !important;
}

.list-group-item.disabled,.list-group-item:disabled{
    background-color: var(--light-bg);
}

.table-list>tbody>tr>td a.border-left {
    border-left: 0 solid rgba(255,255,255,0) !important;
}

.ticket-number {
    padding-right: 100%;
    color: var(--green);
    font-size: 14px;
}

a .ticket-subject {
    color: #fff!important;
    font-size: 16px;
}

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

.tile .title {
    color: var(--main-text-color) !important;
}

.product-icon .fa-stack {
    margin-bottom: 18px;
}

.product-status-active {
    background-color: var(--success);
}

.product-status-active .product-icon .fa-stack-2x {
    color: var(--blue);
}

div.product-details div.product-icon {
    margin: 0;
    background-color: var(--body-bg);
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    border-bottom-right-radius: 0px;
    border-bottom-left-radius: 0px;
    padding: 30px;
    line-height: 1em;
    font-size: 60px;
}

.product-details .col-md-6.text-center h4 {
    padding-top: 18px;
    line-height: 20px;
    letter-spacing: .5px;
}

.breadcrumb-item {
    padding-top: 16px;
}

.domain-renewals,.domain-renewals .domain-renewal:nth-child(even) {
    background-color: var(--lighter-bg) !important;
}

.label {
    font-size: 90% !important;
}

#order-standard_cart .product-info .product-title {
    color: #fff !important;
    font-weight: 500;
}

#order-standard_cart .product-info {
    background-color: var(--light-bg) !important;
    padding: 18px 15px 0px 15px !important;
}

.iti-flag{
    margin-bottom: 5px;
    margin-right: 6px;
}

.page-link:focus, .page-link.focus, .btn.focus, .btn:focus {
    box-shadow: 0 0 0 0.2rem rgba(0,0,0,0) !important;
}

.btn-social {
    padding-bottom: 7px;
    padding-top: 7px;
}

#cartItemCount {
    top: 7px;
    right: 5px;
    padding: 3px 6px;
}

.btn.nav-link.cart-btn {
    height: 100%;
}

.btn.nav-link.cart-btn i {
    vertical-align: middle;
}

.button-outline {
    border-radius: 6px;
    font-size: 16px;
    font-weight: 600;
    line-height: 46px;
    height: 48px;
    display: inline-block;
    padding: 0 25px;
    background: transparent;
    border: 1px solid #fff;
    box-shadow: none;
    color: #fff!important;
}

.panels-dropdown-style {
    position: absolute;
    top: 60px;
    right: 74.5%;
    background: var(--light-bg);
    min-width: 260px;
    transform: translateX(50%);
    padding: 6px;
    border-radius: 6px;
    z-index: 1001;
    box-shadow: 0 2px 8px 1px rgba(0,0,0,0.22);
    font-size: 16px;
}

.panels-dropdown-style:before {
    width: 20px;
    height: 20px;
    transform: rotate(45deg);
    background: var(--light-bg);
    border-radius: 3px;
    content: " ";
    position: absolute;
    left: 87.5%;
    margin-left: -10px;
    top: -3px;
    z-index: -999;
}

  #rh-toolbar .panels-dropdown-style {
      padding:6px;
      top: 44px;
      display:none;
  }
  
  
  #rh-toolbar li:hover .panels-dropdown-style {
      display:block !important;
  }
  
  
  #rh-toolbar li:hover a.dropdown-link {
      color:var(--blue);
  }
  
  
  #rh-toolbar .panels-dropdown-style li {
      padding:0px 0px;
      display:block;
      width:100%;
  }
  
  #rh-toolbar .panels-dropdown-style li a {
      padding:2px 18px !important;
      display:block;
      position: relative;
  }
  
  #rh-toolbar .panels-dropdown-style li a:hover {
      background:rgba(255,255,255,0.04) !important;
      border-radius:6px;
  }
  
  #rh-toolbar .panels-dropdown-style li a i {
      width:18px;
      text-align:center;
  }

.panels-dropdown-style li {
    line-height: 44px;
}

.panels-dropdown-style li a {
    color: #fff;
}

/* ============================================
   TICKET VIEW - Premium Dark Theme
   ============================================ */

.view-ticket .card-body {
    border-bottom: 0;
    padding: 20px !important;
}

.view-ticket .card-body:first-child {
    padding-bottom: 12px !important;
}

.view-ticket .card-body + .card-body {
    padding-top: 8px !important;
    padding-bottom: 8px !important;
}

/* Ticket Reply Container */
.ticket-reply {
    margin: 0 !important;
    padding: 0;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    flex-direction: column;
    position: relative;
    background: var(--light-bg);
    overflow: hidden;
}

/* Reply Header */
.ticket-reply .user {
    order: 1;
    display: grid;
    grid-template-columns: 36px 1fr;
    grid-template-rows: auto auto;
    gap: 2px 10px;
    padding: 12px 16px;
    color: #fff;
    background: rgba(0, 0, 0, 0.15);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    position: relative;
}

/* User Avatar */
.ticket-reply .user > i {
    grid-row: 1 / 3;
    float: none;
    font-size: 1em;
    padding: 0;
    color: rgba(255, 255, 255, 0.45);
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.06);
}

/* User name */
.ticket-reply .user .name {
    grid-column: 2;
    grid-row: 1;
    display: inline !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.4;
    margin: 0;
    text-transform: capitalize;
    align-self: end;
}

/* Role Labels - compact inline badge */
.ticket-reply .user .name .label {
    display: inline-block !important;
    font-size: 9px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 4px;
    margin-left: 6px;
    vertical-align: middle;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border: none;
}

.ticket-reply .user .name .label.requestor-type-owner {
    background: #22c55e;
    color: #fff;
}

.ticket-reply .user .name .label.requestor-type-operator {
    background: #3b82f6;
    color: #fff;
}

/* Email/Staff - directly below name */
.ticket-reply .type {
    grid-column: 2;
    grid-row: 2;
    font-size: 13px;
    line-height: 1.3;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 400 !important;
    align-self: start;
}

/* Date - positioned top right */
.ticket-reply .date {
    order: 0;
    position: absolute;
    top: 14px;
    right: 16px;
    float: none !important;
    font-size: 11px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.35);
    letter-spacing: 0.02em;
    margin: 0;
}

/* Mobile: move date below header */
@media (max-width: 576px) {
    .ticket-reply .date {
        position: static !important;
        order: 2;
        padding: 8px 16px;
        background: rgba(0, 0, 0, 0.08);
        border-bottom: 1px solid rgba(255, 255, 255, 0.03);
    }
}

/* Message Content */
.ticket-reply .message {
    order: 3;
    padding: 18px 20px !important;
    font-size: 14px;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.82);
}

.ticket-reply .message p {
    margin-bottom: 12px;
}

.ticket-reply .message p:last-child {
    margin-bottom: 0;
}

/* IP Address line */
.ticket-reply .message hr {
    background: rgba(255, 255, 255, 0.06);
    border: none;
    height: 1px;
    margin: 16px 0;
}

/* Attachments */
.ticket-reply .attachments {
    order: 4;
    padding: 14px 20px;
    background: rgba(0, 0, 0, 0.1);
    border-top: 1px solid rgba(255, 255, 255, 0.04);
}

.ticket-reply .attachments strong {
    font-size: 12px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.6);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.ticket-reply .attachment-list {
    margin-top: 10px;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ticket-reply .attachment-list li a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 6px;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.7);
    transition: all 0.2s ease;
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.ticket-reply .attachment-list li a:hover {
    background: rgba(59, 130, 246, 0.15);
    border-color: rgba(59, 130, 246, 0.3);
    color: #fff;
}

/* Staff Reply Styling */
.ticket-reply.staff {
    border-left: 3px solid var(--blue);
}

.ticket-reply.staff .user {
    background: rgba(59, 130, 246, 0.06);
}

.ticket-reply.staff .user i {
    background: rgba(59, 130, 246, 0.12);
    color: var(--blue);
    border-color: rgba(59, 130, 246, 0.15);
}

/* Rating Stars */
.ticket-reply .rating,
.ticket-reply .rating-done {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    margin-top: 8px;
    padding-right: 4px;
}

.ticket-reply .rating .star,
.ticket-reply .rating-done .star {
    font-size: 18px;
    cursor: pointer;
    transition: all 0.15s ease;
    color: rgba(255, 255, 255, 0.15);
}

.ticket-reply .rating .star:hover,
.ticket-reply .rating .star:hover ~ .star,
.ticket-reply .rating-done .star.active {
    color: #fbbf24;
    text-shadow: 0 0 12px rgba(251, 191, 36, 0.4);
}

.ticket-reply .rating-done .rated {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.4);
    margin-left: 6px;
}

/* Ticket Header */
.view-ticket > .card-body:first-child {
    border-bottom: 1px solid rgba(255, 255, 255, 0.04) !important;
}

.view-ticket .card-title {
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.01em;
}

.view-ticket .ticket-actions .btn {
    border-radius: 8px;
    font-weight: 500;
    font-size: 13px;
    padding: 8px 16px;
    transition: all 0.2s ease;
}

.view-ticket .ticket-actions .btn-default {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #fff;
}

.view-ticket .ticket-actions .btn-default:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.15);
}

.view-ticket .ticket-actions .btn-danger {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
    border: none;
    box-shadow: 0 2px 8px rgba(239, 68, 68, 0.3);
}

.view-ticket .ticket-actions .btn-danger:hover {
    background: linear-gradient(135deg, #f87171 0%, #ef4444 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
}

.product-details-tab-container {
    background-color: var(--light-bg) !important;
    border-radius: 4px !important;
    border: 0 !important;
}

.nav-tabs, .nav-tabs .nav-link, .nav-tabs .nav-link:focus {
    border: 0!important;
}

.nav-tabs>li>a {
    color: var(--main-text-color);
}

.responsive-tabs-sm .nav-item a:hover {
    background-color: var(--lighter-bg);
    border: 0 !important;
}


.responsive-tabs-sm .nav-item .nav-link.active {
    background-color: var(--blue)!important;
    color: #fff;
    border-radius: 4px 4px 0 0;
    border: 0;
    opacity: 1;
}

.card-header:first-child {
    border-radius: calc(0.25rem - 1px) calc(0.25rem - 1px) 0 0;
    background-color: var(--lighter-bg);
    padding: 6px 17px;
    /* margin: 8px 8px 4px 8px; */
    border-radius: 4px;
}

.popover {
    background-color: var(--light-bg);
        border-color: var(--lighter-bg);
}

.popover-user-notifications ul li a{
    color: var(--white);
    border-radius: 5px;
}

.popover-user-notifications ul li a:hover{
    background-color: var(--lighter-bg)
}

.modal-content {
    background-color: var(--light-bg);
}

tr.masspay-total td {
    background-color: #212229 !important;
}

.affiliate-stat i {
    font-size: 1.5em;
    padding-top: 5px;
}

.affiliate-stat span {
    font-size: 1.5em;
}

/* ================================================
   CLEAN CART/ORDER REDESIGN - Hide Sidebar
   ================================================ */

/* Hide breadcrumb on cart/order pages */
body:has(#order-standard_cart) .master-breadcrumb {
    display: none !important;
}

/* Hide the left sidebar completely on cart pages */
#order-standard_cart .cart-sidebar {
    display: none !important;
}

/* Make cart body full width */
#order-standard_cart {
    max-width: 100% !important;
    overflow-x: hidden !important;
    padding-top: 32px !important;
}

#order-standard_cart > .row {
    display: block !important;
    margin: 0 !important;
}

#order-standard_cart .cart-body {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    float: none !important;
}

/* Hide collapsed sidebar too */
#order-standard_cart .sidebar-categories-collapsed {
    display: none !important;
}

/* ================================================
   CLEANER CONFIGURE PAGE LAYOUT
   ================================================ */

/* Form row layout - 5:2 ratio (configure product & viewcart) */
#order-standard_cart #frmConfigureProduct > .row,
#order-standard_cart .cart-body > .row {
    display: grid !important;
    grid-template-columns: 5fr 2fr !important;
    gap: 24px !important;
    margin: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Main content area */
#order-standard_cart .secondary-cart-body {
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
}

/* Order summary sidebar */
#order-standard_cart .secondary-cart-sidebar {
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
}

/* Clean header */
#order-standard_cart .header-lined h1 {
    font-size: 32px !important;
    font-weight: 600 !important;
    margin-bottom: 8px !important;
    padding-bottom: 0 !important;
}

#order-standard_cart .header-lined {
    border: none !important;
    margin-bottom: 24px !important;
}

/* Product info card styling */
#order-standard_cart .product-info {
    background: var(--light-bg) !important;
    border-radius: 8px !important;
    padding: 24px !important;
    margin-bottom: 24px !important;
    border: 1px solid var(--border-color) !important;
}

#order-standard_cart .product-info .product-title {
    font-size: 22px !important;
    font-weight: 600 !important;
    margin-bottom: 12px !important;
}

#order-standard_cart .product-info p {
    color: var(--main-text-color) !important;
    line-height: 1.6 !important;
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}

/* ================================================
   CARD-STYLE CONFIGURABLE OPTIONS (Location, etc)
   ================================================ */

#order-standard_cart .product-configurable-options .form-group {
    margin-bottom: 24px !important;
}

/* Reduce column gap from 30px to 10px */
#order-standard_cart .product-configurable-options > .row {
    margin-left: -5px !important;
    margin-right: -5px !important;
}

#order-standard_cart .product-configurable-options > .row > [class*="col-"] {
    padding-left: 5px !important;
    padding-right: 5px !important;
}

#order-standard_cart .product-configurable-options label {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #fff !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 12px !important;
    display: block !important;
}

/* Style form inputs and select dropdowns cleaner */
#order-standard_cart .form-control,
#order-standard_cart .field,
#order-standard_cart input.field,
#order-standard_cart select.form-control {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    color: #fff !important;
    height: 46px !important;
    line-height: 46px !important;
    /* padding: 10px 16px !important; */
    font-size: 15px !important;
}

#order-standard_cart .field::placeholder,
#order-standard_cart .form-control::placeholder,
#order-standard_cart input::placeholder {
    color: #666 !important;
}

#order-standard_cart select.form-control {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-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 8L1 3h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px center !important;
    padding-right: 40px !important;
    cursor: pointer !important;
}

#order-standard_cart select.form-control option {
    background: #1a1b23 !important;
    color: #fff !important;
    padding: 10px !important;
}

#order-standard_cart .form-control:focus {
    border-color: var(--blue) !important;
    box-shadow: 0 0 0 2px rgba(0, 150, 255, 0.15) !important;
    outline: none !important;
}

/* Radio button options as cards */
#order-standard_cart .product-configurable-options input[type="radio"] {
    display: none !important;
}

#order-standard_cart .product-configurable-options input[type="radio"] + label,
#order-standard_cart .product-configurable-options label:has(input[type="radio"]) {
    display: flex !important;
    align-items: center !important;
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    padding: 16px 20px !important;
    margin-bottom: 10px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    font-weight: 400 !important;
    font-size: 15px !important;
}

#order-standard_cart .product-configurable-options input[type="radio"]:checked + label,
#order-standard_cart .product-configurable-options label:has(input[type="radio"]:checked) {
    border-color: var(--blue) !important;
    background: rgba(0, 150, 255, 0.08) !important;
}

#order-standard_cart .product-configurable-options input[type="radio"] + label:hover,
#order-standard_cart .product-configurable-options label:has(input[type="radio"]):hover {
    border-color: var(--blue) !important;
}

/* Custom radio indicator */
#order-standard_cart .product-configurable-options input[type="radio"] + label::before,
#order-standard_cart .product-configurable-options label:has(input[type="radio"])::before {
    content: '' !important;
    width: 22px !important;
    height: 22px !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 50% !important;
    margin-right: 14px !important;
    flex-shrink: 0 !important;
    transition: all 0.2s ease !important;
}

#order-standard_cart .product-configurable-options input[type="radio"]:checked + label::before,
#order-standard_cart .product-configurable-options label:has(input[type="radio"]:checked)::before {
    border-color: var(--blue) !important;
    background: var(--blue) !important;
    box-shadow: inset 0 0 0 4px var(--body-bg) !important;
}

/* ================================================
   CLEANER ORDER SUMMARY
   ================================================ */

#order-standard_cart .order-summary {
    border-radius: 12px !important;
    overflow: hidden !important;
    border: 1px solid var(--border-color) !important;
    background: var(--light-bg) !important;
    position: relative !important;
}

/* Clean header */
#order-standard_cart .order-summary h2 {
    font-size: 20px !important;
    font-weight: 600 !important;
    padding: 20px 20px 16px 20px !important;
    margin: 0 !important;
    text-align: left !important;
    color: #fff !important;
    background: transparent !important;
    border-bottom: none !important;
}

/* Fix loader position */
#order-standard_cart .order-summary .loader {
    position: absolute !important;
    top: 20px !important;
    right: 20px !important;
    padding: 0 !important;
}

#order-standard_cart .summary-container {
    padding: 0 20px 20px 20px !important;
    background: transparent !important;
}

/* New summary styles */
#order-standard_cart .summary-product-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid var(--border-color) !important;
    margin-bottom: 12px !important;
}

#order-standard_cart .summary-product-name {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #fff !important;
}

#order-standard_cart .summary-product-price {
    font-size: 14px !important;
    color: var(--main-text-color) !important;
}

#order-standard_cart .summary-config-row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 6px 0 !important;
}

#order-standard_cart .summary-config-label {
    font-size: 13px !important;
    color: var(--main-text-color) !important;
}

#order-standard_cart .summary-config-label i {
    font-size: 10px !important;
    margin-right: 6px !important;
    opacity: 0.6 !important;
}

#order-standard_cart .summary-config-price {
    font-size: 13px !important;
    color: var(--main-text-color) !important;
}

#order-standard_cart .summary-billing-row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 12px 0 !important;
    margin-top: 8px !important;
    border-top: 1px solid var(--border-color) !important;
}

#order-standard_cart .summary-billing-label {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #fff !important;
    text-decoration: underline !important;
    text-underline-offset: 3px !important;
}

#order-standard_cart .summary-billing-price {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #fff !important;
}

#order-standard_cart .summary-tax-row {
    display: flex !important;
    justify-content: space-between !important;
    font-size: 13px !important;
    color: var(--main-text-color) !important;
    padding: 6px 0 !important;
}

#order-standard_cart .summary-total-section {
    text-align: center !important;
    padding-top: 16px !important;
    margin-top: 12px !important;
    border-top: 1px solid var(--border-color) !important;
}

#order-standard_cart .summary-total-label {
    display: block !important;
    font-size: 12px !important;
    color: var(--main-text-color) !important;
    margin-bottom: 4px !important;
}

#order-standard_cart .summary-total-amount {
    display: block !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    color: #fff !important;
}

/* Legacy support for old template classes */
#order-standard_cart .summary-container .clearfix {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 6px 0 !important;
}

#order-standard_cart .summary-container .clearfix::after {
    display: none !important;
}

#order-standard_cart .summary-container .pull-left,
#order-standard_cart .summary-container .float-left {
    font-size: 13px !important;
    color: var(--main-text-color) !important;
    float: none !important;
}

#order-standard_cart .summary-container .pull-right,
#order-standard_cart .summary-container .float-right {
    font-size: 13px !important;
    color: var(--main-text-color) !important;
    float: none !important;
}

#order-standard_cart .total-due-today {
    text-align: center !important;
    padding: 16px 0 0 0 !important;
    margin-top: 12px !important;
    border-top: 1px solid var(--border-color) !important;
    background: transparent !important;
}

#order-standard_cart .total-due-today span:not(.amt) {
    display: block !important;
    font-size: 12px !important;
    color: #fff !important;
    margin-bottom: 4px !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

#order-standard_cart .total-due-today .amt {
    display: block !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    color: #fff !important;
}

/* ================================================
   HIDE CONFIGURABLE OPTIONS DIVIDER
   ================================================ */

#order-standard_cart .sub-heading,
#order-standard_cart .sub-heading-borderless {
    display: none !important;
}

/* Continue button */
#order-standard_cart #btnCompleteProductConfig,
#order-standard_cart .btn-checkout {
    display: block !important;
    width: calc(100% - 40px) !important;
    margin: 20px auto !important;
    padding: 16px 24px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    text-align: center !important;
}

#order-standard_cart #orderSummary > .text-center {
    padding: 0 0 20px 0 !important;
}

/* Loader positioning */
#order-standard_cart .order-summary .loader {
    padding: 20px !important;
    text-align: center !important;
}

/* ================================================
   CLEANER CART VIEW
   ================================================ */

/* Remove the harsh blue header - make it subtle */
#order-standard_cart .view-cart-items-header {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-bottom: none !important;
    border-radius: 10px 10px 0 0 !important;
    padding: 14px 20px !important;
    color: var(--main-text-color) !important;
}

#order-standard_cart .view-cart-items-header th {
    color: var(--main-text-color) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    background: transparent !important;
}

#order-standard_cart .view-cart-items {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-top: none !important;
    border-radius: 0 0 10px 10px !important;
    overflow: hidden !important;
}

#order-standard_cart .view-cart-items .item {
    padding: 20px !important;
    border-bottom: 1px solid var(--border-color) !important;
    background: transparent !important;
}

#order-standard_cart .view-cart-items .item:last-child {
    border-bottom: none !important;
}

#order-standard_cart .view-cart-items .item-title {
    font-size: 16px !important;
    font-weight: 500 !important;
    color: #fff !important;
}

#order-standard_cart .view-cart-items .item-group {
    color: var(--main-text-color) !important;
    font-size: 13px !important;
}

#order-standard_cart .view-cart-items .item-options {
    color: var(--main-text-color) !important;
    font-size: 13px !important;
    margin-top: 8px !important;
}

#order-standard_cart .view-cart-items .item-price {
    text-align: right !important;
}

#order-standard_cart .view-cart-items .item-price span {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #fff !important;
}

#order-standard_cart .view-cart-items .item-price .cycle {
    display: block !important;
    font-size: 12px !important;
    color: var(--main-text-color) !important;
    font-weight: 400 !important;
}

/* Remove button styling */
#order-standard_cart .view-cart-items .remove-item {
    color: var(--red) !important;
    opacity: 0.7 !important;
    transition: opacity 0.2s !important;
}

#order-standard_cart .view-cart-items .remove-item:hover {
    opacity: 1 !important;
}

/* Empty cart button */
#order-standard_cart .empty-cart {
    margin-top: 16px !important;
    text-align: right !important;
}

#order-standard_cart .empty-cart .btn {
    background: transparent !important;
    border: 1px solid var(--red) !important;
    color: var(--red) !important;
    border-radius: 8px !important;
    padding: 8px 16px !important;
    font-size: 13px !important;
}

#order-standard_cart .empty-cart .btn:hover {
    background: var(--red) !important;
    color: #fff !important;
}

/* Promo code section */
#order-standard_cart .view-cart-tabs {
    margin-top: 24px !important;
}

#order-standard_cart .view-cart-tabs .nav-tabs {
    border: none !important;
    background: transparent !important;
    padding-left: 0 !important;
    font-size: 14px !important;
    margin-bottom: 0 !important;
}

#order-standard_cart .view-cart-tabs .nav-tabs li a,
#order-standard_cart .view-cart-tabs .nav-tabs .nav-link {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-bottom: none !important;
    border-radius: 8px 8px 0 0 !important;
    color: #fff !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    padding: 10px 20px !important;
}

#order-standard_cart .view-cart-tabs .nav-tabs li.active a,
#order-standard_cart .view-cart-tabs .nav-tabs .nav-link.active {
    background: var(--lighter-bg) !important;
    border-color: var(--border-color) !important;
}

#order-standard_cart .view-cart-tabs .tab-content,
#order-standard_cart .view-cart-tabs .tab-pane,
#order-standard_cart .panel-body {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 0 10px 10px 10px !important;
    padding: 20px !important;
}

#order-standard_cart .view-cart-tabs .tab-pane {
    border: none !important;
    border-radius: 0 !important;
}

#order-standard_cart .view-cart-tabs .tab-content .form-control,
#order-standard_cart .view-cart-tabs .tab-pane .form-control {
    background: var(--body-bg) !important;
    border: 1px solid var(--border-color) !important;
    color: #fff !important;
    height: 48px !important;
}

/* Prepend icon inputs - applies to promo code and checkout form fields */
.prepend-icon,
#order-standard_cart .prepend-icon {
    position: relative !important;
}

.prepend-icon .form-control,
.prepend-icon input.field,
#order-standard_cart .prepend-icon .form-control,
#order-standard_cart .prepend-icon input.field,
#order-standard_cart .prepend-icon .field {
    padding-left: 40px !important;
}

.prepend-icon .field-icon,
#order-standard_cart .prepend-icon .field-icon,
#order-standard_cart .prepend-icon label.field-icon {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    transform: none !important;
    z-index: 4 !important;
    color: var(--main-text-color) !important;
    pointer-events: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 40px !important;
    height: 100% !important;
    line-height: 38px !important;
    text-align: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.prepend-icon .field-icon i,
#order-standard_cart .prepend-icon .field-icon i {
    font-size: 14px !important;
    position: static !important;
    color: #888 !important;
}

/* Phone number input with intl-tel-input - hide the prepend icon since flag selector takes its place */
#order-standard_cart .prepend-icon .iti,
.prepend-icon .iti {
    width: 100% !important;
}

#order-standard_cart .prepend-icon:has(.iti) .field-icon,
.prepend-icon:has(.iti) .field-icon {
    display: none !important;
}

/* Let intl-tel-input handle padding automatically */

/* Style the intl-tel-input dropdown */
.iti__flag-container {
    padding: 0 !important;
}

.iti__selected-flag {
    background: transparent !important;
    border-right: 1px solid var(--border-color) !important;
    padding: 0 8px 0 12px !important;
}

.iti__country-list {
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    margin-top: 4px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
    z-index: 9999 !important;
    max-height: 300px !important;
}

.iti__country {
    padding: 8px 12px !important;
    color: #fff !important;
}

.iti__country:hover,
.iti__country.iti__highlight {
    background: rgba(59, 130, 246, 0.15) !important;
}

.iti__country-name {
    color: #fff !important;
}

.iti__dial-code {
    color: var(--main-text-color) !important;
}

.iti__divider {
    border-bottom-color: var(--border-color) !important;
}

/* Scrollbar for intl-tel-input country list */
.iti__country-list::-webkit-scrollbar {
    width: 8px !important;
}

.iti__country-list::-webkit-scrollbar-track {
    background: #2a2b33 !important;
    border-radius: 4px !important;
}

.iti__country-list::-webkit-scrollbar-thumb {
    background: #4a4b53 !important;
    border-radius: 4px !important;
}

.iti__country-list::-webkit-scrollbar-thumb:hover {
    background: #5a5b63 !important;
}

/* Old intl-tel-input version (without iti__ prefix) used in cart */
.intl-tel-input .country-list {
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    margin-top: 4px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
    z-index: 9999 !important;
    max-height: 300px !important;
}

.intl-tel-input .country-list .country {
    padding: 8px 12px !important;
    color: #fff !important;
}

.intl-tel-input .country-list .country:hover,
.intl-tel-input .country-list .country.highlight {
    background: rgba(59, 130, 246, 0.15) !important;
}

.intl-tel-input .country-list .country-name {
    color: #fff !important;
}

.intl-tel-input .country-list .dial-code {
    color: var(--main-text-color) !important;
}

.intl-tel-input .country-list .divider {
    border-bottom-color: var(--border-color) !important;
}

.intl-tel-input .selected-flag {
    background: transparent !important;
}

.intl-tel-input .selected-flag:hover,
.intl-tel-input .selected-flag:focus {
    background: rgba(255, 255, 255, 0.05) !important;
}

/* Scrollbar for old intl-tel-input */
.intl-tel-input .country-list::-webkit-scrollbar {
    width: 8px !important;
}

.intl-tel-input .country-list::-webkit-scrollbar-track {
    background: #2a2b33 !important;
    border-radius: 4px !important;
}

.intl-tel-input .country-list::-webkit-scrollbar-thumb {
    background: #4a4b53 !important;
    border-radius: 4px !important;
}

.intl-tel-input .country-list::-webkit-scrollbar-thumb:hover {
    background: #5a5b63 !important;
}

/* Phone field in cart - ensure cursor is after dropdown button */
.phone-field-container .intl-tel-input {
    width: 100% !important;
    display: block !important;
}

.phone-field-container .intl-tel-input input,
.phone-field-container .intl-tel-input input.form-control,
.phone-field-container .intl-tel-input input[type=tel],
#order-standard_cart .phone-field-container .intl-tel-input input,
#inputPhone {
    padding-left: 90px !important;
}

#order-standard_cart .view-cart-tabs .tab-content .btn,
#order-standard_cart .view-cart-tabs .tab-pane .btn,
#order-standard_cart button[name="validatepromo"] {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    color: #fff !important;
}

#order-standard_cart .view-cart-tabs .tab-content .btn:hover,
#order-standard_cart .view-cart-tabs .tab-pane .btn:hover,
#order-standard_cart button[name="validatepromo"]:hover {
    border-color: var(--blue) !important;
    background: var(--lighter-bg) !important;
}

/* Continue Shopping button */
#order-standard_cart .btn-continue-shopping,
#order-standard_cart .btn-link {
    color: var(--blue) !important;
    text-decoration: none !important;
}

#order-standard_cart .btn-continue-shopping:hover,
#order-standard_cart .btn-link:hover {
    color: #fff !important;
    text-decoration: underline !important;
}

/* Default buttons in cart */
#order-standard_cart .btn-default {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    color: #fff !important;
}

#order-standard_cart .btn-default:hover {
    border-color: var(--blue) !important;
}

/* Order Summary section in cart view */
#order-standard_cart .order-summary {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    padding: 20px !important;
}

#order-standard_cart .total-due-today {
    background: transparent !important;
    border: none !important;
    padding: 16px 0 0 0 !important;
}

#order-standard_cart .order-summary h2 {
    font-size: 20px !important;
    font-weight: 600 !important;
    color: #fff !important;
    margin-bottom: 16px !important;
}

#order-standard_cart .order-summary .subtotal,
#order-standard_cart .order-summary .clearfix {
    padding: 8px 0 !important;
    border-bottom: 1px solid var(--border-color) !important;
    color: var(--main-text-color) !important;
}

#order-standard_cart .order-summary .total {
    padding-top: 12px !important;
    font-size: 24px !important;
    font-weight: 600 !important;
    color: #fff !important;
}

/* Checkout button */
#order-standard_cart .btn-checkout,
#order-standard_cart a[href*="checkout"] .btn-primary,
#order-standard_cart .btn-success.btn-lg {
    background: #4ade80 !important;
    border: none !important;
    color: #000 !important;
    font-weight: 600 !important;
    border-radius: 10px !important;
    padding: 14px 24px !important;
    font-size: 15px !important;
    width: 100% !important;
    margin-top: 16px !important;
}

#order-standard_cart .btn-checkout:hover,
#order-standard_cart a[href*="checkout"] .btn-primary:hover,
#order-standard_cart .btn-success.btn-lg:hover {
    background: #22c55e !important;
}

/* ================================================
   CHECKOUT PAGE - Login & Signup Forms
   ================================================ */

/* Already registered section */
#order-standard_cart .already-registered {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    padding: 16px 20px !important;
    margin-bottom: 24px !important;
}

#order-standard_cart .already-registered::before,
#order-standard_cart .already-registered::after {
    display: none !important;
    content: none !important;
}

#order-standard_cart .already-registered p {
    margin: 0 !important;
    padding: 0 !important;
    color: var(--main-text-color) !important;
    font-size: 14px !important;
    order: -1 !important;
    flex: 1 !important;
}

#order-standard_cart .already-registered .pull-right,
#order-standard_cart .already-registered .float-right {
    float: none !important;
    order: 1 !important;
}

#order-standard_cart #btnAlreadyRegistered {
    background: transparent !important;
    border: 1px solid var(--blue) !important;
    color: var(--blue) !important;
    font-weight: 500 !important;
    padding: 8px 20px !important;
    border-radius: 6px !important;
}

#order-standard_cart #btnAlreadyRegistered:hover {
    background: var(--blue) !important;
    color: #fff !important;
}

#order-standard_cart #btnNewUserSignup {
    background: transparent !important;
    border: 1px solid var(--blue) !important;
    color: var(--blue) !important;
    font-weight: 500 !important;
    padding: 8px 20px !important;
    border-radius: 6px !important;
}

#order-standard_cart #btnNewUserSignup:hover {
    background: var(--blue) !important;
    color: #fff !important;
}

/* Existing user login container */
#order-standard_cart #containerExistingUserSignin {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    padding: 24px !important;
    margin-bottom: 24px !important;
}

#order-standard_cart #containerExistingUserSignin .sub-heading {
    margin-top: 0 !important;
    border: none !important;
    padding-bottom: 0 !important;
    text-align: left !important;
    height: auto !important;
}

#order-standard_cart #containerExistingUserSignin .sub-heading span {
    background: transparent !important;
    padding: 0 !important;
    position: static !important;
    top: auto !important;
}

#order-standard_cart #btnExistingLogin {
    background: var(--blue) !important;
    border: none !important;
    color: #fff !important;
    font-weight: 600 !important;
    padding: 10px 32px !important;
    border-radius: 6px !important;
    margin-top: 8px !important;
}

#order-standard_cart #btnExistingLogin:hover {
    background: #0080e0 !important;
}

/* Total Due Today alert */
#order-standard_cart .alert-success {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    color: var(--main-text-color) !important;
    border-radius: 10px !important;
    padding: 16px 20px !important;
}

#order-standard_cart #totalDueToday {
    color: #fff !important;
}

#order-standard_cart #totalCartPrice {
    color: #22c55e !important;
    font-size: 1.3em !important;
}

/* Apply credit container */
#order-standard_cart .apply-credit-container {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    color: var(--main-text-color) !important;
}

#order-standard_cart .apply-credit-container span {
    color: var(--main-text-color) !important;
}

/* Textarea styling */
#order-standard_cart textarea.field,
#order-standard_cart textarea.form-control {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    color: var(--main-text-color) !important;
    border-radius: 8px !important;
    padding: 12px !important;
}

#order-standard_cart textarea.field::placeholder,
#order-standard_cart textarea.form-control::placeholder {
    color: #666 !important;
}

/* Credit card input container */
#order-standard_cart .cc-input-container {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    color: var(--main-text-color) !important;
    padding: 16px !important;
    margin-top: 0 !important;
}

#order-standard_cart .cc-input-container ul li {
    color: var(--main-text-color) !important;
}

/* Checkout security message */
#order-standard_cart .checkout-security-msg {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    color: var(--main-text-color) !important;
    border-radius: 10px !important;
}

/* Payment gateway container */
#order-standard_cart .view-cart-gateway-checkout {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
}

/* Payment method labels */
#order-standard_cart #paymentGatewaysContainer label,
#order-standard_cart .radio-inline {
    color: var(--main-text-color) !important;
    font-weight: 400 !important;
}

/* ================================================
   ACCOUNT SELECTOR - Checkout
   ================================================ */

.account-select-container {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 24px;
}

.account-option {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px;
    background: var(--surface-3);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
}

.account-option:hover {
    background: var(--surface-4);
    border-color: var(--blue);
}

.account-option--selected,
.account-option:has(input:checked) {
    background: var(--blue-subtle);
    border-color: var(--blue);
}

.account-option--disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.account-option input[type="radio"] {
    flex-shrink: 0;
}

.account-option__content {
    flex: 1;
}

.account-option__name {
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 4px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.account-option__badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: var(--text-xs);
    font-weight: 500;
    border-radius: 4px;
    background: var(--blue);
    color: #fff;
}

.account-option__badge--disabled {
    background: var(--text-muted);
}

.account-option__address {
    color: var(--text-tertiary);
    font-size: var(--text-sm);
    line-height: 1.4;
}

.account-option--new {
    background: transparent;
    border-style: dashed;
}

.account-option--new:hover {
    background: var(--surface-3);
    border-style: solid;
}

.account-option__new-text {
    color: var(--text-secondary);
    font-weight: 500;
}

/* ================================================
   PAYMENT GATEWAY LIST - Checkout
   ================================================ */

.payment-gateways-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 12px;
}

.payment-gateway-option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: var(--surface-3);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
    color: var(--text-primary);
    font-weight: 500;
}

.payment-gateway-option:hover {
    background: var(--surface-4);
    border-color: var(--blue);
}

.payment-gateway-option:has(input:checked) {
    background: var(--blue-subtle);
    border-color: var(--blue);
}

.payment-gateway-option input[type="radio"] {
    flex-shrink: 0;
}

/* ================================================
   NEW CARD SAVE SETTINGS - Checkout
   ================================================ */

.new-card-save-settings {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--border-color);
}

.new-card-save-settings .form-group {
    margin-bottom: 16px;
}

.store-card-toggle {
    display: flex;
    align-items: center;
    gap: 12px;
}

.store-card-toggle .toggle-label {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    color: var(--text-secondary);
}

/* ================================================
/* ================================================
   BILLING CYCLE SELECTOR - Cleaner dropdown
   ================================================ */

#order-standard_cart .field-container {
    margin-bottom: 24px !important;
    width: 100% !important;
}

#order-standard_cart .field-container.billing-cycle-container {
    width: 100% !important;
    max-width: 100% !important;
}

#order-standard_cart #inputBillingcycle {
    max-width: 280px !important;
}

/* ================================================
   SUB-HEADINGS
   ================================================ */

#order-standard_cart .sub-heading {
    margin: 32px 0 20px 0 !important;
    border-bottom: 1px solid var(--border-color) !important;
    padding-bottom: 12px !important;
}

#order-standard_cart .sub-heading span {
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
}

/* ================================================
   HELP TEXT / CONTACT BANNER
   ================================================ */

#order-standard_cart .alert-warning.info-text-sm {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    color: var(--main-text-color) !important;
    padding: 16px 20px !important;
    margin-top: 32px !important;
}

#order-standard_cart .alert-warning.info-text-sm a {
    color: var(--blue) !important;
}

/* ================================================
   RESPONSIVE ADJUSTMENTS
   ================================================ */

@media (max-width: 991px) {
    /* Switch grid from 2 columns to single column */
    #order-standard_cart #frmConfigureProduct > .row,
    #order-standard_cart .cart-body > .row {
        grid-template-columns: 1fr !important;
        gap: 24px !important;
    }

    #order-standard_cart .secondary-cart-body,
    #order-standard_cart .secondary-cart-sidebar {
        width: 100% !important;
        max-width: 100% !important;
        padding-right: 0 !important;
    }

    #order-standard_cart .secondary-cart-sidebar {
        margin-top: 8px !important;
    }
}

/* ================================================
   COMMON OPTION CARDS (used by billing cycle & location)
   ================================================ */

#order-standard_cart .option-cards,
#order-standard_cart .billing-cycle-cards,
#order-standard_cart .location-cards {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

#order-standard_cart .option-card,
#order-standard_cart .billing-cycle-card,
#order-standard_cart .location-card {
    flex: 0 0 calc(25% - 7.5px) !important;
    width: calc(25% - 7.5px) !important;
    max-width: calc(25% - 7.5px) !important;
    min-width: 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    padding: 12px 14px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

#order-standard_cart .option-card:hover,
#order-standard_cart .billing-cycle-card:hover,
#order-standard_cart .location-card:hover {
    border-color: var(--blue) !important;
}

#order-standard_cart .option-card.selected,
#order-standard_cart .billing-cycle-card.selected,
#order-standard_cart .location-card.selected {
    border-color: var(--blue) !important;
    background: rgba(0, 150, 255, 0.08) !important;
}

/* ================================================
   BILLING CYCLE CARDS - specific styles
   ================================================ */

#order-standard_cart .billing-cycle-container {
    margin-bottom: 32px !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}


#order-standard_cart .billing-cycle-label {
    display: block !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #fff !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 16px !important;
}

#order-standard_cart .billing-cycle-card {
    position: relative !important;
    justify-content: space-between !important;
}

#order-standard_cart .billing-cycle-card input[type="radio"],
#order-standard_cart .billing-cycle-cards input[type="radio"],
.billing-cycle-card input[type="radio"] {
    position: absolute !important;
    opacity: 0 !important;
    pointer-events: none !important;
    width: 0 !important;
    height: 0 !important;
    visibility: hidden !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    display: none !important;
}

/* Hide iCheck in billing cycle cards completely */
#order-standard_cart .billing-cycle-card .iradio_square-blue,
#order-standard_cart .billing-cycle-card .icheckbox_square-blue,
#order-standard_cart .billing-cycle-card > div[class*="iradio"],
#order-standard_cart .billing-cycle-card > div[class*="icheckbox"],
.billing-cycle-card .iradio_square-blue,
.billing-cycle-cards .iradio_square-blue,
#order-standard_cart .billing-cycle-card .iCheck-helper,
.billing-cycle-card .iCheck-helper,
.billing-cycle-cards .iCheck-helper {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    min-width: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    position: absolute !important;
    visibility: hidden !important;
    opacity: 0 !important;
    overflow: hidden !important;
}

/* Custom radio circle */
#order-standard_cart .billing-cycle-card .cycle-radio,
.billing-cycle-card .cycle-radio {
    display: inline-block !important;
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    background: transparent !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 50% !important;
    margin-right: 10px !important;
    position: relative !important;
    transition: all 0.2s ease !important;
}

#order-standard_cart .billing-cycle-card.selected .cycle-radio,
.billing-cycle-card.selected .cycle-radio {
    border-color: var(--blue) !important;
    background: var(--blue) !important;
}

#order-standard_cart .billing-cycle-card.selected .cycle-radio::after,
.billing-cycle-card.selected .cycle-radio::after {
    content: '' !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 6px !important;
    height: 6px !important;
    background: #fff !important;
    border-radius: 50% !important;
}

#order-standard_cart .billing-cycle-card .cycle-name {
    font-size: 16px !important;
    font-weight: 300 !important;
    color: var(--main-text-color) !important;
    margin-bottom: 0 !important;
    margin-right: auto !important;
}

#order-standard_cart .billing-cycle-card.selected .cycle-name {
    font-weight: 500 !important;
    color: #fff !important;
}

#order-standard_cart .billing-cycle-card .cycle-badge {
    font-size: 10px !important;
    font-weight: 600 !important;
    color: #4ade80 !important;
    background: rgba(74, 222, 128, 0.15) !important;
    padding: 2px 8px !important;
    border-radius: 10px !important;
    margin-bottom: 0 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

/* All badges use same green color */

#order-standard_cart .billing-cycle-card .cycle-price {
    font-size: 13px !important;
    color: var(--main-text-color) !important;
}

#order-standard_cart .billing-cycle-card.selected .cycle-price {
    color: #fff !important;
}

@media (max-width: 576px) {
    #order-standard_cart .billing-cycle-cards {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* ================================================
   PROMO CODE BANNER
   ================================================ */

#order-standard_cart .promo-code-banner {
    align-items: center !important;
    gap: 14px !important;
    background: rgba(74, 222, 128, 0.15) !important;
    border: 1px solid rgba(74, 222, 128, 0.3) !important;
    border-radius: 10px !important;
    padding: 16px 20px !important;
    margin: 16px 0 !important;
    color: #4ade80 !important;
}

#order-standard_cart .promo-code-banner.show {
    display: flex !important;
}

#order-standard_cart .promo-code-banner i {
    font-size: 24px !important;
}

#order-standard_cart .promo-code-banner .promo-code-text {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

#order-standard_cart .promo-code-banner .promo-code-text strong {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #4ade80 !important;
}

#order-standard_cart .promo-code-banner .promo-code-text span {
    font-size: 13px !important;
    color: var(--main-text-color) !important;
}

/* Applied promo code display */
.view-cart-promotion-code {
    background: var(--green-subtle) !important;
    color: var(--green) !important;
    border: 1px solid var(--green) !important;
    border-radius: var(--radius-md) !important;
    padding: 16px 20px !important;
    text-align: center !important;
    margin-bottom: 16px !important;
}

.view-cart-promotion-code a.btn {
    background: transparent !important;
    border: 1px solid var(--green) !important;
    color: var(--green) !important;
    margin-top: 12px !important;
}

.view-cart-promotion-code a.btn:hover {
    background: var(--green) !important;
    color: #fff !important;
}

/* Continue button full width */
#order-standard_cart #btnCompleteProductConfig {
    width: 100% !important;
    margin-top: 16px !important;
}

/* Order Confirmation Page */
.alert.order-confirmation {
    display: block !important;
    background: var(--blue-subtle) !important;
    border: 1px solid var(--blue) !important;
    color: var(--text-primary) !important;
    padding: 20px 24px !important;
    border-radius: var(--radius-md) !important;
    text-align: center !important;
    max-width: 400px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    margin-bottom: 20px !important;
}

.alert.order-confirmation span {
    font-size: 24px;
    font-weight: 700;
    color: var(--blue);
    display: block;
    margin-top: 8px;
}

/* Support CTA */
#order-standard_cart .support-cta {
    margin-top: 16px !important;
    padding: 14px 16px !important;
    border: 1px solid var(--blue) !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    color: var(--main-text-color) !important;
    text-align: center !important;
}

#order-standard_cart .support-cta i {
    color: var(--blue) !important;
    margin-right: 6px !important;
}

#order-standard_cart .support-cta a {
    color: var(--blue) !important;
    text-decoration: none !important;
}

#order-standard_cart .support-cta a:hover {
    text-decoration: underline !important;
}

/* ================================================
   LOCATION SELECTOR CARDS
   ================================================ */

#order-standard_cart .location-selector-group {
    margin-bottom: 24px !important;
}

#order-standard_cart .location-selector-group > label {
    display: block !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #fff !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 12px !important;
}

#order-standard_cart .location-region {
    margin-bottom: 20px !important;
}

#order-standard_cart .location-region:last-child {
    margin-bottom: 0 !important;
}

#order-standard_cart .location-region-label {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--main-text-color) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 12px !important;
    opacity: 0.7 !important;
}

/* Location-specific styles (base styles in common section above) */
#order-standard_cart .location-card .location-flag {
    width: 28px !important;
    height: 20px !important;
    object-fit: cover !important;
    border-radius: 3px !important;
    flex-shrink: 0 !important;
}

#order-standard_cart .location-card .location-name {
    font-size: 16px !important;
    font-weight: 300 !important;
    color: var(--main-text-color) !important;
    line-height: 1.3 !important;
}

#order-standard_cart .location-card.selected .location-name {
    font-weight: 500 !important;
    color: #fff !important;
}

@media (max-width: 768px) {
    #order-standard_cart .location-cards {
        flex-direction: column !important;
    }

    #order-standard_cart .location-card {
        flex: 0 0 100% !important;
        width: 100% !important;
        max-width: 100% !important;
    }
}

/* ================================================
   RADIO CONFIG OPTIONS (like CPU Priority)
   ================================================ */

#order-standard_cart .radio-config-group {
    width: 100% !important;
}

#order-standard_cart .radio-config-group > label:first-child {
    display: block !important;
    margin-bottom: 12px !important;
}

#order-standard_cart .radio-options-container {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}

#order-standard_cart .radio-option-card {
    flex: 0 0 calc(50% - 5px) !important;
    display: flex !important;
    align-items: center !important;
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    padding: 0 14px !important;
    height: 48px !important;
    margin: 0 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    box-sizing: border-box !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

#order-standard_cart .radio-option-card:hover {
    border-color: var(--blue) !important;
}

#order-standard_cart .radio-option-card.selected {
    border-color: var(--blue) !important;
    background: rgba(0, 150, 255, 0.08) !important;
}

#order-standard_cart .radio-option-card.selected .radio-option-text {
    font-weight: 500 !important;
    color: #fff !important;
}

/* Radio option text with price badge */
#order-standard_cart .radio-option-card .radio-option-text {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex: 1 !important;
    justify-content: space-between !important;
    font-size: 16px !important;
    font-weight: 300 !important;
    color: var(--main-text-color) !important;
}

#order-standard_cart .radio-option-card .price-badge {
    font-size: 10px !important;
    font-weight: 600 !important;
    color: var(--blue) !important;
    background: rgba(0, 150, 255, 0.15) !important;
    padding: 2px 8px !important;
    border-radius: 10px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    white-space: nowrap !important;
}

/* ================================================
   ADDON PANELS
   ================================================ */

#order-standard_cart .addon-section > label {
    display: block !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #fff !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 12px !important;
}

#order-standard_cart .addon-products {
    margin: 0 !important;
}

#order-standard_cart .addon-products > div {
    padding: 0 !important;
}

#order-standard_cart .panel-addon {
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    margin: 0 !important;
    box-shadow: none !important;
    text-align: left !important;
}

#order-standard_cart .panel-addon:hover {
    border-color: var(--blue) !important;
}

#order-standard_cart .panel-addon.panel-addon-selected,
#order-standard_cart .panel-addon:has(input:checked) {
    border-color: var(--blue) !important;
    background: rgba(0, 150, 255, 0.08) !important;
}

#order-standard_cart .panel-addon .panel-body {
    padding: 16px 20px !important;
    background: transparent !important;
    border: none !important;
}

#order-standard_cart .panel-addon .panel-body label {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    color: #fff !important;
    margin: 0 0 8px 0 !important;
    cursor: pointer !important;
}

#order-standard_cart .panel-addon .panel-body label input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    accent-color: var(--blue) !important;
}

/* Hide iCheck on addon checkboxes */
#order-standard_cart .panel-addon .icheckbox_square-blue {
    display: none !important;
}

#order-standard_cart .panel-addon .panel-body br {
    display: none !important;
}

#order-standard_cart .panel-addon .panel-body label + br + * {
    color: var(--main-text-color) !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

#order-standard_cart .panel-addon .panel-price {
    background: var(--lighter-bg) !important;
    color: #4ade80 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    padding: 10px 20px !important;
    text-align: center !important;
    border: none !important;
}

#order-standard_cart .panel-addon .panel-add {
    display: none !important;
}

/* ================================================
   BATTLEMETRICS RCON - PARTNER STYLING
   ================================================ */

#order-standard_cart .battlemetrics-card {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    background: var(--light-bg) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    padding: 16px 20px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

#order-standard_cart .battlemetrics-card:hover {
    border-color: var(--blue) !important;
}

#order-standard_cart .battlemetrics-card.selected {
    border-color: var(--blue) !important;
    background: rgba(0, 150, 255, 0.08) !important;
}

#order-standard_cart .battlemetrics-logo-wrap {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-shrink: 0 !important;
}

#order-standard_cart .battlemetrics-logo {
    height: 40px !important;
    width: auto !important;
}

#order-standard_cart .partner-badge {
    background: rgba(255, 7, 0, 0.15) !important;
    color: #ff0700 !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    padding: 3px 8px !important;
    border-radius: 10px !important;
}

/* Tagline text */
#order-standard_cart .battlemetrics-tagline {
    color: var(--main-text-color) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    margin: 0 !important;
    flex: 1 !important;
}

/* Price badge - same style as CPU priority */
#order-standard_cart .battlemetrics-price {
    font-size: 10px !important;
    font-weight: 600 !important;
    color: var(--blue) !important;
    background: rgba(0, 150, 255, 0.15) !important;
    padding: 2px 8px !important;
    border-radius: 10px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}

/* ================================================
   SELECT DROPDOWN FIXES
   ================================================ */

#order-standard_cart select.form-control,
.product-configurable-options select.form-control {
    scrollbar-width: thin !important;
    scrollbar-color: var(--border-color) var(--light-bg) !important;
}

#order-standard_cart select.form-control::-webkit-scrollbar,
.product-configurable-options select.form-control::-webkit-scrollbar {
    width: 8px !important;
    background: var(--light-bg) !important;
}

#order-standard_cart select.form-control::-webkit-scrollbar-track,
.product-configurable-options select.form-control::-webkit-scrollbar-track {
    background: var(--light-bg) !important;
    border-radius: 0 4px 4px 0 !important;
}

#order-standard_cart select.form-control::-webkit-scrollbar-thumb,
.product-configurable-options select.form-control::-webkit-scrollbar-thumb {
    background: var(--border-color) !important;
    border-radius: 4px !important;
}

#order-standard_cart select.form-control option,
.product-configurable-options select.form-control option {
    background: var(--light-bg) !important;
    color: var(--main-text-color) !important;
    padding: 10px 12px !important;
    border: none !important;
    outline: none !important;
}

#order-standard_cart select.form-control,
.product-configurable-options select.form-control {
    border-right: 1px solid var(--border-color) !important;
    outline: none !important;
    box-shadow: none !important;
}

/* ================================================
   PRODUCT HERO BANNER
   ================================================ */

#order-standard_cart .product-hero-banner {
    position: relative !important;
    width: 100% !important;
    /* background-image set dynamically via inline style in template */
    background-color: #23242b !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: 12px !important;
    border: 1px solid var(--border-color) !important;
    margin-bottom: 24px !important;
    overflow: hidden !important;
}

#order-standard_cart .product-hero-banner::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: linear-gradient(135deg, rgba(21, 22, 30, 0.8) 0%, rgba(21, 22, 30, 0.5) 100%) !important;
    z-index: 1 !important;
}

#order-standard_cart .product-hero-banner .hero-content {
    position: relative !important;
    z-index: 2 !important;
    padding: 24px 28px !important;
}

#order-standard_cart .product-hero-banner .hero-title {
    font-size: 26px !important;
    font-weight: 700 !important;
    color: #fff !important;
    margin: 0 !important;
    line-height: 1.2 !important;
}

#order-standard_cart .product-hero-banner .hero-group {
    display: block !important;
    font-size: 16px !important;
    color: var(--main-text-color) !important;
    margin-top: 8px !important;
}

@media (max-width: 768px) {
    #order-standard_cart .product-hero-banner .hero-content {
        padding: 20px !important;
    }

    #order-standard_cart .product-hero-banner .hero-title {
        font-size: 22px !important;
    }
}

/* ================================================
   RESPONSIVE - MOBILE STYLES
   ================================================ */

@media (max-width: 991px) {
    /* Config options - full width columns */
    #order-standard_cart .product-configurable-options > .row > [class*="col-"] {
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    #order-standard_cart .product-configurable-options > .row {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* Billing cycle cards - 2 per row on tablet */
    #order-standard_cart .billing-cycle-cards {
        gap: 8px !important;
    }

    #order-standard_cart .option-card,
    #order-standard_cart .billing-cycle-card {
        flex: 0 0 calc(50% - 4px) !important;
        width: calc(50% - 4px) !important;
        max-width: calc(50% - 4px) !important;
        padding: 10px 12px !important;
    }

    /* Radio option cards - full width each */
    #order-standard_cart .radio-option-card {
        flex: 0 0 100% !important;
    }
}

@media (max-width: 576px) {
    /* Billing cycle cards - stack on small mobile */
    #order-standard_cart .option-card,
    #order-standard_cart .billing-cycle-card {
        flex: 0 0 100% !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    #order-standard_cart .billing-cycle-cards,
    #order-standard_cart .option-cards {
        gap: 8px !important;
    }

    /* Billing cycle card content adjustments */
    #order-standard_cart .billing-cycle-card .cycle-info {
        gap: 4px !important;
    }

    #order-standard_cart .billing-cycle-card .cycle-name {
        font-size: 13px !important;
    }

    #order-standard_cart .billing-cycle-card .cycle-price {
        font-size: 12px !important;
    }

    #order-standard_cart .billing-cycle-card .save-badge {
        font-size: 9px !important;
        padding: 2px 6px !important;
    }

    /* Location cards - full width on mobile */
    #order-standard_cart .location-cards {
        flex-direction: column !important;
        gap: 8px !important;
    }

    #order-standard_cart .location-card {
        flex: 0 0 100% !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 12px 14px !important;
    }

    /* BattleMetrics card - stack vertically */
    #order-standard_cart .battlemetrics-card {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 12px !important;
        padding: 16px !important;
    }

    #order-standard_cart .battlemetrics-logo-wrap {
        width: 100% !important;
        justify-content: space-between !important;
    }

    #order-standard_cart .battlemetrics-tagline {
        font-size: 13px !important;
        line-height: 1.4 !important;
    }

    #order-standard_cart .battlemetrics-price {
        align-self: flex-start !important;
    }

    /* Radio option cards */
    #order-standard_cart .radio-option-card {
        height: 44px !important;
        padding: 0 12px !important;
    }

    #order-standard_cart .radio-option-card .radio-option-text {
        font-size: 14px !important;
    }

    /* Addon panels */
    #order-standard_cart .addon-products > div {
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
    }

    #order-standard_cart .panel-addon .panel-body {
        padding: 14px 16px !important;
    }

    /* Config option labels */
    #order-standard_cart .product-configurable-options label {
        font-size: 13px !important;
        margin-bottom: 10px !important;
    }

    /* Form controls */
    #order-standard_cart .form-control,
    #order-standard_cart select.form-control {
        height: 44px !important;
        font-size: 14px !important;
    }

    /* Location region labels */
    #order-standard_cart .location-region-label {
        font-size: 11px !important;
        margin-bottom: 10px !important;
    }

    /* Order summary adjustments */
    #order-standard_cart .order-summary h2 {
        font-size: 20px !important;
    }
}


/* ============================================
   2026 THEME MODERNIZATION
   ============================================ */

/* ---- CARD OVERHAUL ---- */
.client-home-cards .card {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: all var(--transition-base);
    position: relative;
    box-shadow: var(--shadow-md);
}

.client-home-cards .card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 60%;
    background: var(--glass-shine);
    pointer-events: none;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.client-home-cards .card:hover {
    border-color: var(--border-hover);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

/* Card Headers */
.client-home-cards .card-header {
    background: transparent !important;
    border-bottom: 1px solid var(--divider) !important;
    padding: var(--space-4) var(--space-5) !important;
    position: relative;
}

.client-home-cards .card-header h3,
.client-home-cards .card-header .card-title {
    font-size: var(--text-base) !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
    letter-spacing: -0.01em;
    margin: 0 !important;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.client-home-cards .card-header h3 i,
.client-home-cards .card-header .card-title i {
    font-size: var(--text-lg);
    color: var(--blue);
    opacity: 0.9;
}

/* Card Header Buttons */
.client-home-cards .card-header .btn,
.client-home-cards .card-header a.btn {
    font-size: var(--text-xs) !important;
    font-weight: 600 !important;
    padding: 6px 12px !important;
    border-radius: var(--radius-sm) !important;
    background: var(--blue-subtle) !important;
    color: var(--blue) !important;
    border: none !important;
    transition: all var(--transition-fast) !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.client-home-cards .card-header .btn:hover,
.client-home-cards .card-header a.btn:hover {
    background: var(--blue) !important;
    color: white !important;
    transform: translateY(-1px);
}

/* Card Body */
.client-home-cards .card-body {
    padding: var(--space-5) !important;
}

/* Card Footer */
.client-home-cards .card-footer {
    background: rgba(0, 0, 0, 0.15) !important;
    border-top: 1px solid var(--divider) !important;
    padding: var(--space-3) var(--space-5) !important;
}

.client-home-cards .card-footer:empty {
    display: none !important;
}

/* ---- LIST ITEMS OVERHAUL ---- */
.client-home-cards .list-group {
    border: none !important;
    background: transparent !important;
}

.client-home-cards .list-group-item {
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid var(--divider) !important;
    padding: var(--space-4) var(--space-5) !important;
    color: var(--text-secondary) !important;
    transition: all var(--transition-fast) !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
}

.client-home-cards .list-group-item:last-child {
    border-bottom: none !important;
}

.client-home-cards .list-group-item:hover {
    background: rgba(255, 255, 255, 0.03) !important;
    color: var(--text-primary) !important;
    padding-left: calc(var(--space-5) + 4px) !important;
}

.client-home-cards .list-group-item i {
    color: var(--text-tertiary);
    transition: color var(--transition-fast);
    width: 20px;
    text-align: center;
    flex-shrink: 0;
}

.client-home-cards .list-group-item:hover i {
    color: var(--blue);
}

/* ---- SIDEBAR OVERHAUL ---- */
.sidebar .card,
.sidebar .panel {
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden;
    margin-bottom: var(--space-4);
}

.sidebar .card-header,
.sidebar .panel-heading {
    background: transparent !important;
    border-bottom: 1px solid var(--divider) !important;
    padding: var(--space-4) var(--space-4) !important;
}

.sidebar .card-header h3,
.sidebar .panel-title {
    font-size: var(--text-sm) !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-tertiary) !important;
    margin: 0 !important;
}

.sidebar .card-body,
.sidebar .panel-body {
    padding: var(--space-4) !important;
}

.sidebar .list-group-item {
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid var(--divider) !important;
    padding: var(--space-3) 0 !important;
    font-size: 15px;
    color: var(--text-secondary);
    transition: all var(--transition-fast);
}

.sidebar .list-group-item:last-child {
    border-bottom: none !important;
}

.sidebar .list-group-item:hover {
    color: var(--blue);
    padding-left: 4px !important;
}

.sidebar .list-group-item i {
    width: 20px;
    margin-right: var(--space-2);
    color: var(--text-muted);
    transition: color var(--transition-fast);
}

.sidebar .list-group-item:hover i {
    color: var(--blue);
}

/* ---- BUTTONS MODERNIZATION ---- */
.btn {
    font-family: var(--font-sans);
    font-weight: 600;
    border-radius: var(--radius-md);
    transition: all var(--transition-base);
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
}

.btn-primary,
.btn-success {
    background: var(--blue) !important;
    color: white !important;
    border: none !important;
    box-shadow: 0 2px 8px rgba(0, 150, 255, 0.3);
}

.btn-primary:hover,
.btn-success:hover {
    background: var(--blue-hover) !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 150, 255, 0.4);
}

.btn-primary:active,
.btn-success:active {
    transform: translateY(0);
}

.btn-default,
.btn-secondary {
    background: var(--surface-3) !important;
    color: var(--text-secondary) !important;
    border: 1px solid var(--border-color) !important;
}

.btn-default:hover,
.btn-secondary:hover {
    background: var(--surface-4) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-hover) !important;
}

.btn-danger {
    background: var(--red) !important;
    color: white !important;
    border: none !important;
    box-shadow: 0 2px 8px rgba(228, 0, 0, 0.3);
}

.btn-danger:hover {
    background: var(--red-hover) !important;
    box-shadow: 0 4px 16px rgba(228, 0, 0, 0.4);
}

.btn-link {
    color: var(--blue) !important;
    background: transparent !important;
    padding: 0 !important;
}

.btn-link:hover {
    color: var(--blue-hover) !important;
    text-decoration: none !important;
}

/* Small buttons */
.btn-sm, .btn-xs {
    font-size: var(--text-xs);
    padding: 6px 12px;
    border-radius: var(--radius-sm);
}

/* ---- BADGES & LABELS MODERNIZATION ---- */
.badge,
.label {
    font-family: var(--font-sans);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 4px 8px;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    margin-left: 8px;
    background: var(--surface-3) !important;
    color: var(--text-secondary) !important;
}

.badge-success, .label-success {
    background: var(--green-subtle) !important;
    color: var(--green) !important;
}

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

.badge-warning, .label-warning {
    background: var(--gold-subtle) !important;
    color: var(--gold) !important;
}

.badge-info, .label-info {
    background: var(--blue-subtle) !important;
    color: var(--blue) !important;
}

.badge-default, .label-default {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--text-tertiary) !important;
}

/* ---- TABLES MODERNIZATION ---- */
.table {
    border-collapse: separate;
    border-spacing: 0;
}

.table thead th {
    background: var(--surface-2) !important;
    color: var(--text-tertiary) !important;
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: var(--space-3) var(--space-4) !important;
    border-bottom: 1px solid var(--divider) !important;
}

.table tbody td {
    padding: var(--space-4) !important;
    border-bottom: 1px solid var(--divider) !important;
    color: var(--text-secondary);
    transition: background var(--transition-fast);
}

.table tbody tr:hover td {
    background: rgba(255, 255, 255, 0.02);
}

.table tbody tr:last-child td {
    border-bottom: none !important;
}

/* ---- ALERTS MODERNIZATION ---- */
.alert {
    border-radius: var(--radius-md);
    border: none;
    padding: var(--space-4) var(--space-5);
    font-size: var(--text-sm);
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
}

.alert-success {
    background: var(--green-subtle);
    color: var(--green);
    border-left: 3px solid var(--green);
}

.alert-danger, .alert-error {
    background: var(--red-subtle);
    color: var(--red);
    border-left: 3px solid var(--red);
}

.alert-warning {
    background: var(--gold-subtle);
    color: var(--gold);
    border-left: 3px solid var(--gold);
}

.alert-info {
    background: var(--blue-subtle);
    color: var(--blue);
    border-left: 3px solid var(--blue);
}

/* ---- FORM LABELS MODERNIZATION ---- */
label,
.control-label {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: var(--space-2);
    display: block;
}

/* ---- VIEW DETAILS LINKS ---- */
.client-home-cards a[href*="View"],
a.view-details {
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--blue);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    transition: all var(--transition-fast);
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.client-home-cards a[href*="View"]:hover,
a.view-details:hover {
    color: var(--blue-hover);
    gap: 6px;
}

.client-home-cards a[href*="View"]::after,
a.view-details::after {
    content: '→';
    transition: transform var(--transition-fast);
}

.client-home-cards a[href*="View"]:hover::after,
a.view-details:hover::after {
    transform: translateX(2px);
}

/* ---- PAGE ENTRANCE ANIMATIONS ---- */
@keyframes fadeSlideUp {
    from {
        opacity: 0;
        transform: translateY(16px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.client-home-cards .card {
    animation: fadeSlideUp 0.5s cubic-bezier(0.4, 0, 0.2, 1) backwards;
}

.client-home-cards .col-md-6:nth-child(1) .card,
.client-home-cards .col-xl-6:nth-child(1) .card {
    animation-delay: 0.1s;
}

.client-home-cards .col-md-6:nth-child(2) .card,
.client-home-cards .col-xl-6:nth-child(2) .card {
    animation-delay: 0.2s;
}

.sidebar .card,
.sidebar .panel {
    animation: fadeSlideUp 0.5s cubic-bezier(0.4, 0, 0.2, 1) backwards;
    animation-delay: 0.15s;
}

/* ---- SCROLLBAR STYLING ---- */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--surface-1);
}

::-webkit-scrollbar-thumb {
    background: var(--surface-4);
    border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

/* ---- FOCUS STATES ---- */
*:focus-visible {
    outline: 2px solid var(--blue);
    outline-offset: 2px;
}

button:focus-visible,
.btn:focus-visible,
a:focus-visible {
    outline: 2px solid var(--blue);
    outline-offset: 2px;
}

/* ---- TOOLTIP STYLING ---- */
.tooltip-inner {
    background: var(--surface-4);
    color: var(--text-primary);
    font-size: var(--text-xs);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-lg);
}

.tooltip.bs-tooltip-top .arrow::before,
.tooltip.bs-tooltip-auto[x-placement^="top"] .arrow::before {
    border-top-color: var(--surface-4);
}

/* ---- DROPDOWN MENUS ---- */
.dropdown-menu,
.navbar .dropdown-menu,
nav .dropdown-menu,
.nav .dropdown-menu {
    background: var(--surface-3) !important;
    background-color: var(--surface-3) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-xl) !important;
    padding: var(--space-2) !important;
    animation: fadeSlideUp 0.2s ease;
    margin-top: 8px !important;
}

.dropdown-menu > li,
li.dropdown-item {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
}

li.dropdown-item:hover,
li.dropdown-item:focus {
    background: transparent !important;
}

a.dropdown-item,
.dropdown-menu > li > a,
.navbar .dropdown-menu a.dropdown-item,
.navbar .dropdown-menu > li > a {
    color: var(--text-secondary) !important;
    background: transparent !important;
    padding: 10px 16px !important;
    border-radius: var(--radius-sm) !important;
    transition: all var(--transition-fast) !important;
    font-size: 16px !important;
    display: block !important;
}

a.dropdown-item:hover,
a.dropdown-item:focus,
.dropdown-menu > li > a:hover,
.dropdown-menu > li > a:focus,
.dropdown-menu > li:hover > a,
.navbar .dropdown-menu a.dropdown-item:hover,
.navbar .dropdown-menu > li > a:hover {
    background: var(--blue-subtle) !important;
    color: var(--blue) !important;
}

a.dropdown-item.active,
.dropdown-menu > li.active > a,
.dropdown-menu > .active > a,
.navbar .dropdown-menu a.dropdown-item.active,
.navbar .dropdown-menu > li.active > a {
    background: var(--blue-subtle) !important;
    color: var(--blue) !important;
}

/* Dropdown dividers */
.dropdown-divider {
    border-color: var(--border-color) !important;
    margin: var(--space-2) 0 !important;
}

/* ---- PAGINATION ---- */
.pagination {
    gap: var(--space-1);
}

.pagination .page-link,
.pagination > li > a {
    background: var(--surface-3);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    border-radius: var(--radius-sm);
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
    font-weight: 500;
    transition: all var(--transition-fast);
}

.pagination .page-link:hover,
.pagination > li > a:hover {
    background: var(--blue-subtle);
    border-color: var(--blue);
    color: var(--blue);
}

.pagination .page-item.active .page-link,
.pagination > .active > a {
    background: var(--blue);
    border-color: var(--blue);
    color: white;
}

/* ---- BREADCRUMBS ---- */
.breadcrumb {
    background: transparent;
    padding: 0;
    margin-bottom: var(--space-4);
    font-size: var(--text-sm);
}

.breadcrumb-item,
.breadcrumb > li {
    color: var(--text-tertiary);
}

.breadcrumb-item a,
.breadcrumb > li a {
    color: var(--text-secondary);
    transition: color var(--transition-fast);
}

.breadcrumb-item a:hover,
.breadcrumb > li a:hover {
    color: var(--blue);
}

.breadcrumb-item.active,
.breadcrumb > .active {
    color: var(--text-primary);
}

.breadcrumb-item + .breadcrumb-item::before,
.breadcrumb > li + li::before {
    color: var(--text-muted);
    content: "›";
}

/* ---- MODALS ---- */
.modal-content {
    background: var(--surface-2);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
}

.modal-header {
    border-bottom: 1px solid var(--divider);
    padding: var(--space-5);
}

.modal-title {
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--text-primary);
}

.modal-body {
    padding: var(--space-5);
}

.modal-footer {
    border-top: 1px solid var(--divider);
    padding: var(--space-4) var(--space-5);
    gap: var(--space-2);
}

.close,
.btn-close {
    color: var(--text-tertiary);
    opacity: 1;
    transition: color var(--transition-fast);
}

.close:hover,
.btn-close:hover {
    color: var(--text-primary);
}

/* ---- SPECIFIC HOMEPAGE PANELS ---- */

/* Your Info Panel */
.sidebar .card:first-child .card-body,
#panelYourInfo .card-body {
    text-align: center;
}

#panelYourInfo .client-avatar,
.sidebar .card:first-child .fa-user-circle {
    font-size: 48px;
    color: var(--blue);
    margin-bottom: var(--space-3);
    opacity: 0.8;
}

/* Shortcuts styling */
#panelShortcuts .list-group-item,
.sidebar .card:last-child .list-group-item {
    padding: var(--space-3) var(--space-4) !important;
}

/* Active Products Panel */
#servicesPanel .list-group-item,
[menuitemname*="Service"] .list-group-item {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
}

/* Unpaid Invoices - warning card accent */
#invoicesPanel.card-accent-gold,
[menuitemname*="Invoice"].card-accent-gold {
    border-left: 3px solid var(--gold);
}

#invoicesPanel.card-accent-gold .card-header i,
[menuitemname*="Invoice"].card-accent-gold .card-header i {
    color: var(--gold);
}

/* Support Tickets Panel */
#ticketsPanel .list-group-item .label,
[menuitemname*="Ticket"] .list-group-item .label {
    flex-shrink: 0;
}

/* ---- SIDEBAR CONTACTS PANEL ---- */
.sidebar .card .card-body {
    padding: var(--space-4) !important;
}

/* No Contacts Found text */
.sidebar .card-body p,
.sidebar .panel-body p {
    color: var(--text-tertiary);
    font-size: var(--text-sm);
    margin-bottom: var(--space-3);
    text-align: center;
}

/* New Contact button in sidebar */
.sidebar .card-body .btn,
.sidebar .panel-body .btn {
    width: 100%;
    justify-content: center;
}

/* Sidebar card header titles - CONTACTS, SHORTCUTS etc */
.sidebar .card-header h3,
.sidebar .card-header .card-title,
.sidebar .panel-heading .panel-title {
    font-size: 14px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: var(--text-tertiary) !important;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.sidebar .card-header h3 i,
.sidebar .card-header .card-title i {
    font-size: 14px;
    opacity: 0.7;
}

/* Collapse/expand arrow in sidebar */
.sidebar .card-header .float-right,
.sidebar .card-header [data-toggle="collapse"],
.sidebar .panel-heading [data-toggle="collapse"] {
    color: var(--text-muted) !important;
    transition: transform var(--transition-fast);
}

/* Your Info panel - center the content */
.sidebar .card:first-of-type .card-body {
    text-align: center;
    padding: var(--space-5) var(--space-4) !important;
}

.sidebar .card:first-of-type .card-body address {
    font-style: normal;
    color: var(--text-secondary);
    font-size: var(--text-sm);
    line-height: 1.6;
    margin-bottom: var(--space-4);
}

/* Update button - use brand green */
.sidebar .btn-success,
.sidebar .btn-primary {
    background: var(--green) !important;
    border: none !important;
    color: #000 !important;
    font-weight: 600 !important;
    padding: 10px 20px !important;
    width: 100%;
}

.sidebar .btn-success:hover,
.sidebar .btn-primary:hover {
    background: var(--green-hover) !important;
}

/* Shortcuts list alignment */
.sidebar .list-group-item {
    display: flex !important;
    align-items: center !important;
    gap: var(--space-3) !important;
    padding: var(--space-3) var(--space-4) !important;
    background: transparent !important;
    background-color: transparent !important;
}

.sidebar .list-group-item:hover,
.sidebar .list-group-item:focus,
.sidebar .list-group-item:active,
.sidebar .list-group-item.active:not(.btn),
.sidebar .list-group-item-action:hover,
.sidebar .list-group-item-action:focus,
.sidebar .list-group-item-action:active,
.sidebar .card .list-group-item,
.sidebar .card .list-group-item:hover,
.sidebar .card .list-group-item:focus,
.sidebar .card .list-group-item-action,
.sidebar .card .list-group-item-action:hover,
.sidebar .card .list-group-item-action:focus,
.sidebar .card .list-group-item-action:active,
.list-group-item-action.list-group-item:hover,
.list-group-item-action.list-group-item:focus {
    background: transparent !important;
    background-color: transparent !important;
}

.sidebar .list-group-item i {
    width: 18px;
    text-align: center;
    flex-shrink: 0;
}

/* Old payment form CSS removed - see consolidated section below */

#billingAddressChoice .address1,
#billingAddressChoice .city,
#billingAddressChoice .state,
#billingAddressChoice .postcode,
#billingAddressChoice .country {
    color: var(--text-tertiary);
    font-size: var(--text-sm);
}

/* CVV help link */
#cvvWhereLink,
#stripeCvcWhere .btn-link {
    color: var(--blue) !important;
    font-size: var(--text-sm) !important;
    padding: 0 !important;
}

/* Card description input */
#inputDescriptionContainer .form-control,
#inputDescription {
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    color: var(--text-primary) !important;
    padding: 12px 16px !important;
    height: 46px !important;
}

#inputDescriptionContainer .form-control:focus,
#inputDescription:focus {
    border-color: var(--blue) !important;
    box-shadow: none !important;
}

/* New billing address form */
#newBillingAddress .form-control {
    background: #1b1c24 !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    color: var(--text-primary) !important;
    height: 46px !important;
}

#newBillingAddress select.form-control,
#newBillingAddress .custom-select {
    background-color: #1b1c24 !important;
    color: var(--text-primary) !important;
}

/* International phone input */
.intl-tel-input {
    width: 100%;
}

.intl-tel-input .selected-flag {
    background: var(--surface-3) !important;
    border-right: 1px solid var(--border-color) !important;
    padding: 0 12px !important;
}

.intl-tel-input .country-list {
    background: var(--surface-3) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    box-shadow: var(--shadow-xl) !important;
    max-height: 300px;
}

.intl-tel-input .country-list .country {
    padding: 8px 12px !important;
    color: var(--text-secondary) !important;
}

.intl-tel-input .country-list .country:hover,
.intl-tel-input .country-list .country.highlight {
    background: var(--blue-subtle) !important;
    color: var(--blue) !important;
}

.intl-tel-input .country-list .country.active {
    background: var(--blue) !important;
    color: white !important;
}

.intl-tel-input .country-list .divider {
    border-color: var(--border-color) !important;
}

/* ============================================
   INVOICE SUMMARY CARD - Complete Dark Theme
   ============================================ */

/* The card wrapper */
#invoiceIdSummary.card {
    background: var(--surface-2) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden;
}

#invoiceIdSummary .card-body {
    background: transparent !important;
    padding: 24px !important;
}

/* Invoice number heading */
#invoiceIdSummary h2,
.invoice-summary h2 {
    color: var(--text-primary) !important;
    font-size: var(--text-xl) !important;
    font-weight: 600 !important;
    margin-bottom: 20px !important;
}

/* Invoice summary table */
.invoice-summary-table {
    background: var(--surface-3) !important;
    border-radius: var(--radius-md) !important;
    overflow: hidden;
    margin-bottom: 16px !important;
}

.invoice-summary-table .table {
    margin-bottom: 0 !important;
    color: var(--text-secondary) !important;
}

.invoice-summary-table .table td {
    background: transparent !important;
    border-color: var(--border-color) !important;
    padding: 12px 16px !important;
    color: var(--text-secondary) !important;
    vertical-align: middle !important;
}

.invoice-summary-table .table td strong {
    color: var(--text-primary) !important;
}

.invoice-summary-table .table tr:first-child td {
    background: rgba(0, 0, 0, 0.2) !important;
    color: var(--text-tertiary) !important;
    font-size: var(--text-sm) !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 1px solid var(--border-color) !important;
}

.invoice-summary-table .total-row {
    background: rgba(0, 0, 0, 0.15) !important;
    border-top: 1px solid var(--border-color) !important;
    font-weight: 500;
}

/* Payments to date text */
#invoiceIdSummary .mb-2,
.invoice-summary > .mb-2 {
    color: var(--text-secondary) !important;
    font-size: var(--text-sm) !important;
}

#invoiceIdSummary .mb-2 strong,
.invoice-summary > .mb-2 strong {
    color: var(--text-primary) !important;
}

/* Balance due alert */
#invoiceIdSummary .alert-success,
.invoice-summary .alert-success {
    background: linear-gradient(135deg, var(--green) 0%, #5ad92a 100%) !important;
    border: none !important;
    border-radius: var(--radius-md) !important;
    color: #000 !important;
    font-weight: 600 !important;
    padding: 16px 20px !important;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.2);
}

#invoiceIdSummary .alert-success strong,
.invoice-summary .alert-success strong {
    color: #000 !important;
}

/* ============================================
   iCHECK DARK THEME STYLING
   ============================================ */

/* Dark theme colors for iCheck blue skin */
.iradio_square-blue,
.icheckbox_square-blue {
    background-color: var(--surface-3);
    border-color: var(--border-color);
}

.iradio_square-blue.checked,
.icheckbox_square-blue.checked {
    border-color: var(--blue);
}

.iradio_square-blue:hover,
.icheckbox_square-blue:hover {
    border-color: var(--blue);
}

/* ============================================
   BILLING ADDRESS SELECTOR FIX
   ============================================ */

#billingAddressChoice {
    margin-bottom: 24px !important;
}

/* Old billing address styles moved to consolidated section below */

/* Address parts */
#billingAddressChoice .address1,
#billingAddressChoice .address2,
#billingAddressChoice .city,
#billingAddressChoice .state,
#billingAddressChoice .postcode,
#billingAddressChoice .country {
    color: var(--text-tertiary) !important;
    font-size: var(--text-sm) !important;
}

/* Text truncation wrapper */
#billingAddressChoice .text-truncate {
    display: block !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    max-width: 400px !important;
}

/* Duplicate payment CSS removed - see CUSTOM PAYMENT PAGE TEMPLATES section */

/* Billing address choice - compact */
#billingAddressChoice {
    margin-bottom: 16px !important;
}

/* Reset for old template structure */
#billingAddressChoice > .col-sm-8 {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

#billingAddressChoice br {
    display: none !important;
}

/* Only style billing-option labels as cards, not the section label */
#billingAddressChoice label.billing-option,
#billingAddressChoice .billing-contact-0 {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 16px !important;
    background: var(--surface-3) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-md) !important;
    margin: 0 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    font-size: var(--text-sm) !important;
}

#billingAddressChoice label.billing-option:hover {
    background: var(--surface-4) !important;
    border-color: var(--blue) !important;
}

#billingAddressChoice label.billing-option:has(.billing-option__radio:checked),
#billingAddressChoice label.billing-option:has(.iradio_square-blue.checked) {
    background: var(--blue-subtle) !important;
    border-color: var(--blue) !important;
}

/* "Add new billing address" option with + icon */
#billingAddressChoice label.billing-option--new {
    background: transparent !important;
    border-style: dashed !important;
}

#billingAddressChoice label.billing-option--new:hover {
    background: var(--surface-3) !important;
    border-color: var(--blue) !important;
    border-style: solid !important;
}

#billingAddressChoice label.billing-option--new .billing-option__name {
    color: var(--blue) !important;
}

#billingAddressChoice label.billing-option--new .billing-option__name i {
    font-size: 14px;
}

#billingAddressChoice .name {
    display: inline !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
}

#billingAddressChoice .name strong {
    color: var(--text-primary) !important;
    font-weight: 600 !important;
}

/* Submit button container */
#btnSubmitContainer {
    margin-top: 24px !important;
    padding-top: 20px !important;
    border-top: 1px solid var(--border-color) !important;
}

#btnSubmit {
    padding: 14px 40px !important;
    font-size: var(--text-base) !important;
    font-weight: 600 !important;
    border-radius: var(--radius-md) !important;
}

/* Payment method radio - compact */
#frmPayment .paymethod-info,
#frmPayment [class*="paymethod"] {
    margin-bottom: 16px !important;
}

/* Card description - compact */
#inputDescriptionContainer {
    margin-bottom: 0 !important;
}

/* Stripe error text - keep it readable */
#frmPayment .gateway-errors {
    background: var(--red-subtle) !important;
    border: 1px solid var(--red) !important;
    border-radius: var(--radius-md) !important;
    color: var(--red) !important;
    padding: 12px 16px !important;
    margin-bottom: 16px !important;
}

/* Hide error containers by default - JS will show them */
.gateway-errors {
    display: none;
}

/* ============================================
   CUSTOM PAYMENT PAGE TEMPLATES
   ============================================ */

/* Page Layout */
.payment-page {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 24px;
    align-items: start;
}

@media (max-width: 991px) {
    .payment-page {
        grid-template-columns: 1fr;
    }
    .payment-page__sidebar {
        order: -1;
    }
}

/* Payment Card (Main Form) */
.payment-card {
    background: var(--surface-2);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.payment-card__header {
    padding: 20px 24px;
    border-bottom: 1px solid var(--border-color);
    background: rgba(0, 0, 0, 0.15);
}

.payment-card__title {
    margin: 0;
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 10px;
}

.payment-card__title i {
    color: var(--blue);
}

.payment-card__body {
    padding: 24px;
}

.payment-card__submit {
    padding: 20px 24px;
    border-top: 1px solid var(--border-color);
    background: rgba(0, 0, 0, 0.1);
}

/* Submit Button */
.btn-submit-payment {
    width: 100%;
    padding: 16px 32px;
    font-size: var(--text-base);
    font-weight: 600;
    color: #000;
    background: linear-gradient(135deg, var(--green) 0%, #5ad92a 100%);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.btn-submit-payment:hover {
    background: linear-gradient(135deg, var(--green-hover) 0%, var(--green) 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 20px rgba(106, 235, 52, 0.3);
}

.btn-submit-payment:active {
    transform: translateY(0);
}

.btn-submit-payment i {
    font-size: 14px;
}

/* Form Sections */
.form-section {
    margin-bottom: 20px;
}

.form-section__label {
    display: block;
    color: var(--text-secondary);
    font-size: var(--text-sm);
    font-weight: 500;
    margin-bottom: 8px;
}

.form-section__content {
    width: 100%;
}

/* Form Rows */
.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

@media (max-width: 576px) {
    .form-row {
        grid-template-columns: 1fr;
    }
}

/* Form Fields */
.form-field {
    margin-bottom: 16px;
}

.form-field label {
    display: block;
    color: var(--text-secondary);
    font-size: var(--text-sm);
    font-weight: 500;
    margin-bottom: 6px;
}

/* Inputs */
.payment-page .form-control,
.payment-card .form-control,
.new-billing-form .form-control {
    background: #1b1c24;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    padding: 12px 16px;
    height: auto;
    font-size: var(--text-base);
    transition: all 0.2s ease;
}

.payment-page .form-control:focus,
.payment-card .form-control:focus,
.new-billing-form .form-control:focus {
    border-color: var(--blue);
    box-shadow: 0 0 0 3px var(--blue-glow);
    outline: none;
}

.payment-page .form-control::placeholder {
    color: var(--text-muted);
}

.input-short {
    max-width: 140px;
}

/* CVV Input Group */
.cvv-input-group {
    display: flex;
    align-items: center;
    gap: 12px;
}

.cvv-help-btn {
    background: none;
    border: none;
    color: var(--blue);
    font-size: var(--text-sm);
    cursor: pointer;
    padding: 0;
    white-space: nowrap;
}

.cvv-help-btn:hover {
    color: var(--blue-hover);
    text-decoration: underline;
}

/* Field Error */
.field-error-msg {
    display: none;
    color: var(--red);
    font-size: var(--text-sm);
    margin-top: 6px;
}

.has-error .field-error-msg {
    display: block;
}

.has-error .form-control {
    border-color: var(--red);
}

/* ============================================
   SAVED CARDS
   ============================================ */

.saved-cards {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 16px;
}

.saved-card {
    display: flex !important;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--surface-3);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
}

.saved-card:hover {
    background: var(--surface-4);
    border-color: var(--blue);
}

.saved-card:has(.saved-card__radio:checked) {
    background: var(--blue-subtle);
    border-color: var(--blue);
}

.saved-card--expired {
    opacity: 0.6;
}

.saved-card__radio {
    flex-shrink: 0;
}

.saved-card__content {
    display: flex;
    align-items: center;
    gap: 14px;
    flex: 1;
}

.saved-card__icon {
    width: 40px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--surface-2);
    border-radius: 4px;
    font-size: 18px;
    color: var(--text-secondary);
}

.saved-card__details {
    flex: 1;
}

.saved-card__name {
    font-weight: 500;
    color: var(--text-primary);
    font-size: var(--text-sm);
}

.saved-card__info {
    color: var(--text-tertiary);
    font-size: var(--text-xs);
    margin-top: 2px;
}

.saved-card__expiry {
    margin-left: 8px;
}

.saved-card__expired-badge {
    color: var(--red);
    font-weight: 500;
    margin-left: 4px;
}

/* New Card Option */
.new-card-option {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--surface-3);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
}

.new-card-option:hover {
    background: var(--surface-4);
    border-color: var(--blue);
}

.new-card-option:has(.new-card-option__radio:checked) {
    background: var(--blue-subtle);
    border-color: var(--blue);
}

.new-card-option__text {
    color: var(--text-primary);
    font-weight: 500;
}

/* Fix iCheck wrapper in new-card-option - center vertically */
.new-card-option .iradio_square-blue,
.new-card-option .icheckbox_square-blue {
    flex-shrink: 0;
    margin-right: 12px;
    align-self: center;
}

/* Hide new card form when existing card selected */
#order-standard_cart .saved-cards:has(.existing-card:checked) ~ #newCardInfo,
#order-standard_cart .saved-cards:has(.existing-card:checked) ~ #stripeElements,
#order-standard_cart #existingCardsContainer:has(.existing-card:checked) ~ #newCardInfo,
#order-standard_cart #existingCardsContainer:has(.existing-card:checked) ~ #stripeElements {
    display: none !important;
}


/* TOS checkbox spacing */
#order-standard_cart #accepttos,
#order-standard_cart [name="accepttos"] {
    margin-top: 32px !important;
}

#order-standard_cart .checkbox-inline:has(#accepttos),
#order-standard_cart label:has([name="accepttos"]) {
    margin-top: 32px !important;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Card Inputs Container */
.card-inputs {
    padding: 20px 0;
    border-top: 1px solid var(--border-color);
    margin-top: 20px;
}

/* ============================================
   BILLING ADDRESS
   ============================================ */

.billing-address-options {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.billing-option {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--surface-3);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
}

.billing-option:hover {
    background: var(--surface-4);
    border-color: var(--blue);
}

.billing-option:has(.billing-option__radio:checked) {
    background: var(--blue-subtle);
    border-color: var(--blue);
}

.billing-option__radio {
    flex-shrink: 0;
}

/* Center iCheck wrappers in billing options */
.billing-option .iradio_square-blue,
.billing-option .icheckbox_square-blue {
    flex-shrink: 0;
    align-self: center;
}

.billing-option__content {
    flex: 1;
}

.billing-option__name {
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.billing-option__address {
    color: var(--text-tertiary);
    font-size: var(--text-sm);
    line-height: 1.4;
}

.billing-option--new .billing-option__name {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 0;
}

.billing-option--new .billing-option__name i {
    color: var(--blue);
}

/* New Billing Address Form */
.new-billing-form {
    padding: 20px 0;
    border-top: 1px solid var(--border-color);
    margin-top: 20px;
}

/* Store Card Toggle */
.store-card-option {
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
}

.store-card-toggle {
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
}

.store-card-toggle__label {
    color: var(--text-secondary);
    font-size: var(--text-sm);
}

/* ============================================
   INVOICE SUMMARY CARD
   ============================================ */

.invoice-summary-card {
    background: var(--surface-2);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    overflow: hidden;
    position: sticky;
    top: 24px;
}

.invoice-summary-card__header {
    padding: 20px 24px;
    border-bottom: 1px solid var(--border-color);
    background: rgba(0, 0, 0, 0.15);
    text-align: center;
}

.invoice-summary-card__title {
    margin: 0;
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--text-primary);
}

.invoice-summary-card__body {
    padding: 20px 24px;
}

/* Invoice Items */
.invoice-items {
    margin-bottom: 16px;
}

.invoice-items__header {
    display: flex;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-tertiary);
    font-size: var(--text-xs);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.invoice-items__row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 12px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    gap: 16px;
}

.invoice-items__desc {
    color: var(--text-secondary);
    font-size: var(--text-sm);
    flex: 1;
    line-height: 1.4;
}

.invoice-items__amount {
    color: var(--text-primary);
    font-size: var(--text-sm);
    font-weight: 500;
    white-space: nowrap;
}

/* Invoice Totals */
.invoice-totals {
    background: var(--surface-3);
    border-radius: var(--radius-md);
    padding: 12px 16px;
}

.invoice-totals__row {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    color: var(--text-secondary);
    font-size: var(--text-sm);
}

.invoice-totals__row--total {
    border-top: 1px solid var(--border-color);
    margin-top: 8px;
    padding-top: 12px;
    color: var(--text-primary);
    font-weight: 600;
}

/* Invoice Summary Footer */
.invoice-summary-card__footer {
    padding: 16px 24px;
    border-top: 1px solid var(--border-color);
    background: rgba(0, 0, 0, 0.1);
}

.payments-to-date {
    text-align: center;
    color: var(--text-secondary);
    font-size: var(--text-sm);
    margin-bottom: 12px;
}

.payments-to-date strong {
    color: var(--text-primary);
}

.balance-due {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 18px;
    background: linear-gradient(135deg, var(--green) 0%, #5ad92a 100%);
    border-radius: var(--radius-md);
    color: #000;
    font-weight: 600;
}

.balance-due__label {
    font-size: var(--text-sm);
}

.balance-due__amount {
    font-size: var(--text-lg);
}

/* SSL Notice */
.ssl-notice {
    margin-top: 20px;
    padding: 14px 18px;
    background: var(--gold-subtle);
    border: 1px solid var(--gold);
    border-radius: var(--radius-md);
    color: var(--gold);
    font-size: var(--text-sm);
    display: flex;
    align-items: center;
    gap: 10px;
}

/* 3D Secure iframe */
.auth3d-area {
    background: var(--surface-2);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    margin-top: 20px;
}

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

    background: #1a1c23 !important;
    border-radius: 4px !important;
    padding: 10px 12px !important;
}

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

/* Also handle regular autofill for other browsers */
input:-moz-autofill,
input:-moz-autofill-preview {
    background: var(--light-bg) !important;
    color: #fff !important;
}

/* ================================================
   FIX CHROME AUTOFILL STYLING
   ================================================ */

/* Override Chrome's autofill white background */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px #1b1c24 inset !important;
    -webkit-text-fill-color: #fff !important;
    border-radius: 8px !important;
    transition: background-color 5000s ease-in-out 0s !important;
}

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

/* Unpaid - Red */
.label-unpaid,
.status-unpaid {
    background: rgba(239, 68, 68, 0.15) !important;
    color: #ef4444 !important;
}

/* Paid - Green */
.label-paid {
    background: rgba(34, 197, 94, 0.15) !important;
    color: #22c55e !important;
}

/* Refunded - Blue */
.label-refunded {
    background: rgba(59, 130, 246, 0.15) !important;
    color: #3b82f6 !important;
}

/* Cancelled - Gray */
.label-cancelled {
    background: rgba(107, 114, 128, 0.15) !important;
    color: #9ca3af !important;
}

/* Draft - Yellow */
.label-draft {
    background: rgba(234, 179, 8, 0.15) !important;
    color: #eab308 !important;
}

/* Collections - Orange */
.label-collections {
    background: rgba(249, 115, 22, 0.15) !important;
    color: #f97316 !important;
}

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

/* Base styling for status labels */
.label.status {
    display: inline-block !important;
    padding: 4px 12px !important;
    border-radius: 4px !important;
    font-weight: 600 !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

/* Unpaid - Red */
.status-unpaid {
    background: rgba(239, 68, 68, 0.15) !important;
}

.status-unpaid .textred {
    color: #ef4444 !important;
}

/* Paid - Green */
.status-paid {
    background: rgba(34, 197, 94, 0.15) !important;
}

.status-paid span {
    color: #22c55e !important;
}

/* Refunded - Blue */
.status-refunded {
    background: rgba(59, 130, 246, 0.15) !important;
}

.status-refunded .textblack,
.status-refunded span {
    color: #3b82f6 !important;
}

/* Cancelled - Gray */
.status-cancelled {
    background: rgba(107, 114, 128, 0.15) !important;
}

.status-cancelled span {
    color: #9ca3af !important;
}

/* Draft - Yellow */
.status-draft {
    background: rgba(234, 179, 8, 0.15) !important;
}

.status-draft span {
    color: #eab308 !important;
}

/* Collections - Orange */
.status-collections {
    background: rgba(249, 115, 22, 0.15) !important;
}

.status-collections span {
    color: #f97316 !important;
}

/* Service/Product Status Badges */
.status-active {
    background: rgba(34, 197, 94, 0.15) !important;
    color: #22c55e !important;
}

.status-terminated,
.status-cancelled {
    background: rgba(107, 114, 128, 0.15) !important;
    color: #9ca3af !important;
}

.status-suspended {
    background: rgba(239, 68, 68, 0.15) !important;
    color: #ef4444 !important;
}

.status-pending {
    background: rgba(234, 179, 8, 0.15) !important;
    color: #eab308 !important;
}

.status-fraud {
    background: rgba(220, 38, 38, 0.15) !important;
    color: #dc2626 !important;
}

.status-completed {
    background: rgba(34, 197, 94, 0.15) !important;
    color: #22c55e !important;
}


/* Allow phone number dropdown to escape containers */
.card:has(.intl-tel-input),
.card:has(.iti),
.panel:has(.intl-tel-input),
.panel:has(.iti),
.card-body:has(.intl-tel-input),
.card-body:has(.iti) {
    overflow: visible !important;
}

/* Ensure country list appears above other elements */
.iti__country-list,
.intl-tel-input .country-list {
    z-index: 9999 !important;
    position: absolute !important;
}
