/* =============================================================================
   CLOUDLY WHMCS THEME — Custom Stylesheet
   Design System: Vision UI Glassmorphism Edition v1.0
   Portal: portal.cloudly.com.au
   Last Updated: 2026-03
   
   OVERVIEW:
   This file overrides the default WHMCS Twenty-One theme styles to match the
   Cloudly brand identity — deep-space dark background, glassmorphism surfaces,
   blue-to-purple brand gradient, Inter typeface.
   
   HOW IT WORKS:
   WHMCS auto-loads this file (css/custom.css) via the {assetExists} directive
   in includes/head.tpl. It is loaded AFTER theme.min.css so all declarations
   here take precedence.
   
   SECTIONS:
   1.  CSS Custom Properties (Design Tokens)
   2.  Base Reset & Typography
   3.  Background & Ambient Orbs
   4.  Header & Navbar
   5.  Topbar (logged-in bar)
   6.  Navigation Links
   7.  Sidebar
   8.  Breadcrumb
   9.  Cards & Panels
   10. Home Tiles
   11. Buttons
   12. Forms & Inputs
   13. Tables
   14. Badges & Alerts
   15. Login Page
   16. Footer
   17. Modal Dialogs
   18. Scrollbar
   19. Animations & Keyframes
   20. Responsive Overrides
============================================================================= */

/* =============================================================================
   1. CSS CUSTOM PROPERTIES (DESIGN TOKENS)
============================================================================= */

/* NOTE: Inter font is loaded via <link> in includes/head.tpl — no @import needed here.
   Removing the @import ensures this CSS file is parsed immediately without waiting
   for the font download, which fixes specificity/timing issues with store.css. */

:root {
    /* Brand */
    --cl-brand:          #3b82f6;
    --cl-brand-dark:     #2563eb;
    --cl-purple:         #8b5cf6;
    --cl-teal:           #14b8a6;
    --cl-orange:         #f97316;

    /* Gradient */
    --cl-gradient:       linear-gradient(135deg, #3b82f6, #8b5cf6);
    --cl-gradient-text:  linear-gradient(135deg, #3b82f6, #8b5cf6);

    /* Semantic */
    --cl-success:        #22c55e;
    --cl-warning:        #f59e0b;
    --cl-error:          #ef4444;

    /* Background */
    --cl-body-bg:        #060b1a;
    --cl-surface:        rgba(255, 255, 255, 0.06);
    --cl-surface-border: rgba(255, 255, 255, 0.12);
    --cl-surface-hover:  rgba(255, 255, 255, 0.09);

    /* Text */
    --cl-text-primary:   #f1f5f9;
    --cl-text-secondary: #94a3b8;
    --cl-text-muted:     #64748b;

    /* Input */
    --cl-input-bg:       rgba(15, 23, 42, 0.6);
    --cl-input-border:   rgba(255, 255, 255, 0.12);

    /* Glow */
    --cl-glow-blue:      rgba(59, 130, 246, 0.30);
    --cl-glow-green:     rgba(34, 197, 94,  0.30);
    --cl-glow-red:       rgba(239, 68, 68,  0.30);
    --cl-glow-purple:    rgba(168, 85, 247, 0.25);
    --cl-glow-teal:      rgba(20, 184, 166, 0.30);
    --cl-glow-orange:    rgba(249, 115, 22, 0.30);

    /* Shape */
    --cl-radius-card:    20px;
    --cl-radius-btn:     12px;
    --cl-radius-badge:    8px;
    --cl-radius-input:   12px;

    /* Glass */
    --cl-blur:           24px;
    --cl-saturate:       180%;

    /* Typography */
    --cl-font: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Display',
               Helvetica, Arial, sans-serif;
}

/* =============================================================================
   2. BASE RESET & TYPOGRAPHY
============================================================================= */

html {
    font-size: 14px;
    scroll-behavior: smooth;
}

body {
    font-family:             var(--cl-font) !important;
    background-color:        var(--cl-body-bg) !important;
    color:                   var(--cl-text-primary) !important;
    -webkit-font-smoothing:  antialiased;
    -moz-osx-font-smoothing: grayscale;
    position:                relative;
    overflow-x:              hidden;
}

/* Body background gradient — matches the website deep-space look */
body::before {
    content:    '';
    position:   fixed;
    inset:      0;
    background: linear-gradient(145deg, #060b1a 0%, #0f1629 40%, #0a1231 100%);
    z-index:    -2;
    pointer-events: none;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--cl-font) !important;
    color:       var(--cl-text-primary) !important;
    font-weight: 700;
}

p, li, span, label, small, td, th {
    font-family: var(--cl-font) !important;
    color:       var(--cl-text-secondary);
}

a {
    color:       var(--cl-brand) !important;
    transition:  color 0.15s ease;
}

a:hover {
    color:           var(--cl-brand-dark) !important;
    text-decoration: none !important;
}

/* Custom scrollbar — matches the website */
::-webkit-scrollbar       { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background:    rgba(255, 255, 255, 0.15);
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.25);
}

/* Text selection */
::selection       { background: rgba(59, 130, 246, 0.3); color: #f1f5f9; }
::-moz-selection  { background: rgba(59, 130, 246, 0.3); color: #f1f5f9; }

/* Focus ring */
:focus-visible {
    outline:        2px solid var(--cl-brand);
    outline-offset: 2px;
    border-radius:  4px;
}
:focus:not(:focus-visible) { outline: none; }

/* =============================================================================
   3. BACKGROUND AMBIENT ORBS
   Floating blurred colour orbs replicating the cloudly.com.au aesthetic.
   Injected via a fixed container so all pages share the orb layer.
============================================================================= */

/* The orb container is inserted by header.tpl via a custom snippet.
   These declarations support it: */
.cl-orbs {
    position:       fixed;
    inset:          0;
    z-index:        -1;
    pointer-events: none;
    overflow:       hidden;
}

.cl-orb {
    position:      absolute;
    border-radius: 50%;
    filter:        blur(80px);
    opacity:       0.12;
}

.cl-orb-1 {
    width:      500px; height: 500px;
    background: #3b82f6;
    top:        -150px; left: -100px;
    animation:  clFloatOrb 25s ease-in-out infinite;
}

.cl-orb-2 {
    width:      400px; height: 400px;
    background: #a855f7;
    top:        40%; right: -80px;
    animation:  clFloatOrb 30s ease-in-out infinite reverse;
}

.cl-orb-3 {
    width:      350px; height: 350px;
    background: #14b8a6;
    bottom:     -100px; left: 30%;
    animation:  clFloatOrb 22s ease-in-out infinite 5s;
}

.cl-orb-4 {
    width:      300px; height: 300px;
    background: #f97316;
    top:        60%; left: 60%;
    animation:  clFloatOrb 28s ease-in-out infinite 3s;
}

/* =============================================================================
   4. HEADER & NAVBAR
============================================================================= */

#header,
.header {
    background:    rgba(6, 11, 26, 0.85) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    box-shadow:    none !important;
    position:      sticky;
    top:           0;
    z-index:       1000;
}

/* Brand / Logo area */
.navbar-brand,
.navbar-brand:hover {
    color:       var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-size:   1.35rem !important;
    font-weight: 800 !important;
    background:  var(--cl-gradient) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip:         text !important;
    letter-spacing: -0.02em;
}

.navbar-brand img.logo-img {
    /* Logo image – preserve dimensions but ensure it doesn't get clipped */
    max-height:              40px;
    -webkit-text-fill-color: initial !important;
    filter:                  brightness(1.1);
}

/* Top (branded) navbar */
.navbar.navbar-light {
    background: transparent !important;
    padding:    0.6rem 0 !important;
}

/* Main nav wrapper */
.navbar.main-navbar-wrapper {
    background:    rgba(6, 11, 26, 0.6) !important;
    border-top:    1px solid var(--cl-surface-border) !important;
    border-bottom: none !important;
    padding:       0 !important;
}

/* =============================================================================
   5. TOPBAR (logged-in account bar)
============================================================================= */

.topbar {
    background:    rgba(15, 23, 42, 0.7) !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    font-size:     0.8rem;
}

.topbar .btn,
.topbar .input-group-text {
    background:  transparent !important;
    color:       var(--cl-text-secondary) !important;
    border:      none !important;
    font-family: var(--cl-font) !important;
}

.topbar .btn-active-client {
    color:       var(--cl-text-primary) !important;
    font-weight: 600;
}

.topbar .btn:hover {
    color: var(--cl-brand) !important;
}

/* =============================================================================
   6. NAVIGATION LINKS
============================================================================= */

#nav .nav-link,
.navbar-nav .nav-link {
    font-family: var(--cl-font) !important;
    font-size:   0.875rem !important;
    font-weight: 500 !important;
    color:       var(--cl-text-secondary) !important;
    padding:     0.75rem 1rem !important;
    transition:  color 0.15s ease !important;
    border-bottom: 2px solid transparent;
}

#nav .nav-link:hover,
.navbar-nav .nav-link:hover {
    color:        var(--cl-text-primary) !important;
    border-color: var(--cl-brand);
}

#nav .nav-link.active,
.navbar-nav .nav-link.active {
    color:        var(--cl-brand) !important;
    font-weight:  600 !important;
    border-color: var(--cl-brand);
}

/* Dropdown menus */
.dropdown-menu {
    background:    rgba(15, 23, 42, 0.95) !important;
    backdrop-filter: blur(20px) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-radius: var(--cl-radius-card) !important;
    box-shadow:    0 12px 32px rgba(0, 0, 0, 0.4) !important;
    padding:       8px !important;
    margin-top:    4px !important;
}

.dropdown-item {
    font-family:   var(--cl-font) !important;
    color:         var(--cl-text-secondary) !important;
    border-radius: 10px !important;
    padding:       8px 12px !important;
    font-size:     0.875rem !important;
    transition:    all 0.15s ease !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background: var(--cl-surface-hover) !important;
    color:      var(--cl-text-primary) !important;
}

.dropdown-divider {
    border-color: var(--cl-surface-border) !important;
    margin:       4px 0 !important;
}

/* Search input in navbar */
.navbar .form-inline .form-control,
.navbar .input-group .form-control {
    background:    var(--cl-input-bg) !important;
    border:        1px solid var(--cl-input-border) !important;
    border-radius: var(--cl-radius-input) !important;
    color:         var(--cl-text-primary) !important;
    font-family:   var(--cl-font) !important;
}

.navbar .input-group-text,
.navbar .input-group-prepend .btn {
    background: var(--cl-input-bg) !important;
    border:     1px solid var(--cl-input-border) !important;
    color:      var(--cl-text-muted) !important;
}

/* Cart button */
.cart-btn {
    color:      var(--cl-text-secondary) !important;
    transition: color 0.15s ease !important;
}
.cart-btn:hover { color: var(--cl-brand) !important; }

.badge-info {
    background:    var(--cl-brand) !important;
    border-radius: 99px !important;
    font-size:     0.65rem !important;
    font-weight:   700 !important;
    padding:       2px 6px !important;
}

/* =============================================================================
   7. SIDEBAR
============================================================================= */

.sidebar {
    background:    var(--cl-surface) !important;
    backdrop-filter: blur(var(--cl-blur)) !important;
    -webkit-backdrop-filter: blur(var(--cl-blur)) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-radius: var(--cl-radius-card) !important;
    overflow:      hidden;
    margin-bottom: 24px;
    position:      relative;
}

/* Subtle top-edge light — glassmorphism signature */
.sidebar::before {
    content:    '';
    position:   absolute;
    top:        0; left: 0; right: 0;
    height:     1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
    pointer-events: none;
}

.sidebar .list-group-item,
.sidebar .list-group-item-action {
    background:    transparent !important;
    border-color:  var(--cl-surface-border) !important;
    color:         var(--cl-text-secondary) !important;
    font-family:   var(--cl-font) !important;
    font-size:     0.875rem !important;
    font-weight:   500 !important;
    transition:    all 0.15s ease !important;
    border-left:   none !important;
    border-right:  none !important;
}

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

.sidebar .list-group-item:hover,
.sidebar .list-group-item-action:hover {
    background: var(--cl-surface-hover) !important;
    color:      var(--cl-text-primary) !important;
}

.sidebar .list-group-item.active,
.sidebar .list-group-item-action.active {
    background:    rgba(59, 130, 246, 0.15) !important;
    border-color:  rgba(59, 130, 246, 0.3) !important;
    color:         var(--cl-brand) !important;
    font-weight:   600 !important;
}

.sidebar .sidebar-header,
.sidebar .card-header {
    background:    transparent !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    color:         var(--cl-text-primary) !important;
    font-family:   var(--cl-font) !important;
    font-weight:   700 !important;
    font-size:     0.8125rem !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding:       14px 16px !important;
}

/* =============================================================================
   8. BREADCRUMB
============================================================================= */

.master-breadcrumb,
nav.master-breadcrumb {
    background:    rgba(6, 11, 26, 0.5) !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    padding:       8px 0 !important;
}

.breadcrumb {
    background:    transparent !important;
    margin:        0 !important;
    padding:       0 !important;
}

.breadcrumb-item,
.breadcrumb-item a {
    font-family: var(--cl-font) !important;
    font-size:   0.8125rem !important;
    color:       var(--cl-text-muted) !important;
}

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

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

/* =============================================================================
   9. CARDS & PANELS
============================================================================= */

.card,
.panel,
.card-default {
    background:    var(--cl-surface) !important;
    backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    -webkit-backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-radius: var(--cl-radius-card) !important;
    color:         var(--cl-text-primary) !important;
    position:      relative;
    overflow:      hidden;
    animation:     clFadeInUp 0.5s ease-out both;
    transition:    all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow:    0 4px 24px rgba(0, 0, 0, 0.2);
    margin-bottom: 24px;
}

/* Top-edge glass highlight */
.card::before,
.panel::before {
    content:    '';
    position:   absolute;
    top:        0; left: 0; right: 0;
    height:     1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
    pointer-events: none;
    z-index:    1;
}

.card:hover {
    transform:  translateY(-1px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25) !important;
}

.card-header {
    background:    transparent !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    color:         var(--cl-text-primary) !important;
    font-family:   var(--cl-font) !important;
    font-weight:   700 !important;
    padding:       16px 24px !important;
}

.card-body {
    padding:    24px !important;
    color:      var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

.card-footer {
    background:  transparent !important;
    border-top:  1px solid var(--cl-surface-border) !important;
    color:       var(--cl-text-muted) !important;
    font-family: var(--cl-font) !important;
    padding:     12px 24px !important;
    font-size:   0.8125rem !important;
}

.card-title {
    font-family: var(--cl-font) !important;
    font-weight: 700 !important;
    color:       var(--cl-text-primary) !important;
    font-size:   1rem !important;
    margin:      0 !important;
}

/* Accent cards — use brand color border */
.card-accent-blue    { border-color: rgba(59, 130, 246, 0.35) !important; }
.card-accent-green   { border-color: rgba(34, 197, 94, 0.35) !important; }
.card-accent-red     { border-color: rgba(239, 68, 68, 0.35) !important; }
.card-accent-gold,
.card-accent-yellow  { border-color: rgba(245, 158, 11, 0.35) !important; }
.card-accent-purple  { border-color: rgba(168, 85, 247, 0.35) !important; }
.card-accent-teal    { border-color: rgba(20, 184, 166, 0.35) !important; }

/* List groups inside cards */
.list-group-item {
    background:  transparent !important;
    border-color: var(--cl-surface-border) !important;
    color:       var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
    transition:  all 0.15s ease !important;
}

.list-group-item:hover,
.list-group-item-action:hover {
    background: var(--cl-surface-hover) !important;
    color:      var(--cl-text-primary) !important;
}

.list-group-item.active {
    background:   rgba(59, 130, 246, 0.2) !important;
    border-color: rgba(59, 130, 246, 0.4) !important;
    color:        var(--cl-brand) !important;
}

/* =============================================================================
   10. HOME TILES
============================================================================= */

.tiles {
    margin-bottom: 24px !important;
}

.tile {
    display:         flex !important;
    flex-direction:  column !important;
    align-items:     center !important;
    justify-content: center !important;
    padding:         28px 16px !important;
    background:      var(--cl-surface) !important;
    backdrop-filter: blur(var(--cl-blur)) !important;
    -webkit-backdrop-filter: blur(var(--cl-blur)) !important;
    border:          1px solid var(--cl-surface-border) !important;
    border-radius:   var(--cl-radius-card) !important;
    color:           var(--cl-text-primary) !important;
    text-decoration: none !important;
    position:        relative;
    overflow:        hidden;
    transition:      all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
    text-align:      center;
    margin:          2px;
}

.tile::before {
    content:    '';
    position:   absolute;
    top: 0; left: 0; right: 0;
    height:     1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
}

.tile:hover {
    background:  var(--cl-surface-hover) !important;
    transform:   translateY(-3px) !important;
    box-shadow:  0 12px 32px rgba(0, 0, 0, 0.3) !important;
    border-color: rgba(59, 130, 246, 0.4) !important;
    text-decoration: none !important;
    color:       var(--cl-text-primary) !important;
}

.tile i {
    font-size:   2rem !important;
    margin-bottom: 8px !important;
    background:  var(--cl-gradient);
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

.tile .stat {
    font-size:   2rem !important;
    font-weight: 800 !important;
    color:       var(--cl-text-primary) !important;
    line-height: 1.1 !important;
    font-family: var(--cl-font) !important;
    letter-spacing: -0.02em;
}

.tile .title {
    font-size:   0.75rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color:       var(--cl-text-muted) !important;
    margin-top:  4px !important;
    font-family: var(--cl-font) !important;
}

/* Colour highlight strip at bottom */
.tile .highlight {
    position: absolute;
    bottom:   0; left: 0; right: 0;
    height:   3px;
}

.bg-color-blue   { background: var(--cl-brand) !important; }
.bg-color-green  { background: var(--cl-success) !important; }
.bg-color-red    { background: var(--cl-error) !important; }
.bg-color-gold   { background: var(--cl-warning) !important; }

/* =============================================================================
   11. BUTTONS
============================================================================= */

.btn {
    font-family: var(--cl-font) !important;
    font-weight: 600 !important;
    border-radius: var(--cl-radius-btn) !important;
    transition:  all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
    font-size:   0.875rem !important;
}

.btn-primary,
.btn-primary:visited {
    background:  var(--cl-gradient) !important;
    border:      none !important;
    color:       #fff !important;
    box-shadow:  0 2px 8px rgba(59, 130, 246, 0.3) !important;
}

.btn-primary:hover,
.btn-primary:focus {
    transform:   translateY(-1px) !important;
    box-shadow:  0 6px 20px rgba(59, 130, 246, 0.45) !important;
    color:       #fff !important;
}

.btn-primary:active {
    transform: translateY(0) !important;
}

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

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

.btn-success {
    background:  linear-gradient(135deg, #22c55e, #16a34a) !important;
    border:      none !important;
    color:       #fff !important;
    box-shadow:  0 2px 8px rgba(34, 197, 94, 0.3) !important;
}
.btn-success:hover {
    transform:  translateY(-1px) !important;
    box-shadow: 0 6px 20px rgba(34, 197, 94, 0.45) !important;
    color:      #fff !important;
}

.btn-danger {
    background:  transparent !important;
    border:      1px solid rgba(239, 68, 68, 0.4) !important;
    color:       var(--cl-error) !important;
}
.btn-danger:hover {
    background: rgba(239, 68, 68, 0.1) !important;
    color:      var(--cl-error) !important;
}

.btn-warning {
    background:  linear-gradient(135deg, #f59e0b, #d97706) !important;
    border:      none !important;
    color:       #fff !important;
}

.btn-info {
    background:  linear-gradient(135deg, #06b6d4, #0891b2) !important;
    border:      none !important;
    color:       #fff !important;
}

.btn-link {
    color:       var(--cl-brand) !important;
    background:  transparent !important;
    border:      none !important;
    padding-left: 0 !important;
}
.btn-link:hover { color: var(--cl-brand-dark) !important; }

/* Small / XS button variants */
.btn-xs {
    padding:       4px 10px !important;
    font-size:     0.75rem !important;
    border-radius: 8px !important;
}

.btn-sm {
    padding:       6px 14px !important;
    font-size:     0.8125rem !important;
}

/* btn-reveal-pw in login */
.btn-reveal-pw {
    background:  transparent !important;
    border:      none !important;
    color:       var(--cl-text-muted) !important;
}

/* Return to admin button */
.btn-return-to-admin {
    background:  linear-gradient(135deg, #f59e0b, #d97706) !important;
    color:       #fff !important;
    border-radius: var(--cl-radius-btn) !important;
    font-weight: 700 !important;
}

/* =============================================================================
   12. FORMS & INPUTS
============================================================================= */

.form-control {
    background:    var(--cl-input-bg) !important;
    border:        1px solid var(--cl-input-border) !important;
    border-radius: var(--cl-radius-input) !important;
    color:         var(--cl-text-primary) !important;
    font-family:   var(--cl-font) !important;
    font-size:     0.875rem !important;
    padding:       10px 14px !important;
    backdrop-filter: blur(8px) !important;
    transition:    border-color 0.15s ease, box-shadow 0.15s ease !important;
}

/* Preserve icon spacing for WHMCS prepended-icon inputs on checkout/payment forms.
   The global .form-control padding above removes the native left inset and can
   cause .field-icon glyphs to overlap card/identity field text. */
body #order-standard_cart .prepend-icon .field,
body #order-standard_cart .prepend-icon .form-control,
body #order-cloudly-cart .prepend-icon .field,
body #order-cloudly-cart .prepend-icon .form-control {
    padding-left: 42px !important;
    min-height: 48px !important;
}

body #order-standard_cart .prepend-icon .field-icon,
body #order-cloudly-cart .prepend-icon .field-icon {
    margin-bottom: 0 !important;
    top: 0 !important;
    transform: none !important;
    width: 42px !important;
    height: 48px !important;
    line-height: 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

body #order-standard_cart .prepend-icon .field-icon i,
body #order-cloudly-cart .prepend-icon .field-icon i {
    position: static !important;
}

/* Register page parity with Cloudly form styling + icon-safe spacing */
body #registration .field,
body #registration .form-control,
body #registration select,
body #registration textarea {
    background: var(--cl-input-bg) !important;
    border: 1px solid var(--cl-input-border) !important;
    border-radius: var(--cl-radius-input) !important;
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-size: 0.875rem !important;
    padding: 10px 14px !important;
    backdrop-filter: blur(8px) !important;
    transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
}

body #registration .field::placeholder,
body #registration .form-control::placeholder,
body #registration input::placeholder,
body #registration textarea::placeholder {
    color: var(--cl-text-muted) !important;
}

body #registration .field:focus,
body #registration .form-control:focus,
body #registration input:focus,
body #registration select:focus,
body #registration textarea:focus {
    background: var(--cl-input-bg) !important;
    border-color: var(--cl-brand) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15) !important;
    color: var(--cl-text-primary) !important;
    outline: none !important;
}

body #registration .prepend-icon .field,
body #registration .prepend-icon .form-control,
body #registration .prepend-icon input,
body #registration .prepend-icon textarea,
body #registration .prepend-icon select {
    padding-left: 42px !important;
    min-height: 48px !important;
}

body #registration .prepend-icon .field-icon {
    margin-bottom: 0 !important;
    top: 0 !important;
    transform: none !important;
    width: 42px !important;
    height: 48px !important;
    line-height: 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

body #registration .prepend-icon .field-icon i {
    position: static !important;
    color: var(--cl-text-muted) !important;
}

/* Register page logo lockup — mirrors homepage/login branding */
body .cl-register-logo {
    text-align: center;
    margin: 4px 0 28px;
    animation: clFadeInUp 0.5s ease-out both;
}

body .cl-register-logo img {
    height: 44px;
    width: auto;
    filter: brightness(1.1);
    margin-bottom: 14px;
}

body .cl-register-logo-divider {
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, #3b82f6, #8b5cf6);
    border-radius: 1px;
    margin: 0 auto 14px;
}

body .cl-register-logo-sub {
    font-family: var(--cl-font) !important;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    background: linear-gradient(135deg, #c4b5fd, #a855f7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-shadow: none;
}

@media (max-width: 575px) {
    body .cl-register-logo {
        margin-bottom: 22px;
    }

    body .cl-register-logo img {
        height: 38px;
    }
}

body #registration input:-webkit-autofill,
body #registration input:-webkit-autofill:hover,
body #registration input:-webkit-autofill:focus,
body #registration textarea:-webkit-autofill,
body #registration textarea:-webkit-autofill:hover,
body #registration textarea:-webkit-autofill:focus,
body #registration select:-webkit-autofill,
body #registration select:-webkit-autofill:hover,
body #registration select:-webkit-autofill:focus {
    -webkit-text-fill-color: var(--cl-text-primary) !important;
    box-shadow: 0 0 0 1000px rgba(15, 23, 42, 0.92) inset !important;
    transition: background-color 9999s ease-in-out 0s;
}

.form-control:focus {
    background:  var(--cl-input-bg) !important;
    border-color: var(--cl-brand) !important;
    box-shadow:  0 0 0 3px rgba(59, 130, 246, 0.15) !important;
    color:       var(--cl-text-primary) !important;
    outline:     none !important;
}

.form-control::placeholder {
    color: var(--cl-text-muted) !important;
}

/* Labels */
.form-control-label,
label,
.col-form-label {
    font-family:    var(--cl-font) !important;
    font-size:      0.75rem !important;
    font-weight:    700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    color:          var(--cl-text-secondary) !important;
    margin-bottom:  6px !important;
}

/* Input groups */
.input-group-text {
    background:  var(--cl-input-bg) !important;
    border:      1px solid var(--cl-input-border) !important;
    color:       var(--cl-text-muted) !important;
    font-family: var(--cl-font) !important;
}

.input-group-prepend .input-group-text,
.input-group-prepend .btn {
    border-right:  none !important;
    border-radius: var(--cl-radius-input) 0 0 var(--cl-radius-input) !important;
}

.input-group-append .input-group-text,
.input-group-append .btn {
    border-left:   none !important;
    border-radius: 0 var(--cl-radius-input) var(--cl-radius-input) 0 !important;
}

.input-group .form-control:not(:first-child) {
    border-radius: 0 var(--cl-radius-input) var(--cl-radius-input) 0 !important;
}

.input-group .form-control:not(:last-child) {
    border-radius: var(--cl-radius-input) 0 0 var(--cl-radius-input) !important;
}

/* Select */
select.form-control {
    appearance: none;
    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='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    padding-right: 36px !important;
}

select.form-control option {
    background: #0f1629 !important;
    color:      var(--cl-text-primary) !important;
}

/* Checkbox / Radio */
.form-check-input {
    accent-color: var(--cl-brand) !important;
    cursor: pointer;
}

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

/* =============================================================================
   13. TABLES
============================================================================= */

.table {
    color: var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

.table thead th,
.table > thead > tr > th {
    background:     rgba(255, 255, 255, 0.04) !important;
    border-bottom:  1px solid var(--cl-surface-border) !important;
    border-top:     none !important;
    color:          var(--cl-text-muted) !important;
    font-family:    var(--cl-font) !important;
    font-size:      0.6875rem !important;
    font-weight:    700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    padding:        12px 16px !important;
}

.table tbody td,
.table > tbody > tr > td {
    border-bottom: 1px solid rgba(255,255,255,0.05) !important;
    border-top:    none !important;
    color:         var(--cl-text-secondary) !important;
    font-family:   var(--cl-font) !important;
    font-size:     0.875rem !important;
    padding:       14px 16px !important;
    vertical-align: middle !important;
}

.table tbody tr:hover,
.table > tbody > tr:hover {
    background: rgba(255,255,255,0.03) !important;
}

.table-bordered,
.table-bordered td,
.table-bordered th {
    border-color: var(--cl-surface-border) !important;
}

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

/* Responsive table wrapper */
.table-responsive {
    border-radius: var(--cl-radius-card) !important;
    border:        1px solid var(--cl-surface-border) !important;
    overflow:      hidden;
}

/* =============================================================================
   14. BADGES & ALERTS
============================================================================= */

/* Base badge style */
.badge {
    font-family:    var(--cl-font) !important;
    font-size:      0.6875rem !important;
    font-weight:    700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    border-radius:  var(--cl-radius-badge) !important;
    padding:        3px 10px !important;
}

/* Status badges */
.badge-success { background: rgba(34, 197, 94, 0.15) !important;  color: var(--cl-success) !important; }
.badge-danger  { background: rgba(239, 68, 68, 0.15) !important;  color: var(--cl-error) !important; }
.badge-warning { background: rgba(245, 158, 11, 0.15) !important; color: var(--cl-warning) !important; }
.badge-info    { background: rgba(59, 130, 246, 0.15) !important; color: var(--cl-brand) !important; }
.badge-primary { background: rgba(59, 130, 246, 0.15) !important; color: var(--cl-brand) !important; }
.badge-secondary {
    background: rgba(148, 163, 184, 0.12) !important;
    color:      var(--cl-text-secondary) !important;
}

/* Alerts */
.alert {
    font-family:   var(--cl-font) !important;
    border-radius: var(--cl-radius-card) !important;
    border:        1px solid transparent !important;
    padding:       14px 18px !important;
    font-size:     0.875rem !important;
}

.alert-success {
    background:   rgba(34, 197, 94, 0.12) !important;
    border-color: rgba(34, 197, 94, 0.3) !important;
    color:        var(--cl-success) !important;
}

.alert-danger {
    background:   rgba(239, 68, 68, 0.12) !important;
    border-color: rgba(239, 68, 68, 0.3) !important;
    color:        var(--cl-error) !important;
}

.alert-warning {
    background:   rgba(245, 158, 11, 0.12) !important;
    border-color: rgba(245, 158, 11, 0.3) !important;
    color:        var(--cl-warning) !important;
}

.alert-info {
    background:   rgba(59, 130, 246, 0.12) !important;
    border-color: rgba(59, 130, 246, 0.3) !important;
    color:        var(--cl-brand) !important;
}

/* Flash messages */
.flash-message,
.alertmessage {
    font-family:   var(--cl-font) !important;
    border-radius: var(--cl-radius-card) !important;
}

/* =============================================================================
   15. LOGIN PAGE
============================================================================= */

/* The login page wrapping (.mw-540) */
.mw-540 {
    max-width: 520px !important;
    margin:    0 auto !important;
}

/* Login card — full glassmorphism treatment */
.login-form .card {
    background:      rgba(255, 255, 255, 0.06) !important;
    backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    -webkit-backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    border:          1px solid var(--cl-surface-border) !important;
    border-radius:   var(--cl-radius-card) !important;
    box-shadow:      0 24px 48px rgba(0, 0, 0, 0.4) !important;
    animation:       clFadeInUp 0.7s ease-out both !important;
}

/* Top-edge luminance on login card */
.login-form .card::before {
    content:    '';
    position:   absolute;
    top: 0; left: 0; right: 0;
    height:     1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
    z-index:    1;
}

/* Login heading */
.login-form .h3,
.login-form h3 {
    font-family:    var(--cl-font) !important;
    font-size:      1.5rem !important;
    font-weight:    700 !important;
    background:     var(--cl-gradient) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    letter-spacing: -0.02em !important;
    margin-bottom:  4px !important;
}

.login-form .text-muted {
    color:   var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

/* Forgot password link */
.login-form .small.text-muted {
    color:       var(--cl-text-muted) !important;
    font-size:   0.8125rem !important;
    transition:  color 0.15s ease;
}

.login-form .small.text-muted:hover {
    color: var(--cl-brand) !important;
}

/* Card padding for login */
.login-form .px-sm-5 { padding-left: 2rem !important; padding-right: 2rem !important; }

/* Login submit button */
#login.btn-primary {
    padding:     12px 28px !important;
    font-size:   0.9375rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.01em;
}

/* Remember me */
.login-form .form-check-input { accent-color: var(--cl-brand) !important; }
.login-form label { color: var(--cl-text-muted) !important; }

/* =============================================================================
   16. FOOTER
============================================================================= */

#footer,
.footer {
    background:  rgba(6, 11, 26, 0.85) !important;
    backdrop-filter: blur(20px) !important;
    border-top:  1px solid var(--cl-surface-border) !important;
    color:       var(--cl-text-muted) !important;
    font-family: var(--cl-font) !important;
    padding:     32px 0 !important;
    margin-top:  48px;
}

.footer .nav-link {
    color:       var(--cl-text-muted) !important;
    font-size:   0.875rem !important;
    padding:     4px 12px !important;
    transition:  color 0.15s ease !important;
}

.footer .nav-link:hover {
    color: var(--cl-brand) !important;
}

.footer .copyright {
    font-size: 0.8125rem !important;
    color:     var(--cl-text-muted) !important;
}

.footer .list-inline-item .btn {
    color:   var(--cl-text-secondary) !important;
    padding: 4px 12px !important;
}

.footer .list-inline-item .btn:hover {
    color: var(--cl-brand) !important;
}

/* =============================================================================
   17. MODAL DIALOGS
============================================================================= */

.modal-backdrop,
.modal-backdrop.in {
    background: rgba(0, 0, 0, 0.65) !important;
    backdrop-filter: blur(8px) !important;
}

.modal-content {
    background:      rgba(15, 23, 42, 0.95) !important;
    backdrop-filter: blur(var(--cl-blur)) !important;
    -webkit-backdrop-filter: blur(var(--cl-blur)) !important;
    border:          1px solid var(--cl-surface-border) !important;
    border-radius:   var(--cl-radius-card) !important;
    box-shadow:      0 24px 48px rgba(0, 0, 0, 0.5) !important;
    color:           var(--cl-text-primary) !important;
    font-family:     var(--cl-font) !important;
    overflow:        hidden;
}

.modal-header {
    background:    transparent !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    padding:       20px 24px !important;
}

.modal-title {
    font-family: var(--cl-font) !important;
    font-weight: 700 !important;
    color:       var(--cl-text-primary) !important;
}

.modal-body {
    padding: 24px !important;
    color:   var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

.modal-footer {
    background:  transparent !important;
    border-top:  1px solid var(--cl-surface-border) !important;
    padding:     16px 24px !important;
}

.close,
.modal .close {
    color:      var(--cl-text-secondary) !important;
    opacity:    0.7 !important;
    text-shadow: none !important;
    font-size:  1.5rem !important;
    transition: all 0.15s ease !important;
}

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

/* Language / currency modal */
.modal-localisation .modal-content {
    background: rgba(6, 11, 26, 0.95) !important;
}

.modal-localisation .item {
    background:    var(--cl-surface) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-radius: 10px !important;
    color:         var(--cl-text-secondary) !important;
    font-family:   var(--cl-font) !important;
    padding:       10px !important;
    text-align:    center;
    display:       block;
    transition:    all 0.15s ease !important;
    text-decoration: none !important;
    margin-bottom: 8px;
}

.modal-localisation .item:hover,
.modal-localisation .item.active {
    background:   rgba(59, 130, 246, 0.12) !important;
    border-color: rgba(59, 130, 246, 0.35) !important;
    color:        var(--cl-brand) !important;
}

/* =============================================================================
   18. SCROLLBAR (already set above in base, this ensures theme overrides)
============================================================================= */

* {
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.15) transparent;
}

/* =============================================================================
   19. ANIMATIONS & KEYFRAMES
============================================================================= */

@keyframes clFadeInUp {
    from {
        opacity:   0;
        transform: translateY(24px);
    }
    to {
        opacity:   1;
        transform: translateY(0);
    }
}

@keyframes clSlideDown {
    from {
        opacity:   0;
        transform: translateY(-20px);
    }
    to {
        opacity:   1;
        transform: translateY(0);
    }
}

@keyframes clFloatOrb {
    0%   { transform: translate(0, 0) scale(1); }
    33%  { transform: translate(40px, -30px) scale(1.05); }
    66%  { transform: translate(-20px, 20px) scale(0.95); }
    100% { transform: translate(0, 0) scale(1); }
}

@keyframes clPulseGlow {
    0%, 100% { box-shadow: 0 0 12px var(--cl-glow-blue); }
    50%       { box-shadow: 0 0 24px var(--cl-glow-blue); }
}

/* Staggered card animation */
.card:nth-child(1)  { animation-delay: 0.05s; }
.card:nth-child(2)  { animation-delay: 0.10s; }
.card:nth-child(3)  { animation-delay: 0.15s; }
.card:nth-child(4)  { animation-delay: 0.20s; }
.card:nth-child(5)  { animation-delay: 0.25s; }

.tile:nth-child(1)  { animation: clFadeInUp 0.5s 0.05s ease-out both; }
.tile:nth-child(2)  { animation: clFadeInUp 0.5s 0.10s ease-out both; }
.tile:nth-child(3)  { animation: clFadeInUp 0.5s 0.15s ease-out both; }
.tile:nth-child(4)  { animation: clFadeInUp 0.5s 0.20s ease-out both; }

/* =============================================================================
   20. RESPONSIVE OVERRIDES
============================================================================= */

@media (max-width: 991px) {
    /* Stack sidebar below content on tablet */
    .sidebar {
        margin-bottom: 16px;
    }

    /* Tiles: 2-column grid */
    .tiles .col-6 {
        width: 50% !important;
    }
}

@media (max-width: 767px) {
    /* Reduce card padding on mobile */
    .card-body    { padding: 16px !important; }
    .card-header  { padding: 14px 16px !important; }
    .card-footer  { padding: 10px 16px !important; }

    /* Full-width tiles on mobile */
    .tiles .col-6 {
        width: 100% !important;
    }

    /* Reduce modal padding */
    .modal-body   { padding: 16px !important; }
    .modal-header { padding: 14px 16px !important; }
    .modal-footer { padding: 12px 16px !important; }

    /* Full-width login card */
    .mw-540 { max-width: 100% !important; }
    .login-form .px-sm-5 {
        padding-left:  1rem !important;
        padding-right: 1rem !important;
    }
}

/* =============================================================================
   MISCELLANEOUS UTILITIES
============================================================================= */

/* Ensure primary bg class (used on body) applies our colour */
.primary-bg-color {
    background-color: var(--cl-body-bg) !important;
}

/* Page section spacing */
#main-body {
    padding:    32px 0 48px;
    min-height: calc(100vh - 200px);
}

/* Network issue notifications */
#network-issues-notifications {
    background:    rgba(245, 158, 11, 0.12) !important;
    border-bottom: 1px solid rgba(245, 158, 11, 0.3) !important;
    color:         var(--cl-warning) !important;
    font-family:   var(--cl-font) !important;
}

/* Pagination */
.pagination .page-item .page-link {
    background:    var(--cl-surface) !important;
    border:        1px solid var(--cl-surface-border) !important;
    color:         var(--cl-text-secondary) !important;
    font-family:   var(--cl-font) !important;
    transition:    all 0.15s ease !important;
}

.pagination .page-item.active .page-link {
    background:  var(--cl-brand) !important;
    border-color: var(--cl-brand) !important;
    color:       #fff !important;
}

.pagination .page-item .page-link:hover {
    background:  var(--cl-surface-hover) !important;
    color:       var(--cl-text-primary) !important;
}

/* Domain/Service status indicators */
.text-success { color: var(--cl-success) !important; }
.text-danger  { color: var(--cl-error) !important; }
.text-warning { color: var(--cl-warning) !important; }
.text-muted   { color: var(--cl-text-muted) !important; }
.text-info    { color: var(--cl-brand) !important; }

/* Horizontal rules */
hr {
    border-color: var(--cl-surface-border) !important;
    margin: 24px 0 !important;
}

/* Well component (used in some WHMCS pages) */
.well {
    background:    var(--cl-surface) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-radius: var(--cl-radius-card) !important;
    box-shadow:    none !important;
    color:         var(--cl-text-secondary) !important;
    font-family:   var(--cl-font) !important;
}

/* Progress bars */
.progress {
    background:    rgba(255,255,255,0.08) !important;
    border-radius: 99px !important;
    height:        8px !important;
}

.progress-bar {
    background: var(--cl-gradient) !important;
    border-radius: 99px !important;
}

/* Tabs (Bootstrap nav-tabs override) */
.nav-tabs {
    border-bottom: 1px solid var(--cl-surface-border) !important;
}

.nav-tabs .nav-link {
    background:    transparent !important;
    border:        1px solid transparent !important;
    border-radius: 10px 10px 0 0 !important;
    color:         var(--cl-text-secondary) !important;
    font-family:   var(--cl-font) !important;
    font-weight:   500 !important;
    transition:    all 0.15s ease !important;
}

.nav-tabs .nav-link:hover {
    border-color: var(--cl-surface-border) var(--cl-surface-border) transparent !important;
    color:        var(--cl-text-primary) !important;
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
    background:   rgba(59, 130, 246, 0.1) !important;
    border-color: rgba(59, 130, 246, 0.3) rgba(59, 130, 246, 0.3) transparent !important;
    color:        var(--cl-brand) !important;
    font-weight:  700 !important;
}

.tab-content { padding-top: 16px !important; }

/* Pills nav (used in WHMCS for quick tabs) */
.nav-pills .nav-link {
    background:    transparent !important;
    border-radius: var(--cl-radius-btn) !important;
    color:         var(--cl-text-secondary) !important;
    font-family:   var(--cl-font) !important;
    font-weight:   500 !important;
    padding:       6px 16px !important;
    transition:    all 0.15s ease !important;
}

.nav-pills .nav-link:hover {
    background: var(--cl-surface-hover) !important;
    color:      var(--cl-text-primary) !important;
}

.nav-pills .nav-link.active {
    background:  var(--cl-brand) !important;
    color:       #fff !important;
    font-weight: 700 !important;
    box-shadow:  0 4px 12px rgba(59, 130, 246, 0.3) !important;
}

/* Code blocks */
code, pre {
    font-family: 'Fira Code', 'Consolas', monospace !important;
}

code {
    background:    rgba(255,255,255,0.06) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-radius: 6px !important;
    color:         var(--cl-brand) !important;
    padding:       2px 6px !important;
    font-size:     0.8125rem !important;
}

pre {
    background:    rgba(15, 23, 42, 0.8) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-radius: var(--cl-radius-card) !important;
    color:         var(--cl-text-secondary) !important;
    padding:       16px !important;
}

/* Promo/announcement blocks */
.promo,
.announce-notice {
    background:    rgba(59, 130, 246, 0.08) !important;
    border:        1px solid rgba(59, 130, 246, 0.25) !important;
    border-radius: var(--cl-radius-card) !important;
    color:         var(--cl-text-secondary) !important;
    padding:       16px 20px !important;
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration:       0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration:      0.01ms !important;
    }

    .cl-orb { animation: none !important; }
}

/* =============================================================================
   25. PORTAL LABEL — Centred "Portal" text in the header navbar
   Uses purple gradient styling for high visibility against the dark nav bar.
============================================================================= */

.cl-portal-label {
    position:        absolute;
    left:            50%;
    top:             50%;
    transform:       translate(-50%, -50%);
    z-index:         10;
    pointer-events:  none;
}

.cl-portal-label-text {
    font-family:      var(--cl-font);
    font-size:        1rem;
    font-weight:      700;
    letter-spacing:   0.18em;
    text-transform:   uppercase;
    /* Purple gradient text — matches the CLIENT PORTAL on the login page */
    background:       linear-gradient(135deg, #c4b5fd, #a855f7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip:  text;
    /* Glass pill container */
    padding:          5px 20px;
    border:           1px solid rgba(139, 92, 246, 0.3);
    border-radius:    10px;
    backdrop-filter:  blur(8px);
    -webkit-backdrop-filter: blur(8px);
    /* Set a bg behind the gradient text so the pill is visible */
    position:         relative;
    user-select:      none;
}

/* Re-add the pill background as a pseudo since background-clip:text removes it */
.cl-portal-label-text::before {
    content:       '';
    position:      absolute;
    inset:         0;
    background:    rgba(139, 92, 246, 0.10);
    border-radius: 10px;
    z-index:       -1;
}

@media (max-width: 767px) {
    .cl-portal-label {
        display: none;       /* Hide on small screens to save space */
    }
}

/* =============================================================================
   21. HOMEPAGE — PRODUCT SHOWCASE
   Replaces the default domain-search white banner with a Cloudly-branded
   product showcase section (Cirrus AI, VoIP, NBN).
============================================================================= */

.cl-showcase {
    padding: 0;
}

.cl-showcase-badge {
    display:        inline-flex;
    align-items:    center;
    gap:            6px;
    background:     rgba(59, 130, 246, 0.12);
    border:         1px solid rgba(59, 130, 246, 0.25);
    border-radius:  8px;
    padding:        4px 14px;
    font-size:      0.75rem;
    font-weight:    700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color:          #3b82f6;
    font-family:    var(--cl-font);
    margin-bottom:  16px;
}

.cl-showcase-badge::before {
    content:      '';
    width:        6px;
    height:       6px;
    border-radius: 50%;
    background:   #3b82f6;
    box-shadow:   0 0 6px rgba(59, 130, 246, 0.6);
}

.cl-showcase-title {
    font-family:    var(--cl-font) !important;
    font-size:      2rem !important;
    font-weight:    800 !important;
    background:     linear-gradient(135deg, #f1f5f9, #94a3b8) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    letter-spacing: -0.02em !important;
    line-height:    1.25 !important;
    margin-bottom:  16px !important;
}

.cl-showcase-subtitle {
    color:       var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
    font-size:   1rem !important;
    margin:      0 !important;
}

/* Showcase card grid — 3 columns */
.cl-showcase-grid {
    display:               grid;
    grid-template-columns: repeat(3, 1fr);
    gap:                   24px;
    margin-top:            32px;
}

/* Individual showcase card */
.cl-showcase-card {
    display:         flex;
    flex-direction:  column;
    background:      var(--cl-surface);
    backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate));
    -webkit-backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate));
    border:          1px solid var(--cl-surface-border);
    border-radius:   var(--cl-radius-card);
    padding:         28px 24px;
    text-decoration: none !important;
    color:           var(--cl-text-primary) !important;
    position:        relative;
    overflow:        hidden;
    transition:      all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    animation:       clFadeInUp 0.6s ease-out both;
}

.cl-showcase-card::before {
    content:    '';
    position:   absolute;
    top: 0; left: 0; right: 0;
    height:     1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
}

.cl-showcase-card:hover {
    transform:  translateY(-4px);
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.3);
    text-decoration: none !important;
    color:      var(--cl-text-primary) !important;
}

/* Blue variant */
.cl-showcase-card-blue {
    border-color: rgba(59, 130, 246, 0.25);
}
.cl-showcase-card-blue:hover {
    border-color: rgba(59, 130, 246, 0.45);
    box-shadow:   0 16px 48px rgba(59, 130, 246, 0.12);
}

/* Purple variant */
.cl-showcase-card-purple {
    border-color: rgba(139, 92, 246, 0.25);
}
.cl-showcase-card-purple:hover {
    border-color: rgba(139, 92, 246, 0.45);
    box-shadow:   0 16px 48px rgba(139, 92, 246, 0.12);
}

/* Teal variant */
.cl-showcase-card-teal {
    border-color: rgba(20, 184, 166, 0.25);
}
.cl-showcase-card-teal:hover {
    border-color: rgba(20, 184, 166, 0.45);
    box-shadow:   0 16px 48px rgba(20, 184, 166, 0.12);
}

/* Card icon */
.cl-showcase-card-icon {
    width:         52px;
    height:        52px;
    border-radius: 14px;
    display:       flex;
    align-items:   center;
    justify-content: center;
    font-size:     1.4rem;
    margin-bottom: 16px;
}

.cl-showcase-card-blue .cl-showcase-card-icon {
    background: linear-gradient(135deg, rgba(59,130,246,0.28), rgba(59,130,246,0.12));
    box-shadow: 0 0 16px rgba(59, 130, 246, 0.2);
    color:      #3b82f6;
}

.cl-showcase-card-purple .cl-showcase-card-icon {
    background: linear-gradient(135deg, rgba(139,92,246,0.28), rgba(139,92,246,0.12));
    box-shadow: 0 0 16px rgba(139, 92, 246, 0.2);
    color:      #8b5cf6;
}

.cl-showcase-card-teal .cl-showcase-card-icon {
    background: linear-gradient(135deg, rgba(20,184,166,0.28), rgba(20,184,166,0.12));
    box-shadow: 0 0 16px rgba(20, 184, 166, 0.2);
    color:      #14b8a6;
}

/* Card badge */
.cl-showcase-card-badge {
    font-size:      0.65rem;
    font-weight:    700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color:          var(--cl-text-muted);
    font-family:    var(--cl-font);
    margin-bottom:  6px;
}

/* Card title */
.cl-showcase-card-title {
    font-family:   var(--cl-font) !important;
    font-size:     1.125rem !important;
    font-weight:   700 !important;
    color:         var(--cl-text-primary) !important;
    margin-bottom: 10px !important;
}

/* Card description */
.cl-showcase-card-desc {
    font-family:  var(--cl-font) !important;
    font-size:    0.875rem !important;
    color:        var(--cl-text-secondary) !important;
    line-height:  1.6 !important;
    flex-grow:    1;
    margin-bottom: 20px !important;
}

/* Card link */
.cl-showcase-card-link {
    font-family:  var(--cl-font);
    font-size:    0.8125rem;
    font-weight:  600;
    color:        var(--cl-brand);
    margin-top:   auto;
    transition:   color 0.15s ease;
}

.cl-showcase-card:hover .cl-showcase-card-link {
    color: var(--cl-brand-dark);
}

/* Stagger animation for showcase cards */
.cl-showcase-card:nth-child(1) { animation-delay: 0.1s; }
.cl-showcase-card:nth-child(2) { animation-delay: 0.2s; }
.cl-showcase-card:nth-child(3) { animation-delay: 0.3s; }

/* Responsive showcase grid */
@media (max-width: 991px) {
    .cl-showcase-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575px) {
    .cl-showcase-grid { grid-template-columns: 1fr; }
    .cl-showcase-title { font-size: 1.5rem !important; }
}

/* =============================================================================
   22. HOMEPAGE — PRODUCT GROUPS (Browse Products)
============================================================================= */

.cl-section-heading {
    font-family:    var(--cl-font) !important;
    font-size:      1.5rem !important;
    font-weight:    700 !important;
    color:          var(--cl-text-primary) !important;
    text-align:     center !important;
    margin:         48px auto 32px !important;
    letter-spacing: -0.01em;
    position:       relative;
}

.cl-section-heading::after {
    content:    '';
    display:    block;
    width:      48px;
    height:     2px;
    background: linear-gradient(90deg, #3b82f6, #8b5cf6);
    margin:     12px auto 0;
    border-radius: 1px;
}

/* Product group cards grid */
.cl-product-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap:                   20px;
    margin-bottom:         48px;
}

.cl-product-card {
    background:      var(--cl-surface);
    backdrop-filter: blur(var(--cl-blur));
    -webkit-backdrop-filter: blur(var(--cl-blur));
    border:          1px solid var(--cl-surface-border);
    border-radius:   var(--cl-radius-card);
    padding:         24px;
    text-align:      center;
    position:        relative;
    overflow:        hidden;
    transition:      all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.cl-product-card::before {
    content:    '';
    position:   absolute;
    top: 0; left: 0; right: 0;
    height:     1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
}

.cl-product-card:hover {
    transform:  translateY(-2px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
}

.cl-product-icon {
    width:         48px;
    height:        48px;
    border-radius: 12px;
    display:       flex;
    align-items:   center;
    justify-content: center;
    margin:        0 auto 16px;
    background:    linear-gradient(135deg, rgba(59,130,246,0.24), rgba(139,92,246,0.12));
    color:         #3b82f6;
    font-size:     1.25rem;
}

.cl-product-title {
    font-family:   var(--cl-font) !important;
    font-size:     1rem !important;
    font-weight:   700 !important;
    color:         var(--cl-text-primary) !important;
    margin-bottom: 8px !important;
}

.cl-product-desc {
    font-family: var(--cl-font) !important;
    font-size:   0.875rem !important;
    color:       var(--cl-text-secondary) !important;
    line-height: 1.5 !important;
}

/* =============================================================================
   23. HOMEPAGE — ACTION ICON BUTTONS ("How can we help" / "Your Account")
   Replaces the default .action-icon-btns white cards with glassmorphism.
============================================================================= */

/* Override any existing action-icon-btns styles */
.action-icon-btns { display: none !important; }

/* New Cloudly action grid */
.cl-action-grid {
    display: grid;
    gap:     20px;
    margin-bottom: 48px;
}

.cl-action-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.cl-action-grid-4 {
    grid-template-columns: repeat(4, 1fr);
}

/* Individual action card */
.cl-action-card {
    display:         flex;
    flex-direction:  column;
    align-items:     center;
    justify-content: center;
    padding:         28px 16px;
    background:      var(--cl-surface);
    backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate));
    -webkit-backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate));
    border:          1px solid var(--cl-surface-border);
    border-radius:   var(--cl-radius-card);
    text-decoration: none !important;
    color:           var(--cl-text-secondary) !important;
    text-align:      center;
    position:        relative;
    overflow:        hidden;
    transition:      all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    animation:       clFadeInUp 0.5s ease-out both;
}

.cl-action-card::before {
    content:    '';
    position:   absolute;
    top: 0; left: 0; right: 0;
    height:     1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
}

.cl-action-card:hover {
    background:      var(--cl-surface-hover);
    transform:       translateY(-3px);
    box-shadow:      0 12px 32px rgba(0, 0, 0, 0.25);
    border-color:    rgba(59, 130, 246, 0.35);
    color:           var(--cl-text-primary) !important;
    text-decoration: none !important;
}

/* Action icon container */
.cl-action-icon {
    width:         52px;
    height:        52px;
    border-radius: 14px;
    display:       flex;
    align-items:   center;
    justify-content: center;
    font-size:     1.25rem;
    margin-bottom: 14px;
    transition:    transform 0.25s ease;
}

.cl-action-card:hover .cl-action-icon {
    transform: scale(1.1);
}

/* Icon colour variants */
.cl-action-icon-blue {
    background: linear-gradient(135deg, rgba(59,130,246,0.28), rgba(59,130,246,0.12));
    box-shadow: 0 0 12px rgba(59, 130, 246, 0.2);
    color:      #3b82f6;
}

.cl-action-icon-purple {
    background: linear-gradient(135deg, rgba(139,92,246,0.28), rgba(139,92,246,0.12));
    box-shadow: 0 0 12px rgba(139, 92, 246, 0.2);
    color:      #8b5cf6;
}

.cl-action-icon-teal {
    background: linear-gradient(135deg, rgba(20,184,166,0.28), rgba(20,184,166,0.12));
    box-shadow: 0 0 12px rgba(20, 184, 166, 0.2);
    color:      #14b8a6;
}

.cl-action-icon-green {
    background: linear-gradient(135deg, rgba(34,197,94,0.28), rgba(34,197,94,0.12));
    box-shadow: 0 0 12px rgba(34, 197, 94, 0.2);
    color:      #22c55e;
}

.cl-action-icon-orange {
    background: linear-gradient(135deg, rgba(249,115,22,0.28), rgba(249,115,22,0.12));
    box-shadow: 0 0 12px rgba(249, 115, 22, 0.2);
    color:      #f97316;
}

/* Action label */
.cl-action-label {
    font-family:  var(--cl-font);
    font-size:    0.875rem;
    font-weight:  600;
    color:        var(--cl-text-secondary);
    transition:   color 0.15s ease;
    line-height:  1.3;
}

.cl-action-card:hover .cl-action-label {
    color: var(--cl-text-primary);
}

/* Stagger animations */
.cl-action-card:nth-child(1) { animation-delay: 0.05s; }
.cl-action-card:nth-child(2) { animation-delay: 0.10s; }
.cl-action-card:nth-child(3) { animation-delay: 0.15s; }
.cl-action-card:nth-child(4) { animation-delay: 0.20s; }

/* Responsive action grids */
@media (max-width: 991px) {
    .cl-action-grid-3 { grid-template-columns: repeat(3, 1fr); }
    .cl-action-grid-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 575px) {
    .cl-action-grid-3 { grid-template-columns: repeat(1, 1fr); }
    .cl-action-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .cl-action-card  { padding: 20px 12px; }
}

/* =============================================================================
   24. FIX — White backgrounds from default WHMCS theme
   Explicitly override any legacy white/light surfaces that bleed through.
============================================================================= */

/* Home domain search (suppressed but override in case it leaks) */
.home-domain-search,
.home-domain-search.bg-white {
    background:  rgba(6, 11, 26, 0.8) !important;
    border:      none !important;
    box-shadow:  none !important;
}

/* card-columns in homepage */
.card-columns .card,
.card-deck .card {
    background:      var(--cl-surface) !important;
    border:          1px solid var(--cl-surface-border) !important;
    box-shadow:      none !important;
}

.card-columns .card .card-body,
.card-deck .card .card-body {
    background: transparent !important;
    color:      var(--cl-text-secondary) !important;
}

/* Legacy action-icon-btns defaults — ensure no white shows */
.action-icon-btns a,
.action-icon-btns .ico-container {
    background:   transparent !important;
    border-color: var(--cl-surface-border) !important;
    color:        var(--cl-text-secondary) !important;
    box-shadow:   none !important;
}

/* card-accent-* classes used by old homepage */
[class*="card-accent-"]:not(.card) {
    background:    var(--cl-surface) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-radius: var(--cl-radius-card) !important;
    color:         var(--cl-text-secondary) !important;
}

/* Any bg-white override */
.bg-white { background: transparent !important; }

/* =============================================================================
   CSS FALLBACK: Hide ALL domain-related items
   Uses multiple selector strategies to catch every variation WHMCS can produce.
============================================================================= */

/* 1. Exact menuItemName matches (various naming conventions used by WHMCS) */
[menuItemName="Register_a_New_Domain"],
[menuItemName="Transfer_Domains_to_Us"],
[menuItemName="register-domain"],
[menuItemName="transfer-domain"],
[menuItemName="domain-pricing"],
[menuItemName="Domain_Registration"],
[menuItemName="Domain_Transfer"],
[menuItemName="Manage_Domains"],
[menuItemName="manage-domains"],
[menuItemName="Register a New Domain"],
[menuItemName="Transfer in a Domain"],
[menuItemName="Transfer a Domain"],
[menuItemName="Transfer Domains to Us"] {
    display: none !important;
}

/* 2. Partial menuItemName matches — catches any variant with "omain" */
[menuItemName*="omain"]:not([menuItemName*="Your Account"]) {
    display: none !important;
}

/* 3. Hide links that go to domain registration/transfer/checker pages */
a[href*="domain=register"],
a[href*="domain=transfer"],
a[href*="domainchecker.php"],
a[href*="action=domainregisterns"],
a[href*="a=add&domain=register"],
a[href*="a=add&domain=transfer"] {
    display: none !important;
}

/* 4. Hide list-group items that contain domain links (sidebar / actions panels) */
.list-group-item[href*="domain=register"],
.list-group-item[href*="domain=transfer"] {
    display: none !important;
}

/* 5. Hide the domain pricing link in nav */
a[href*="domain-pricing"],
a[href*="domainpricing"] {
    display: none !important;
}

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

/* Section element */
section#main-body { background: transparent !important; }

/* Ensure all containers are transparent */
.container,
.container-fluid { background: transparent !important; }

/* =============================================================================
   26. STORE / PRODUCT PAGES
   Comprehensive styling for the WHMCS store, product group listings,
   individual product cards, pricing, order buttons, and the cart.
   Transforms the default white product cards into Cloudly glassmorphism.
============================================================================= */

/* ── Store page heading ── */
.store-order-container h2,
#main-body h1,
#main-body h2 {
    font-family:    var(--cl-font) !important;
    color:          var(--cl-text-primary) !important;
    font-weight:    700 !important;
}

/* ══════════════════════════════════════════════════════════════════════
   NUCLEAR CARD OVERRIDE — catches ALL .card elements including store
   Bootstrap sets .card { background-color: #fff } in the base layer.
   We must override with maximum specificity + !important.
   ══════════════════════════════════════════════════════════════════════ */
.card,
div.card,
section .card,
#main-body .card,
.container .card,
.primary-content .card,
.card-deck > .card,
.card-columns > .card,
.row .card {
    background:        var(--cl-surface) !important;
    background-color:  var(--cl-surface) !important;
    backdrop-filter:   blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    -webkit-backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    border:            1px solid var(--cl-surface-border) !important;
    border-radius:     var(--cl-radius-card) !important;
    color:             var(--cl-text-primary) !important;
    box-shadow:        0 4px 24px rgba(0, 0, 0, 0.2) !important;
    overflow:          hidden;
    transition:        all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* ── Product group page — product cards ── */
/* These are the cards shown when browsing a product group (e.g. Cirrus AI) */
.card-deck .card,
.card-columns .card,
.card-columns.home .card,
.store-order-container .card {
    background:      var(--cl-surface) !important;
    background-color: var(--cl-surface) !important;
    backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    -webkit-backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    border:          1px solid var(--cl-surface-border) !important;
    border-radius:   var(--cl-radius-card) !important;
    color:           var(--cl-text-primary) !important;
    box-shadow:      0 4px 24px rgba(0, 0, 0, 0.2) !important;
    overflow:        hidden;
    transition:      all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.card-deck .card:hover,
.card-columns .card:hover {
    transform:  translateY(-2px) !important;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3) !important;
    border-color: rgba(59, 130, 246, 0.3) !important;
}

/* Product card header (product name) */
.card-deck .card .card-header,
.card-columns .card .card-header {
    background:    transparent !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    padding:       20px 24px !important;
}

.card-deck .card .card-header h3,
.card-columns .card .card-header h3,
.pricing-card-title {
    font-family:    var(--cl-font) !important;
    font-size:      1.25rem !important;
    font-weight:    700 !important;
    color:          var(--cl-text-primary) !important;
    margin:         0 !important;
    letter-spacing: -0.01em;
}

/* Product card body */
.card-deck .card .card-body,
.card-columns .card .card-body {
    background: transparent !important;
    padding:    24px !important;
    color:      var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
    font-size:  0.875rem !important;
    line-height: 1.65 !important;
}

/* Product description HTML styling */
.card-body strong {
    color:       var(--cl-text-primary) !important;
    font-weight: 700 !important;
}

.card-body em {
    color:      var(--cl-text-muted) !important;
    font-style: italic;
}

/* Checkmark feature lists in product descriptions */
.card-body p {
    color:       var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
    line-height: 1.7 !important;
    margin-bottom: 8px !important;
}

/* ── Pricing display ── */
.product-pricing,
.pricing-amt,
.card .price,
.card-body .price {
    font-family:    var(--cl-font) !important;
    font-size:      1.75rem !important;
    font-weight:    800 !important;
    color:          var(--cl-text-primary) !important;
    letter-spacing: -0.02em;
}

/* Billing cycle text (Monthly, Setup Fee, etc.) */
.pricing-cycle,
.card .billing-cycle,
.card .setup-fee {
    font-family: var(--cl-font) !important;
    font-size:   0.75rem !important;
    color:       var(--cl-text-muted) !important;
    font-weight: 500 !important;
}

/* ── Order Now / Add to Cart buttons ── */
/* Override the green btn-success used by WHMCS for order buttons */
.card .btn-success,
.card-body .btn-success,
.card-footer .btn-success,
.store-order-container .btn-success,
.btn-order-now {
    background:    var(--cl-gradient) !important;
    border:        none !important;
    color:         #fff !important;
    border-radius: var(--cl-radius-btn) !important;
    font-family:   var(--cl-font) !important;
    font-weight:   700 !important;
    font-size:     0.875rem !important;
    padding:       10px 24px !important;
    box-shadow:    0 2px 8px rgba(59, 130, 246, 0.3) !important;
    transition:    all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.card .btn-success:hover,
.card-body .btn-success:hover,
.card-footer .btn-success:hover,
.store-order-container .btn-success:hover,
.btn-order-now:hover {
    transform:  translateY(-1px) !important;
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.45) !important;
    color:      #fff !important;
}

/* btn-outline-primary in product group cards */
.btn-outline-primary {
    background:    transparent !important;
    border:        1px solid rgba(59, 130, 246, 0.4) !important;
    color:         var(--cl-brand) !important;
    border-radius: var(--cl-radius-btn) !important;
    font-family:   var(--cl-font) !important;
    font-weight:   600 !important;
    transition:    all 0.2s ease !important;
}

.btn-outline-primary:hover {
    background:  rgba(59, 130, 246, 0.12) !important;
    border-color: var(--cl-brand) !important;
    color:       var(--cl-brand) !important;
}

/* ── Store domain tab content (white bg override) ── */
.store-domain-tab-content,
.store-domain-tab-content.bg-white,
.tab-content.bg-white.store-domain-tab-content {
    background:    var(--cl-surface) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-top:    none !important;
    border-radius: 0 0 var(--cl-radius-card) var(--cl-radius-card) !important;
    color:         var(--cl-text-secondary) !important;
    padding:       20px !important;
}

/* Store domain tabs */
.store-domain-tabs .nav-link {
    background:    transparent !important;
    border:        1px solid transparent !important;
    color:         var(--cl-text-secondary) !important;
    font-family:   var(--cl-font) !important;
    font-weight:   500 !important;
    transition:    all 0.15s ease !important;
}

.store-domain-tabs .nav-link:hover {
    color: var(--cl-text-primary) !important;
}

.store-domain-tabs .nav-link.active,
.store-domain-tabs .nav-item.active .nav-link {
    background:   rgba(59, 130, 246, 0.1) !important;
    border-color: rgba(59, 130, 246, 0.3) rgba(59, 130, 246, 0.3) transparent !important;
    color:        var(--cl-brand) !important;
    font-weight:  700 !important;
}

/* ── Payment term selector ── */
.payment-term h4 {
    font-family:    var(--cl-font) !important;
    font-size:      0.875rem !important;
    font-weight:    700 !important;
    color:          var(--cl-text-secondary) !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom:  8px !important;
}

.payment-term select.form-control {
    background:    var(--cl-input-bg) !important;
    border:        1px solid var(--cl-input-border) !important;
    border-radius: var(--cl-radius-input) !important;
    color:         var(--cl-text-primary) !important;
    font-family:   var(--cl-font) !important;
}

/* ── Store order container ── */
.store-order-container {
    color: var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

.store-order-container h2 {
    font-size:      1.5rem !important;
    font-weight:    700 !important;
    color:          var(--cl-text-primary) !important;
    margin-bottom:  12px !important;
}

.store-order-container h4 {
    font-family:    var(--cl-font) !important;
    font-size:      1rem !important;
    font-weight:    600 !important;
    color:          var(--cl-text-secondary) !important;
}

.store-order-container p {
    color:       var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
    line-height: 1.7 !important;
}

/* ── Dynamic store page overrides ── */
.dynamic-landing-page {
    color: var(--cl-text-secondary) !important;
}

.dynamic-landing-page h1,
.dynamic-landing-page h2,
.dynamic-landing-page h3 {
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
}

/* ── Product group page header ── */
.store-cat-header,
.product-group-header {
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
}

/* ── Cart page ── */
.view-cart-items-header {
    background:    rgba(255, 255, 255, 0.04) !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    color:         var(--cl-text-muted) !important;
    font-family:   var(--cl-font) !important;
    font-weight:   700 !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size:     0.75rem !important;
}

.view-cart-items .item {
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
    color:         var(--cl-text-secondary) !important;
    font-family:   var(--cl-font) !important;
}

.view-cart-items .item:hover {
    background: rgba(255, 255, 255, 0.03) !important;
}

/* ── Checkout totals ── */
.order-summary,
.cart-total {
    font-family: var(--cl-font) !important;
    color:       var(--cl-text-primary) !important;
}

/* ── Responsive tabs connector (the little arrow between tabs and content) ── */
.responsive-tabs-sm-connector.store .channel {
    background: var(--cl-surface) !important;
}

.responsive-tabs-sm-connector.store .bottom-border {
    border-color: var(--cl-surface-border) !important;
}

/* ── Upsell / promoted product card ── */
.store-promoted-product {
    background:    var(--cl-surface) !important;
    border:        1px solid var(--cl-surface-border) !important;
    border-radius: var(--cl-radius-card) !important;
    color:         var(--cl-text-secondary) !important;
}

.store-promoted-product h3 {
    color:       var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-weight: 700 !important;
}

.store-promoted-product h4 {
    color:       var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

.store-promoted-product .features li {
    color:       var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

.store-promoted-product .features i {
    color: var(--cl-success) !important;
}

/* ── Dynamic store CSS variable overrides ── */
.dynamic-landing-page {
    --bg-color:   transparent !important;
    --bg-light:   rgba(255, 255, 255, 0.04) !important;
    --bg-dark:    rgba(6, 11, 26, 0.8) !important;
    --text-color: #f1f5f9 !important;
    --text-secondary: #94a3b8 !important;
}

/* ── Price comparison cards in dynamic store ── */
.dynamic-landing-page .price-comparison-card,
.dynamic-landing-page .grid-card {
    background:      var(--cl-surface) !important;
    backdrop-filter: blur(var(--cl-blur)) !important;
    border:          1px solid var(--cl-surface-border) !important;
    border-radius:   var(--cl-radius-card) !important;
    color:           var(--cl-text-secondary) !important;
    transition:      all 0.3s ease !important;
}

.dynamic-landing-page .price-comparison-card:hover,
.dynamic-landing-page .grid-card:hover {
    transform:  translateY(-2px) !important;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25) !important;
}

.dynamic-landing-page .price-comparison-card .price,
.dynamic-landing-page .grid-card .price {
    font-family:    var(--cl-font) !important;
    font-size:      1.75rem !important;
    font-weight:    800 !important;
    color:          var(--cl-text-primary) !important;
}

.dynamic-landing-page .price-comparison-card .btn,
.dynamic-landing-page .grid-card .btn {
    background:    var(--cl-gradient) !important;
    border:        none !important;
    color:         #fff !important;
    border-radius: var(--cl-radius-btn) !important;
    font-family:   var(--cl-font) !important;
    font-weight:   700 !important;
    box-shadow:    0 2px 8px rgba(59, 130, 246, 0.3) !important;
}

.dynamic-landing-page .price-comparison-card .btn:hover,
.dynamic-landing-page .grid-card .btn:hover {
    transform:  translateY(-1px) !important;
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.45) !important;
}

/* ── Dynamic store pricing cards (from dynamic-store.css) ── */
.pricing-card,
.dynamic-landing-page .pricing-card {
    background:      var(--cl-surface) !important;
    background-color: var(--cl-surface) !important;
    backdrop-filter: blur(var(--cl-blur)) !important;
    border:          1px solid var(--cl-surface-border) !important;
    border-radius:   var(--cl-radius-card) !important;
    color:           var(--cl-text-secondary) !important;
    box-shadow:      0 4px 24px rgba(0, 0, 0, 0.2) !important;
}

.pricing-card:hover {
    transform:  translateY(-2px) !important;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3) !important;
}

.pricing-card .pricing-card-header,
.pricing-card h3,
.pricing-card h4 {
    color:       var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
}

.pricing-card .pricing-card-price {
    color:       var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-weight: 800 !important;
}

.pricing-card .pricing-card-features li,
.pricing-card ul li {
    color:       var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
    border-color: var(--cl-surface-border) !important;
}

.buy-row,
.pricing-card .buy-row {
    background:   var(--cl-surface) !important;
    border-top:   1px solid var(--cl-surface-border) !important;
}

/* CTA buttons in dynamic store */
.cta-primary-button,
.cta-section--gradient .cta-primary-button {
    background:    var(--cl-gradient) !important;
    color:         #fff !important;
    border-radius: var(--cl-radius-btn) !important;
}

.cta-secondary-button {
    background:    transparent !important;
    border:        1px solid var(--cl-surface-border) !important;
    color:         var(--cl-text-secondary) !important;
    border-radius: var(--cl-radius-btn) !important;
}

.cta-secondary-button:hover {
    background:  var(--cl-surface-hover) !important;
    color:       var(--cl-text-primary) !important;
}

/* ══════════════════════════════════════════════════════════════════════
   ABSOLUTE NUCLEAR — Override ANY white background anywhere in the app
   This catches Bootstrap .card, store pricing cards, tab content, etc.
   ══════════════════════════════════════════════════════════════════════ */
body .card,
body .card-body,
body .card-header,
body .card-footer,
body .tab-content,
body .pricing-card,
body .buy-row {
    background-color: transparent !important;
}

/* Re-apply the glass surface to cards specifically */
body .card {
    background: var(--cl-surface) !important;
}

body .card-header {
    background: transparent !important;
}

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

body .card-footer {
    background: transparent !important;
}

body .tab-content.store-domain-tab-content,
body .tab-content.bg-white {
    background: var(--cl-surface) !important;
}

/* =============================================================================
   27. CLOUDLY CART — REVIEW & CHECKOUT HARD OVERRIDES
   Loaded from the active Twenty-One theme so these rules always apply,
   even if the order form stylesheet is cached or loaded in a different order.
============================================================================= */

body #order-cloudly-cart .secondary-cart-body {
    padding-right: 24px;
}

body #order-cloudly-cart .secondary-cart-sidebar {
    max-width: 320px;
}

body #order-cloudly-cart .cl-cart-header,
body #order-cloudly-cart .view-cart-items-header {
    background: transparent !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    color: var(--cl-text-muted) !important;
    font-family: var(--cl-font) !important;
    font-size: 0.6875rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    padding: 0 0 10px !important;
    margin: 0 0 8px !important;
}

body #order-cloudly-cart .cl-cart-items,
body #order-cloudly-cart .view-cart-items {
    background: transparent !important;
    margin: 0 0 12px !important;
}

body #order-cloudly-cart .cl-cart-item,
body #order-cloudly-cart .view-cart-items .item {
    background: rgba(255, 255, 255, 0.05) !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    border-radius: 16px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.18) !important;
    padding: 16px 18px !important;
    margin: 0 0 12px !important;
    color: var(--cl-text-secondary) !important;
    overflow: hidden !important;
}

body #order-cloudly-cart .cl-cart-item:hover,
body #order-cloudly-cart .view-cart-items .item:hover {
    background: rgba(255, 255, 255, 0.07) !important;
    background-color: rgba(255, 255, 255, 0.07) !important;
    border-color: rgba(59, 130, 246, 0.22) !important;
}

body #order-cloudly-cart .cl-item-title,
body #order-cloudly-cart .view-cart-items .item-title {
    display: block !important;
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    margin: 0 0 4px !important;
}

body #order-cloudly-cart .cl-item-group,
body #order-cloudly-cart .view-cart-items .item-group {
    display: block !important;
    color: var(--cl-text-muted) !important;
    font-family: var(--cl-font) !important;
    font-size: 0.82rem !important;
    margin: 0 0 2px !important;
}

body #order-cloudly-cart .cl-item-domain,
body #order-cloudly-cart .view-cart-items .item-domain,
body #order-cloudly-cart .view-cart-items .item small {
    color: var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

body #order-cloudly-cart .cl-item-price,
body #order-cloudly-cart .view-cart-items .item-price {
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-weight: 700 !important;
    text-align: right !important;
}

body #order-cloudly-cart .cl-cycle,
body #order-cloudly-cart .view-cart-items .item-price .cycle,
body #order-cloudly-cart .view-cart-items .renewal,
body #order-cloudly-cart .view-cart-items .renewal-price {
    color: var(--cl-text-muted) !important;
    font-size: 0.75rem !important;
    font-weight: 500 !important;
}

body #order-cloudly-cart .empty-cart .btn-link,
body #order-cloudly-cart .btn-remove-from-cart,
body #order-cloudly-cart .view-cart-items .btn-link {
    color: var(--cl-brand) !important;
}

body #order-cloudly-cart .empty-cart .btn-link:hover,
body #order-cloudly-cart .btn-remove-from-cart:hover,
body #order-cloudly-cart .view-cart-items .btn-link:hover {
    color: #60a5fa !important;
}

body #order-cloudly-cart .view-cart-tabs {
    margin-top: 20px !important;
}

body #order-cloudly-cart .view-cart-tabs .tab-content {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-top: none !important;
    border-radius: 0 0 18px 18px !important;
    padding: 20px !important;
}

body #order-cloudly-cart .order-summary,
body #order-cloudly-cart #orderSummary,
body #order-cloudly-cart .summary-container {
    background: rgba(15, 23, 42, 0.88) !important;
    background-color: rgba(15, 23, 42, 0.88) !important;
    backdrop-filter: blur(24px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 20px !important;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.28) !important;
    color: var(--cl-text-secondary) !important;
}

body #order-cloudly-cart .order-summary {
    padding: 24px !important;
}

body #order-cloudly-cart .order-summary h2,
body #order-cloudly-cart #orderSummary h2 {
    background: transparent !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-size: 1.1rem !important;
    font-weight: 800 !important;
    margin: 0 0 16px !important;
    padding: 0 0 12px !important;
    text-align: center !important;
}

body #order-cloudly-cart .order-summary .subtotal,
body #order-cloudly-cart .order-summary .recurring-totals,
body #order-cloudly-cart .order-summary .bordered-totals,
body #order-cloudly-cart .order-summary .bordered-totals > div,
body #order-cloudly-cart .order-summary .total-due-today,
body #order-cloudly-cart .order-summary .total-due-today-padded,
body #order-cloudly-cart .order-summary .text-right {
    background: transparent !important;
    background-color: transparent !important;
}

body #order-cloudly-cart .order-summary .subtotal span,
body #order-cloudly-cart .order-summary .recurring-totals span,
body #order-cloudly-cart .order-summary .bordered-totals span {
    color: var(--cl-text-secondary) !important;
}

body #order-cloudly-cart .order-summary #totalDueToday,
body #order-cloudly-cart .order-summary .amt {
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-size: 1.9rem !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
}

body #order-cloudly-cart #checkout,
body #order-cloudly-cart .btn-checkout {
    background: linear-gradient(135deg, #3b82f6 0%, #6366f1 50%, #8b5cf6 100%) !important;
    border: none !important;
    border-radius: 14px !important;
    box-shadow: 0 4px 16px rgba(59, 130, 246, 0.45) !important;
    color: #fff !important;
    font-family: var(--cl-font) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    padding: 14px 24px !important;
    width: 100% !important;
}

body #order-cloudly-cart #continueShopping,
body #order-cloudly-cart .btn-continue-shopping {
    color: var(--cl-brand) !important;
    display: block !important;
    font-family: var(--cl-font) !important;
    font-weight: 600 !important;
    margin-top: 12px !important;
    text-align: center !important;
}

@media (max-width: 991px) {
    body #order-cloudly-cart .secondary-cart-body {
        padding-right: 0 !important;
    }

    body #order-cloudly-cart .secondary-cart-sidebar {
        max-width: 100% !important;
        margin-top: 24px !important;
    }
}

/* =============================================================================
   28. REVIEW & CHECKOUT FALLBACK FOR LEGACY ROOT ID
   If WHMCS is still rendering the cart page with #order-standard_cart,
   these rules ensure the Cloudly styling still applies.
============================================================================= */

body #order-standard_cart .view-cart-items-header,
body #order-standard_cart .cl-cart-header {
    background: transparent !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    color: var(--cl-text-muted) !important;
    font-family: var(--cl-font) !important;
    font-size: 0.6875rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    padding: 0 0 10px !important;
    margin: 0 0 8px !important;
    border-radius: 0 !important;
}

body #order-standard_cart .view-cart-items {
    background: transparent !important;
    border-bottom: none !important;
    margin: 0 0 12px !important;
}

body #order-standard_cart .view-cart-items .item {
    background: rgba(255, 255, 255, 0.05) !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    border-radius: 16px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.18) !important;
    padding: 16px 18px !important;
    margin: 0 0 12px !important;
    color: var(--cl-text-secondary) !important;
}

body #order-standard_cart .view-cart-items .item:nth-child(even) {
    background: rgba(255, 255, 255, 0.05) !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
}

body #order-standard_cart .view-cart-items .item:hover {
    background: rgba(255, 255, 255, 0.07) !important;
    background-color: rgba(255, 255, 255, 0.07) !important;
    border-color: rgba(59, 130, 246, 0.22) !important;
}

body #order-standard_cart .view-cart-items .item-title {
    display: block !important;
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    margin: 0 0 4px !important;
}

body #order-standard_cart .view-cart-items .item-group {
    display: block !important;
    color: var(--cl-text-muted) !important;
    font-family: var(--cl-font) !important;
    font-size: 0.82rem !important;
    margin: 0 0 2px !important;
}

body #order-standard_cart .view-cart-items .item-domain,
body #order-standard_cart .view-cart-items .item small {
    color: var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

body #order-standard_cart .view-cart-items .item-price {
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-weight: 700 !important;
    text-align: right !important;
}

body #order-standard_cart .view-cart-items .item-price span {
    color: inherit !important;
    font-size: 1rem !important;
}

body #order-standard_cart .view-cart-items .item-price .cycle,
body #order-standard_cart .view-cart-items .renewal,
body #order-standard_cart .view-cart-items .renewal-price {
    color: var(--cl-text-muted) !important;
    font-size: 0.75rem !important;
    font-weight: 500 !important;
}

body #order-standard_cart .empty-cart .btn,
body #order-standard_cart .empty-cart .btn-link,
body #order-standard_cart .btn-remove-from-cart,
body #order-standard_cart .view-cart-items .btn-link {
    background: transparent !important;
    color: var(--cl-brand) !important;
    border: none !important;
}

body #order-standard_cart .view-cart-tabs .tab-content {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-top: none !important;
    border-radius: 0 0 18px 18px !important;
    padding: 20px !important;
}

body #order-standard_cart .order-summary,
body #order-standard_cart #orderSummary,
body #order-standard_cart .summary-container {
    background: rgba(15, 23, 42, 0.88) !important;
    background-color: rgba(15, 23, 42, 0.88) !important;
    backdrop-filter: blur(24px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 20px !important;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.28) !important;
    color: var(--cl-text-secondary) !important;
}

body #order-standard_cart .order-summary {
    padding: 24px !important;
}

body #order-standard_cart .order-summary h2,
body #order-standard_cart #orderSummary h2 {
    background: transparent !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-size: 1.1rem !important;
    font-weight: 800 !important;
    margin: 0 0 16px !important;
    padding: 0 0 12px !important;
    text-align: center !important;
}

body #order-standard_cart .order-summary .subtotal,
body #order-standard_cart .order-summary .recurring-totals,
body #order-standard_cart .order-summary .bordered-totals,
body #order-standard_cart .order-summary .bordered-totals > div,
body #order-standard_cart .order-summary .total-due-today,
body #order-standard_cart .order-summary .total-due-today-padded,
body #order-standard_cart .order-summary .text-right {
    background: transparent !important;
    background-color: transparent !important;
}

body #order-standard_cart .order-summary .subtotal span,
body #order-standard_cart .order-summary .recurring-totals span,
body #order-standard_cart .order-summary .bordered-totals span {
    color: var(--cl-text-secondary) !important;
}

body #order-standard_cart .order-summary #totalDueToday,
body #order-standard_cart .order-summary .amt {
    color: var(--cl-text-primary) !important;
    font-family: var(--cl-font) !important;
    font-size: 1.9rem !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
}

body #order-standard_cart #checkout,
body #order-standard_cart .btn-checkout {
    background: linear-gradient(135deg, #3b82f6 0%, #6366f1 50%, #8b5cf6 100%) !important;
    border: none !important;
    border-radius: 14px !important;
    box-shadow: 0 4px 16px rgba(59, 130, 246, 0.45) !important;
    color: #fff !important;
    font-family: var(--cl-font) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    padding: 14px 24px !important;
    width: 100% !important;
}

body #order-standard_cart #continueShopping,
body #order-standard_cart .btn-continue-shopping {
    color: var(--cl-brand) !important;
    display: block !important;
    font-family: var(--cl-font) !important;
    font-weight: 600 !important;
    margin-top: 12px !important;
    text-align: center !important;
}

/* =============================================================================
   29. STANDARD CART CHECKOUT PAGE — CLOUDLY OVERRIDES
   Product groups are currently using the system default/standard cart, so the
   checkout page must be styled from the active Twenty-One theme layer.
 ============================================================================= */

body #order-standard_cart .already-registered {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    margin: 0 0 24px !important;
}

body #order-standard_cart .already-registered p {
    margin: 0 !important;
    color: var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
    font-size: 1rem !important;
    line-height: 1.7 !important;
}

body #order-standard_cart .already-registered .btn {
    min-width: 180px !important;
}

body #order-standard_cart .sub-heading,
body #order-standard_cart .sub-heading-borderless {
    height: auto !important;
    margin: 34px 0 24px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.14) !important;
    text-align: center !important;
    position: relative !important;
}

body #order-standard_cart .sub-heading span,
body #order-standard_cart .sub-heading-borderless span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 30px !important;
    padding: 0 18px !important;
    position: relative !important;
    top: -16px !important;
    background: rgba(6, 11, 26, 0.96) !important;
    border: 1px solid rgba(59, 130, 246, 0.22) !important;
    border-radius: 999px !important;
    box-shadow: 0 10px 30px rgba(2, 6, 23, 0.35) !important;
    color: #38bdf8 !important;
    font-family: var(--cl-font) !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}

body #order-standard_cart .checkout-error-feedback {
    margin: 0 0 24px !important;
}

body #order-standard_cart .account-select-container {
    margin: 0 -8px 8px !important;
    border: 0 !important;
}

body #order-standard_cart .account-select-container > div {
    padding: 0 8px 16px !important;
}

body #order-standard_cart .account-select-container div.account {
    height: 100% !important;
    background: rgba(15, 23, 42, 0.72) !important;
    background-color: rgba(15, 23, 42, 0.72) !important;
    backdrop-filter: blur(24px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-right: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 18px !important;
    box-shadow: 0 8px 28px rgba(2, 6, 23, 0.24) !important;
    overflow: hidden !important;
    transition: all 0.25s ease !important;
}

body #order-standard_cart .account-select-container div.account.active,
body #order-standard_cart .account-select-container div.account:hover {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.16), rgba(139, 92, 246, 0.10)) !important;
    border-color: rgba(59, 130, 246, 0.34) !important;
    box-shadow: 0 16px 44px rgba(2, 6, 23, 0.35), 0 0 0 1px rgba(59, 130, 246, 0.14) !important;
}

body #order-standard_cart .account-select-container div.account label.radio-inline {
    display: flex !important;
    align-items: flex-start !important;
    gap: 12px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 18px 20px !important;
    color: #e2e8f0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
}

body #order-standard_cart .account-select-container div.account strong {
    color: var(--cl-text-primary) !important;
    font-weight: 700 !important;
}

body #order-standard_cart .account-select-container div.account .small {
    display: block !important;
    margin-top: 8px !important;
    color: var(--cl-text-secondary) !important;
    font-size: 0.8rem !important;
    line-height: 1.65 !important;
}

body #order-standard_cart .account-select-container .label-info {
    background: rgba(56, 189, 248, 0.18) !important;
    color: #7dd3fc !important;
    border-radius: 999px !important;
}

body #order-standard_cart .account-select-container .label-default {
    background: rgba(148, 163, 184, 0.16) !important;
    color: #cbd5e1 !important;
    border-radius: 999px !important;
}

body #order-standard_cart #totalDueToday {
    margin: 0 0 22px !important;
    padding: 18px 24px !important;
    border-radius: 20px !important;
    border: 1px solid rgba(16, 185, 129, 0.32) !important;
    background: linear-gradient(135deg, rgba(6, 78, 59, 0.52), rgba(6, 95, 70, 0.22)) !important;
    box-shadow: 0 12px 34px rgba(6, 78, 59, 0.16) !important;
    color: #86efac !important;
    font-family: var(--cl-font) !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
}

body #order-standard_cart #totalDueToday strong,
body #order-standard_cart #totalDueToday #totalCartPrice {
    color: #dcfce7 !important;
    font-size: 1.2rem !important;
    font-weight: 800 !important;
}

body #order-standard_cart .apply-credit-container {
    margin: 0 0 24px !important;
    padding: 20px 22px !important;
    background: rgba(255, 255, 255, 0.05) !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    border-radius: 18px !important;
    color: #cbd5e1 !important;
}

body #order-standard_cart .apply-credit-container p,
body #order-standard_cart .apply-credit-container .radio {
    color: #cbd5e1 !important;
}

body #order-standard_cart #paymentGatewaysContainer {
    margin: 0 0 18px !important;
}

body #order-standard_cart #paymentGatewaysContainer > p {
    margin-bottom: 14px !important;
    color: var(--cl-text-secondary) !important;
}

body #order-standard_cart #paymentGatewaysContainer .text-center {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 12px !important;
}

body #order-standard_cart #paymentGatewaysContainer .radio-inline {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 12px 18px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    color: #cbd5e1 !important;
    box-shadow: 0 8px 24px rgba(2, 6, 23, 0.15) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
}

body #order-standard_cart .gateway-errors {
    margin-bottom: 18px !important;
}

body #order-standard_cart #paymentGatewayInput {
    margin-bottom: 18px !important;
}

body #order-standard_cart .cc-input-container {
    position: relative !important;
    margin-top: 12px !important;
    padding: 28px 28px 16px !important;
    background: rgba(15, 23, 42, 0.76) !important;
    background-color: rgba(15, 23, 42, 0.76) !important;
    backdrop-filter: blur(24px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 24px !important;
    box-shadow: 0 16px 40px rgba(2, 6, 23, 0.26) !important;
    overflow: hidden !important;
}

body #order-standard_cart .cc-input-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.14), transparent);
    pointer-events: none;
}

body #order-standard_cart .cc-input-container ul {
    list-style: none !important;
    margin: 0 0 18px !important;
    padding: 0 !important;
}

body #order-standard_cart .cc-input-container .radio-inline {
    text-transform: none !important;
    letter-spacing: 0 !important;
    color: #e2e8f0 !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
}

body #order-standard_cart .cc-input-container .existing-cc-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 12px !important;
    width: 100% !important;
    margin-bottom: 18px !important;
    color: var(--cl-text-secondary) !important;
}

body #order-standard_cart .cc-input-container .field-error-msg {
    display: block !important;
    margin-top: 8px !important;
    color: #fda4af !important;
    font-size: 0.75rem !important;
    line-height: 1.4 !important;
}

body #order-standard_cart .cc-input-container .field,
body #order-standard_cart .cc-input-container .form-control,
body #order-standard_cart .cc-input-container input[type="tel"],
body #order-standard_cart .cc-input-container input[type="text"] {
    color: #f8fafc !important;
    -webkit-text-fill-color: #f8fafc !important;
    caret-color: #f8fafc !important;
    font-family: var(--cl-font) !important;
    font-size: 1.1rem !important;
    font-weight: 500 !important;
    line-height: 1.3 !important;
}

body #order-standard_cart .cc-input-container .field::placeholder,
body #order-standard_cart .cc-input-container .form-control::placeholder,
body #order-standard_cart .cc-input-container input[type="tel"]::placeholder,
body #order-standard_cart .cc-input-container input[type="text"]::placeholder {
    color: #94a3b8 !important;
    -webkit-text-fill-color: #94a3b8 !important;
    opacity: 1 !important;
    font-size: 1.02rem !important;
}

body #order-standard_cart .cc-input-container .field:focus,
body #order-standard_cart .cc-input-container .form-control:focus,
body #order-standard_cart .cc-input-container input[type="tel"]:focus,
body #order-standard_cart .cc-input-container input[type="text"]:focus {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    border-color: rgba(96, 165, 250, 0.9) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.18) !important;
}

body #order-standard_cart .cc-input-container label,
body #order-standard_cart .cc-input-container .field-icon,
body #order-standard_cart .cc-input-container .field-icon i {
    color: #cbd5e1 !important;
}

body #order-standard_cart .cc-input-container .field-icon i {
    font-size: 1rem !important;
}

body #order-standard_cart .cc-input-container .form-group > label:not(.field-icon),
body #order-standard_cart .cc-input-container .payment-methods,
body #order-standard_cart .cc-input-container .paymethod-info {
    color: #e2e8f0 !important;
    font-size: 0.82rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
}

body #order-standard_cart .cc-input-container input:-webkit-autofill,
body #order-standard_cart .cc-input-container input:-webkit-autofill:hover,
body #order-standard_cart .cc-input-container input:-webkit-autofill:focus {
    -webkit-text-fill-color: #f8fafc !important;
    box-shadow: 0 0 0 1000px rgba(15, 23, 42, 0.96) inset !important;
    transition: background-color 9999s ease-in-out 0s;
}

body #order-standard_cart .cc-input-container #inputCardNumber,
body #order-standard_cart .cc-input-container #inputCardExpiry,
body #order-standard_cart .cc-input-container #inputCardCVV,
body #order-standard_cart .cc-input-container #inputCardCVV2,
body #order-standard_cart .cc-input-container #inputDescription,
body #order-standard_cart .cc-input-container .cc-number-field,
body #order-standard_cart .cc-input-container .input-inline,
body #order-standard_cart .cc-input-container .input-inline-100,
body #order-standard_cart .cc-input-container input:not([type="radio"]):not([type="checkbox"]),
body #order-standard_cart .cc-input-container textarea {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    caret-color: #ffffff !important;
    font-size: 1.16rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.01em !important;
    text-shadow: 0 0 0 #ffffff !important;
    opacity: 1 !important;
}

body #order-standard_cart .cc-input-container #inputCardNumber::placeholder,
body #order-standard_cart .cc-input-container #inputCardExpiry::placeholder,
body #order-standard_cart .cc-input-container #inputCardCVV::placeholder,
body #order-standard_cart .cc-input-container #inputCardCVV2::placeholder,
body #order-standard_cart .cc-input-container #inputDescription::placeholder,
body #order-standard_cart .cc-input-container input:not([type="radio"]):not([type="checkbox"])::placeholder,
body #order-standard_cart .cc-input-container textarea::placeholder {
    color: #cbd5e1 !important;
    -webkit-text-fill-color: #cbd5e1 !important;
    font-size: 1.02rem !important;
    font-weight: 600 !important;
    opacity: 1 !important;
}

body #order-standard_cart .cc-input-container .StripeElement,
body #order-standard_cart .cc-input-container .__PrivateStripeElement,
body #order-standard_cart .cc-input-container [class*="StripeElement"],
body #order-standard_cart .cc-input-container [class*="InputElement"] {
    color: #ffffff !important;
    font-size: 1.16rem !important;
    font-weight: 700 !important;
}

/* =============================================================================
   STRIPE ELEMENTS — fallback readability mode (light panel)
   Stripe text appears black in hosted iframes; use white field surfaces so
   card data is always readable for checkout completion.
============================================================================= */
#paymentGatewayInput:not(:empty),
body #order-standard_cart #paymentGatewayInput:not(:empty),
body #order-cloudly-cart #paymentGatewayInput:not(:empty),
#frmPayment #paymentGatewayInput:not(:empty),
body #frmPayment #paymentGatewayInput:not(:empty) {
    background: #ffffff !important;
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 16px !important;
    padding: 24px !important;
    margin: 16px 0 !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08) !important;
}

/* Hide the container when empty (before Stripe injects content) */
#paymentGatewayInput:empty,
body #order-standard_cart #paymentGatewayInput:empty,
body #order-cloudly-cart #paymentGatewayInput:empty,
#frmPayment #paymentGatewayInput:empty,
body #frmPayment #paymentGatewayInput:empty {
    display: none !important;
}

/* Labels/aux text inside the Stripe payment area */
#paymentGatewayInput label,
#paymentGatewayInput span,
#paymentGatewayInput p,
#paymentGatewayInput div,
body #order-standard_cart #paymentGatewayInput label,
body #order-standard_cart #paymentGatewayInput span,
body #order-standard_cart #paymentGatewayInput p,
body #order-standard_cart #paymentGatewayInput div,
body #order-cloudly-cart #paymentGatewayInput label,
body #order-cloudly-cart #paymentGatewayInput span,
body #order-cloudly-cart #paymentGatewayInput p,
body #order-cloudly-cart #paymentGatewayInput div,
#frmPayment #paymentGatewayInput label,
#frmPayment #paymentGatewayInput span,
#frmPayment #paymentGatewayInput p,
#frmPayment #paymentGatewayInput div {
    color: #1e293b !important;
}

/* Inputs rendered in the Stripe area */
#paymentGatewayInput input,
#paymentGatewayInput .form-control,
body #order-standard_cart #paymentGatewayInput input,
body #order-standard_cart #paymentGatewayInput .form-control,
body #order-cloudly-cart #paymentGatewayInput input,
body #order-cloudly-cart #paymentGatewayInput .form-control,
#frmPayment #paymentGatewayInput input,
#frmPayment #paymentGatewayInput .form-control {
    background: #f8fafc !important;
    background-color: #f8fafc !important;
    border: 1px solid #cbd5e1 !important;
    color: #0f172a !important;
    -webkit-text-fill-color: #0f172a !important;
    caret-color: #0f172a !important;
}

#paymentGatewayInput input::placeholder,
body #order-standard_cart #paymentGatewayInput input::placeholder,
body #order-cloudly-cart #paymentGatewayInput input::placeholder,
#frmPayment #paymentGatewayInput input::placeholder {
    color: #94a3b8 !important;
    -webkit-text-fill-color: #94a3b8 !important;
}

#paymentGatewayInput input:focus,
body #order-standard_cart #paymentGatewayInput input:focus,
body #order-cloudly-cart #paymentGatewayInput input:focus,
#frmPayment #paymentGatewayInput input:focus {
    border-color: #3b82f6 !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15) !important;
    color: #0f172a !important;
    -webkit-text-fill-color: #0f172a !important;
}

/* Stripe element wrappers */
#paymentGatewayInput .StripeElement,
#paymentGatewayInput .__PrivateStripeElement,
#paymentGatewayInput [class*="StripeElement"],
#paymentGatewayInput [class*="InputElement"],
body #order-standard_cart .cc-input-container .StripeElement,
body #order-standard_cart .cc-input-container .__PrivateStripeElement,
body #order-standard_cart .cc-input-container [class*="StripeElement"],
body #order-standard_cart .cc-input-container [class*="InputElement"],
body #order-cloudly-cart .cc-input-container .StripeElement,
body #order-cloudly-cart .cc-input-container .__PrivateStripeElement,
body #order-cloudly-cart .cc-input-container [class*="StripeElement"],
body #order-cloudly-cart .cc-input-container [class*="InputElement"],
#frmPayment #paymentGatewayInput .StripeElement,
#frmPayment #paymentGatewayInput .__PrivateStripeElement,
#frmPayment #paymentGatewayInput [class*="StripeElement"],
#frmPayment #paymentGatewayInput [class*="InputElement"] {
    background: #ffffff !important;
    background-color: #ffffff !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 10px !important;
    color: #0f172a !important;
}

/* Stripe iframes (hosted inputs) */
body #order-standard_cart .cc-input-container iframe[src*="stripe.com"],
body #order-cloudly-cart .cc-input-container iframe[src*="stripe.com"],
body #paymentGatewayInput iframe[src*="stripe.com"],
body #frmPayment #paymentGatewayInput iframe[src*="stripe.com"] {
    background: #ffffff !important;
    background-color: #ffffff !important;
    border-radius: 10px !important;
}

/* Links inside Stripe area */
#paymentGatewayInput a,
#frmPayment #paymentGatewayInput a {
    color: #2563eb !important;
}

body #order-standard_cart textarea.field,
body #order-standard_cart textarea.form-control {
    min-height: 104px !important;
    border-radius: 18px !important;
}

body #order-standard_cart #btnCompleteOrder {
    min-width: 220px !important;
    padding: 14px 28px !important;
    border-radius: 14px !important;
    background: linear-gradient(135deg, #3b82f6 0%, #6366f1 50%, #8b5cf6 100%) !important;
    border: none !important;
    box-shadow: 0 4px 16px rgba(59, 130, 246, 0.45) !important;
    color: #fff !important;
    font-family: var(--cl-font) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
}

body #order-standard_cart .checkout-security-msg {
    margin: 28px 0 0 !important;
    padding: 18px 22px !important;
    background: rgba(245, 158, 11, 0.10) !important;
    background-color: rgba(245, 158, 11, 0.10) !important;
    border: 1px solid rgba(245, 158, 11, 0.26) !important;
    border-radius: 20px !important;
    color: #fbbf24 !important;
    box-shadow: 0 12px 28px rgba(120, 53, 15, 0.10) !important;
}

body #order-standard_cart .checkout-security-msg i {
    color: #f59e0b !important;
    float: none !important;
    margin: 0 10px 0 0 !important;
    font-size: 1rem !important;
}

@media (max-width: 767px) {
    body #order-standard_cart .already-registered {
        align-items: stretch !important;
    }

    body #order-standard_cart .already-registered .pull-right,
    body #order-standard_cart .already-registered .float-right {
        width: 100% !important;
    }

    body #order-standard_cart .already-registered .btn,
    body #order-standard_cart #paymentGatewaysContainer .radio-inline {
        width: 100% !important;
    }

    body #order-standard_cart .cc-input-container {
        padding: 22px 18px 12px !important;
        border-radius: 20px !important;
    }

    body #order-standard_cart #paymentGatewaysContainer .text-center {
        flex-direction: column !important;
        align-items: stretch !important;
    }
}

/* =============================================================================
   30. CLIENT AREA CONTENT HARDENING (tables, tickets, announcements, KB)
   Ensures list pages are fully Cloudly-styled with no legacy white panels.
 ============================================================================= */

/* DataTables/list pages used by:
   /clientarea.php?action=services
   /clientarea.php?action=invoices
   /clientarea.php?action=quotes
   /supporttickets.php */
body .table-container {
    background: transparent !important;
}

body .dataTables_wrapper table.table-list,
body table.table-list {
    margin: 12px 0 !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    border: 1px solid var(--cl-surface-border) !important;
    border-radius: 16px !important;
    overflow: hidden !important;
}

body .dataTables_wrapper table.table-list thead th,
body table.table-list thead th {
    background: rgba(255, 255, 255, 0.04) !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    color: var(--cl-text-muted) !important;
    font-family: var(--cl-font) !important;
    font-size: 0.6875rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

body .table-list > tbody > tr > td,
body .dataTables_wrapper .table-list > tbody > tr > td,
body table.table-list tbody td {
    background: rgba(255, 255, 255, 0.02) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
    color: var(--cl-text-secondary) !important;
}

body .table-list > tbody > tr:hover > td,
body .dataTables_wrapper .table-list > tbody > tr:hover > td {
    background: rgba(255, 255, 255, 0.06) !important;
}

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

body .dataTables_wrapper .dataTables_filter label .form-control {
    background-color: var(--cl-input-bg) !important;
    border: 1px solid var(--cl-input-border) !important;
    color: var(--cl-text-primary) !important;
}

body .dataTables_wrapper .dataTables_info,
body .dataTables_wrapper .dataTables_length,
body .dataTables_wrapper .dataTables_filter,
body .dataTables_wrapper .dataTables_paginate {
    color: var(--cl-text-secondary) !important;
    font-family: var(--cl-font) !important;
}

/* Status pills in services/invoices/quotes/tickets tables */
body .label.status,
body .badge.status {
    border: 1px solid rgba(255, 255, 255, 0.16) !important;
    border-radius: 999px !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em !important;
}

/* Announcements */
body .announcements .announcement {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid var(--cl-surface-border) !important;
    border-radius: 16px !important;
    padding: 20px 22px !important;
    margin-bottom: 18px !important;
}

body .announcements .announcement article,
body .announcements .announcement article p,
body .announcements .announcement li {
    color: var(--cl-text-secondary) !important;
}

body .announcements .announcement h1,
body .announcements .announcement h2,
body .announcements .announcement h3,
body .announcements .announcement a {
    color: var(--cl-text-primary) !important;
}

/* Knowledgebase listing/category/article */
body .kb-category,
body .kb-category .card-body,
body .kb-article-item,
body .list-group-item.kb-article-item {
    background: transparent !important;
    color: var(--cl-text-secondary) !important;
}

body .kb-category a:hover,
body .kb-article-item:hover {
    background: rgba(255, 255, 255, 0.06) !important;
    color: var(--cl-text-primary) !important;
}

body .kb-article-item small,
body article,
body article p,
body article li {
    color: var(--cl-text-secondary) !important;
}

/* Support ticket list readability */
body .ticket-number,
body .ticket-subject {
    color: var(--cl-text-primary) !important;
}

body .ticket-subject.unread {
    color: #bfdbfe !important;
}

/* =============================================================================
   31. INVOICE VIEW (viewinvoice.php) - Cloudly dark glass treatment
 ============================================================================= */

body.cl-invoice-page {
    background:
        radial-gradient(1200px 700px at -10% -20%, rgba(59, 130, 246, 0.22), transparent 60%),
        radial-gradient(1000px 620px at 120% -10%, rgba(168, 85, 247, 0.20), transparent 60%),
        var(--cl-body-bg) !important;
    color: var(--cl-text-secondary) !important;
    min-height: 100vh;
    padding: 24px 0 52px !important;
}

body.cl-invoice-page .invoice-container {
    max-width: 1020px !important;
    background: var(--cl-surface) !important;
    backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    -webkit-backdrop-filter: blur(var(--cl-blur)) saturate(var(--cl-saturate)) !important;
    border: 1px solid var(--cl-surface-border) !important;
    border-radius: 20px !important;
    box-shadow: 0 26px 56px rgba(0, 0, 0, 0.45) !important;
    padding: 34px 36px 28px !important;
}

body.cl-invoice-page .invoice-header h2,
body.cl-invoice-page .invoice-header h3,
body.cl-invoice-page .invoice-container h1,
body.cl-invoice-page .invoice-container h2,
body.cl-invoice-page .invoice-container h3,
body.cl-invoice-page .invoice-container strong {
    color: var(--cl-text-primary) !important;
}

body.cl-invoice-page .invoice-header img {
    max-height: 56px !important;
    width: auto !important;
}

@media (min-width: 768px) {
    body.cl-invoice-page .invoice-header {
        position: relative;
        min-height: 128px;
    }

    /* Keep logo + invoice title in normal left column flow */
    body.cl-invoice-page .invoice-header > .invoice-col:first-child {
        position: relative !important;
        left: auto !important;
        top: auto !important;
        transform: none !important;
        width: auto !important;
        max-width: 50% !important;
        text-align: left !important;
        z-index: 1;
    }

    /* Center UNPAID / Due Date / Pay Now block in the invoice header */
    body.cl-invoice-page .invoice-header > .invoice-col:last-child {
        position: absolute;
        left: 50%;
        top: 0;
        transform: translateX(-50%);
        width: max-content !important;
        max-width: 320px;
        float: none !important;
        z-index: 2;
    }

    body.cl-invoice-page .invoice-header .invoice-col.text-center .payment-btn-container {
        text-align: center !important;
    }
}

body.cl-invoice-page .invoice-container .small-text,
body.cl-invoice-page .invoice-container address,
body.cl-invoice-page .invoice-container p,
body.cl-invoice-page .invoice-container td {
    color: var(--cl-text-secondary) !important;
}

body.cl-invoice-page .invoice-container hr {
    border-color: var(--cl-surface-border) !important;
}

body.cl-invoice-page .invoice-container .invoice-status span {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-width: 120px;
    padding: 8px 14px !important;
    border-radius: 999px !important;
    border: 1px solid transparent !important;
    font-size: 0.8rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

body.cl-invoice-page .invoice-container .invoice-status .unpaid,
body.cl-invoice-page .invoice-container .invoice-status .draft,
body.cl-invoice-page .invoice-container .invoice-status .cancelled,
body.cl-invoice-page .invoice-container .invoice-status .collections {
    background: rgba(239, 68, 68, 0.16) !important;
    border-color: rgba(239, 68, 68, 0.45) !important;
    color: #fca5a5 !important;
}

body.cl-invoice-page .invoice-container .invoice-status .paid {
    background: rgba(34, 197, 94, 0.16) !important;
    border-color: rgba(34, 197, 94, 0.42) !important;
    color: #86efac !important;
}

body.cl-invoice-page .invoice-container .invoice-status .refunded {
    background: rgba(59, 130, 246, 0.16) !important;
    border-color: rgba(59, 130, 246, 0.45) !important;
    color: #93c5fd !important;
}

body.cl-invoice-page .invoice-container .payment-btn-container {
    margin-top: 12px !important;
}

body.cl-invoice-page .invoice-container .payment-btn-container .btn,
body.cl-invoice-page .invoice-container .payment-btn-container button,
body.cl-invoice-page .invoice-container .payment-btn-container input[type="submit"] {
    border-radius: var(--cl-radius-btn) !important;
    font-weight: 700 !important;
}

body.cl-invoice-page .invoice-container .custom-select,
body.cl-invoice-page .invoice-container select {
    background-color: var(--cl-input-bg) !important;
    border: 1px solid var(--cl-input-border) !important;
    border-radius: var(--cl-radius-input) !important;
    color: var(--cl-text-primary) !important;
}

body.cl-invoice-page .invoice-container .card {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid var(--cl-surface-border) !important;
    border-radius: 16px !important;
    box-shadow: none !important;
}

body.cl-invoice-page .invoice-container .card-header,
body.cl-invoice-page .invoice-container .card-title.py-1 {
    background: rgba(255, 255, 255, 0.04) !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    color: var(--cl-text-primary) !important;
}

body.cl-invoice-page .invoice-container .table {
    margin-bottom: 0 !important;
}

body.cl-invoice-page .invoice-container .table thead td,
body.cl-invoice-page .invoice-container .table thead th {
    background: rgba(255, 255, 255, 0.03) !important;
    border-bottom: 1px solid var(--cl-surface-border) !important;
    border-top: none !important;
    color: var(--cl-text-muted) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

body.cl-invoice-page .invoice-container .table td,
body.cl-invoice-page .invoice-container .table th {
    border-color: rgba(255, 255, 255, 0.08) !important;
}

body.cl-invoice-page .invoice-container td.total-row {
    background: rgba(255, 255, 255, 0.06) !important;
    color: var(--cl-text-primary) !important;
}

body.cl-invoice-page .invoice-container .transactions-container a {
    color: var(--cl-brand) !important;
}

body.cl-invoice-page .invoice-container .invoice-qr-wrapper {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid var(--cl-surface-border) !important;
    border-radius: 14px !important;
    padding: 14px !important;
}

body.cl-invoice-page .invoice-container .btn.btn-default {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid var(--cl-surface-border) !important;
    color: var(--cl-text-secondary) !important;
}

body.cl-invoice-page .invoice-container .btn.btn-default:hover {
    background: rgba(255, 255, 255, 0.09) !important;
    color: var(--cl-text-primary) !important;
}

body.cl-invoice-page > p.text-center.d-print-none a {
    color: var(--cl-brand) !important;
    font-weight: 600 !important;
}

@media (max-width: 767px) {
    body.cl-invoice-page .invoice-container {
        padding: 24px 16px 18px !important;
        border-radius: 16px !important;
    }
}

@media print {
    @page {
        margin: 12mm 10mm;
    }

    body.cl-invoice-page {
        background: #fff !important;
        color: #111827 !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    /* Keep white/transparent logo text visible on white paper.
       drop-shadow follows PNG alpha so glow hugs glyphs, not image bounds. */
    body.cl-invoice-page .invoice-header img {
        -webkit-filter:
            drop-shadow(0 0 0.7px rgba(0, 0, 0, 0.95))
            drop-shadow(0 0 1.2px rgba(0, 0, 0, 0.85))
            drop-shadow(0 0 2px rgba(0, 0, 0, 0.7)) !important;
        filter:
            drop-shadow(0 0 0.7px rgba(0, 0, 0, 0.95))
            drop-shadow(0 0 1.2px rgba(0, 0, 0, 0.85))
            drop-shadow(0 0 2px rgba(0, 0, 0, 0.7)) !important;
    }

    body.cl-invoice-page .invoice-container {
        width: auto !important;
        max-width: none !important;
        margin: 0 auto !important;
        padding: 14px 16px 12px !important;
        background: #fff !important;
        border: 1px solid #d1d5db !important;
        border-radius: 10px !important;
        box-shadow: none !important;
    }

    body.cl-invoice-page .invoice-container *,
    body.cl-invoice-page .invoice-container .small-text,
    body.cl-invoice-page .invoice-container address,
    body.cl-invoice-page .invoice-container td,
    body.cl-invoice-page .invoice-container th,
    body.cl-invoice-page .invoice-container h1,
    body.cl-invoice-page .invoice-container h2,
    body.cl-invoice-page .invoice-container h3,
    body.cl-invoice-page .invoice-container strong {
        color: #111827 !important;
    }

    body.cl-invoice-page .invoice-container .card,
    body.cl-invoice-page .invoice-container .card-header,
    body.cl-invoice-page .invoice-container td.total-row {
        background: #fff !important;
    }
}
