/* ==========================================================================
   Coder4Nix Theme - Main Stylesheet
   CSS Custom Properties + Global Bootstrap/WHMCS Overrides
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. CSS Custom Properties (Light Mode Default)
   -------------------------------------------------------------------------- */
:root,
[data-theme="light"] {
    --c4n-bg: #f8f9fa;
    --c4n-bg-alt: #f0f1f3;
    --c4n-surface: rgba(255, 255, 255, 0.85);
    --c4n-surface-2: #e5e7eb;
    --c4n-surface-hover: rgba(243, 244, 246, 0.9);
    --c4n-text: #1f2937;
    --c4n-text-secondary: #4b5563;
    --c4n-text-muted: #6b7280;
    --c4n-primary: #00c853;
    --c4n-primary-hover: #00b347;
    --c4n-primary-rgb: 0, 200, 83;
    --c4n-secondary: #00b0ff;
    --c4n-secondary-hover: #009ee6;
    --c4n-secondary-rgb: 0, 176, 255;
    --c4n-accent: #7c4dff;
    --c4n-accent-hover: #6b3fe6;
    --c4n-accent-rgb: 124, 77, 255;
    --c4n-danger: #ef4444;
    --c4n-warning: #f59e0b;
    --c4n-success: #10b981;
    --c4n-info: #3b82f6;
    --c4n-border: #e5e7eb;
    --c4n-border-light: #f3f4f6;
    --c4n-nav-bg: rgba(255, 255, 255, 0.85);
    --c4n-nav-border: rgba(229, 231, 235, 0.8);
    --c4n-card-bg: rgba(255, 255, 255, 0.7);
    --c4n-card-shadow: 0 4px 6px rgba(0, 0, 0, 0.07), 0 10px 20px rgba(0, 0, 0, 0.05);
    --c4n-card-shadow-hover: 0 10px 30px rgba(0, 0, 0, 0.12), 0 0 15px rgba(0, 200, 83, 0.08);
    --c4n-glow-primary: 0 0 15px rgba(0, 200, 83, 0.15);
    --c4n-glow-secondary: 0 0 15px rgba(0, 176, 255, 0.15);
    --c4n-glow-accent: 0 0 15px rgba(124, 77, 255, 0.15);
    --c4n-input-bg: #ffffff;
    --c4n-input-border: #d1d5db;
    --c4n-input-focus-border: var(--c4n-primary);
    --c4n-input-focus-shadow: 0 0 0 3px rgba(var(--c4n-primary-rgb), 0.2), 0 0 15px rgba(var(--c4n-primary-rgb), 0.1);
    --c4n-code-bg: #f3f4f6;
    --c4n-code-text: #e11d48;
    --c4n-sidebar-bg: #ffffff;
    --c4n-sidebar-active: rgba(var(--c4n-primary-rgb), 0.08);
    --c4n-footer-bg: #111827;
    --c4n-footer-text: #d1d5db;
    --c4n-footer-heading: #ffffff;
    --c4n-footer-link: #9ca3af;
    --c4n-footer-link-hover: #00c853;
    --c4n-modal-bg: #ffffff;
    --c4n-modal-overlay: rgba(0, 0, 0, 0.5);
    --c4n-dropdown-bg: #ffffff;
    --c4n-dropdown-hover: #f3f4f6;
    --c4n-table-stripe: #f9fafb;
    --c4n-table-hover: #f3f4f6;
    --c4n-scrollbar-track: #f1f1f1;
    --c4n-scrollbar-thumb: #c1c1c1;
    --c4n-radius-sm: 6px;
    --c4n-radius: 10px;
    --c4n-radius-lg: 16px;
    --c4n-radius-xl: 24px;
    --c4n-transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --c4n-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --c4n-font-mono: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;
}

/* --------------------------------------------------------------------------
   2. Dark Mode
   -------------------------------------------------------------------------- */
[data-theme="dark"] {
    --c4n-bg: #0d1117;
    --c4n-bg-alt: #090c10;
    --c4n-surface: rgba(22, 27, 34, 0.8);
    --c4n-surface-2: #1c2333;
    --c4n-surface-hover: rgba(28, 33, 41, 0.9);
    --c4n-text: #e6edf3;
    --c4n-text-secondary: #b1bac4;
    --c4n-text-muted: #8b949e;
    --c4n-border: rgba(48, 54, 61, 0.6);
    --c4n-border-light: #21262d;
    --c4n-nav-bg: rgba(13, 17, 23, 0.85);
    --c4n-nav-border: rgba(48, 54, 61, 0.5);
    --c4n-card-bg: rgba(22, 27, 34, 0.6);
    --c4n-card-shadow: 0 4px 6px rgba(0, 0, 0, 0.3), 0 10px 20px rgba(0, 0, 0, 0.2);
    --c4n-card-shadow-hover: 0 10px 30px rgba(0, 0, 0, 0.4), 0 0 20px rgba(0, 200, 83, 0.1);
    --c4n-glow-primary: 0 0 20px rgba(0, 200, 83, 0.3);
    --c4n-glow-secondary: 0 0 20px rgba(0, 176, 255, 0.3);
    --c4n-glow-accent: 0 0 20px rgba(124, 77, 255, 0.3);
    --c4n-input-bg: rgba(13, 17, 23, 0.8);
    --c4n-input-border: rgba(48, 54, 61, 0.6);
    --c4n-input-focus-shadow: 0 0 0 3px rgba(0, 200, 83, 0.2), 0 0 15px rgba(0, 200, 83, 0.1);
    --c4n-sidebar-bg: rgba(22, 27, 34, 0.7);
    --c4n-sidebar-active: rgba(var(--c4n-primary-rgb), 0.12);
    --c4n-modal-bg: rgba(22, 27, 34, 0.9);
    --c4n-modal-overlay: rgba(0, 0, 0, 0.7);
    --c4n-dropdown-bg: rgba(28, 33, 41, 0.95);
    --c4n-dropdown-hover: rgba(37, 44, 53, 0.9);
    --c4n-table-stripe: rgba(19, 25, 32, 0.6);
    --c4n-table-hover: rgba(28, 33, 41, 0.8);
    --c4n-code-bg: #1c2129;
    --c4n-code-text: #ff7eb3;
    --c4n-scrollbar-track: #161b22;
    --c4n-scrollbar-thumb: #30363d;
}

/* --------------------------------------------------------------------------
   3. Base / Reset
   -------------------------------------------------------------------------- */

/* Wider container (+50px) — backgrounds stay 100% */
@media (min-width: 576px)  { .container { max-width: 590px;  } }
@media (min-width: 768px)  { .container { max-width: 770px;  } }
@media (min-width: 992px)  { .container { max-width: 1010px; } }
@media (min-width: 1200px) { .container { max-width: 1190px; } }

*,
*::before,
*::after {
    transition: background-color var(--c4n-transition), border-color var(--c4n-transition), color var(--c4n-transition), box-shadow var(--c4n-transition);
}

html {
    scroll-behavior: smooth;
}

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

::selection {
    background: rgba(var(--c4n-primary-rgb), 0.3);
    color: var(--c4n-text);
}

::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

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

::-webkit-scrollbar-thumb {
    background: var(--c4n-scrollbar-thumb);
    border-radius: 4px;
}

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

/* --------------------------------------------------------------------------
   4. Typography
   -------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    color: var(--c4n-text);
    font-weight: 700;
    letter-spacing: -0.02em;
}

h1, .h1 { font-size: 2.25rem; }
h2, .h2 { font-size: 1.875rem; }
h3, .h3 { font-size: 1.5rem; }
h4, .h4 { font-size: 1.25rem; }

p {
    color: var(--c4n-text-secondary);
}

a {
    color: var(--c4n-primary);
    text-decoration: none;
    transition: color var(--c4n-transition);
}

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

code, pre, .code {
    font-family: var(--c4n-font-mono);
}

code {
    background: var(--c4n-code-bg);
    color: var(--c4n-code-text);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 0.875em;
}

pre {
    background: var(--c4n-code-bg);
    border: 1px solid var(--c4n-border);
    border-radius: var(--c4n-radius);
    padding: 1rem;
    overflow-x: auto;
}

pre code {
    background: transparent;
    padding: 0;
}

small, .small, .text-muted {
    color: var(--c4n-text-muted) !important;
}

/* --------------------------------------------------------------------------
   5. WHMCS Primary BG Override
   -------------------------------------------------------------------------- */
.primary-bg-color {
    background-color: var(--c4n-bg) !important;
}

#main-body {
    min-height: calc(100vh - var(--header-height, 90px));
    padding-top: 1rem;
    padding-bottom: 1.5rem;
}

/* --------------------------------------------------------------------------
   6. Navigation / Header
   -------------------------------------------------------------------------- */
#header {
    position: sticky;
    top: 0;
    z-index: 1030;
    background: var(--c4n-nav-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.15);
}

.topbar {
    background: var(--c4n-surface);
    border-bottom: 1px solid var(--c4n-border);
    padding: 0.35rem 0;
    font-size: 0.85rem;
}

.topbar .btn {
    color: var(--c4n-text-muted);
    font-size: 0.85rem;
    padding: 0.15rem 0.5rem;
}

.topbar .btn:hover {
    color: var(--c4n-primary);
}

.topbar .input-group-text {
    background: transparent;
    border: none;
    color: var(--c4n-text-muted);
    font-size: 0.85rem;
    padding: 0;
}

.topbar .btn-active-client {
    color: var(--c4n-text);
    font-weight: 600;
}

.topbar .btn-return-to-admin {
    color: var(--c4n-warning);
}

#header .navbar {
    padding: 0.6rem 0;
}

#header .navbar-brand {
    padding: 0;
    margin: 0;
    margin-left: -8px;
}

header.header .logo-img,
#header .navbar-brand .logo-img {
    width: auto !important;
    max-width: 180px !important;
    max-height: 88px !important;
    height: auto !important;
    object-fit: contain;
    object-position: left center;
    transition: transform var(--c4n-transition);
}

#header .navbar-brand .logo-img:hover {
    transform: scale(1.03);
}

#header .navbar .search .form-control {
    background: var(--c4n-input-bg);
    border: 1px solid var(--c4n-input-border);
    color: var(--c4n-text);
    border-radius: 0 var(--c4n-radius-sm) var(--c4n-radius-sm) 0;
    font-size: 0.875rem;
}

#header .navbar .search .form-control:focus {
    border-color: var(--c4n-primary);
    box-shadow: var(--c4n-input-focus-shadow);
}

#header .navbar .search .btn {
    background: var(--c4n-input-bg);
    border: 1px solid var(--c4n-input-border);
    border-right: none;
    color: var(--c4n-text-muted);
    border-radius: var(--c4n-radius-sm) 0 0 var(--c4n-radius-sm);
}

/* Toolbar Icons — reset borders, normalize sizes */
.navbar-nav.toolbar .nav-link,
header.header .toolbar .nav-link {
    color: var(--c4n-text-muted);
    position: relative;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    padding: 0.5rem 0.65rem;
    font-size: 1rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 43px;
    height: 43px;
    border-radius: 8px;
    transition: all var(--c4n-transition);
}

.navbar-nav.toolbar .nav-link i,
header.header .toolbar .nav-link i {
    font-size: 1.25rem;
    width: 1.25rem;
    text-align: center;
}

.navbar-nav.toolbar .nav-link:hover,
header.header .toolbar .nav-link:hover {
    color: var(--c4n-primary);
    background: rgba(var(--c4n-primary-rgb), 0.08);
}

.navbar-nav.toolbar .nav-link:focus,
.navbar-nav.toolbar .nav-link:active,
header.header .toolbar .nav-link:focus,
header.header .toolbar .nav-link:active {
    outline: none !important;
    box-shadow: none !important;
    border: none !important;
}

.navbar-nav.toolbar .badge-info {
    background: var(--c4n-primary);
    color: #fff;
    font-size: 0.6rem;
    padding: 2px 4px;
    border-radius: 10px;
    position: absolute;
    top: 2px;
    right: 0;
    min-width: 16px;
    text-align: center;
    line-height: 1.2;
}

/* Cart button — same size as other toolbar icons */
.navbar-nav.toolbar .cart-btn,
header.header .toolbar .cart-btn {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

/* Main Navigation Bar — single row with logo */
.c4n-main-nav {
    padding: 0.5rem 0 !important;
}

.c4n-main-nav .navbar-collapse {
    justify-content: flex-end !important;
    gap: 0.5rem;
}

.c4n-main-nav .navbar-nav .d-block > a {
    color: var(--c4n-text-secondary);
    font-weight: 500;
    font-size: 1.17rem;
    padding: 0.65rem 0.5rem;
    position: relative;
    transition: color var(--c4n-transition);
    white-space: nowrap;
}

.c4n-main-nav .navbar-nav .d-block > a:hover {
    color: var(--c4n-primary);
}

.c4n-main-nav .navbar-nav .d-block.active > a,
.c4n-main-nav .navbar-nav .d-block > a:focus,
.c4n-main-nav .navbar-nav .d-block > a:active,
.c4n-main-nav .navbar-nav .d-block > a.show {
    color: var(--c4n-primary);
    background: transparent !important;
    outline: none;
}

.c4n-main-nav .navbar-nav .d-block > a::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--c4n-primary), var(--c4n-secondary));
    border-radius: 1px;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform var(--c4n-transition);
}

.c4n-main-nav .navbar-nav .d-block > a:hover::before,
.c4n-main-nav .navbar-nav .d-block.active > a::before {
    transform: scaleX(1);
}

/* Dark/Light Toggle */
.c4n-theme-toggle {
    background: transparent;
    border: none !important;
    padding: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 43px;
    height: 43px;
    border-radius: 8px;
    color: var(--c4n-text-muted);
    transition: all var(--c4n-transition);
    outline: none !important;
    box-shadow: none !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.c4n-theme-toggle:hover {
    color: var(--c4n-primary);
    background: rgba(var(--c4n-primary-rgb), 0.08);
}

.c4n-theme-toggle:focus,
.c4n-theme-toggle:active,
.c4n-theme-toggle:focus-visible {
    outline: none !important;
    box-shadow: none !important;
    border: none !important;
}

.c4n-theme-toggle .toggle-icon {
    font-size: 1.25rem;
    width: 1.25rem;
    text-align: center;
    transition: transform 0.5s ease;
}

[data-theme="dark"] .c4n-theme-toggle .toggle-icon {
    transform: rotate(180deg);
}

/* Dropdown Menus */
.dropdown-menu {
    background: var(--c4n-dropdown-bg);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--c4n-radius);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
    padding: 0.5rem;
    margin-top: 0.5rem;
}

[data-theme="light"] .dropdown-menu {
    border: 1px solid var(--c4n-border);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
}

.dropdown-item,
li.dropdown-item > a.dropdown-item {
    color: var(--c4n-text-secondary);
    border-radius: var(--c4n-radius-sm);
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
}

.dropdown-item:hover, .dropdown-item:focus,
li.dropdown-item:hover > a.dropdown-item {
    background: var(--c4n-dropdown-hover);
    color: var(--c4n-primary);
}

.dropdown-item:active, .dropdown-item.active,
li.dropdown-item:active > a.dropdown-item {
    background: var(--c4n-dropdown-hover) !important;
    color: var(--c4n-primary) !important;
}

.dropdown-item:focus, .dropdown-item:focus-visible,
li.dropdown-item:focus > a.dropdown-item {
    background: var(--c4n-dropdown-hover) !important;
    color: var(--c4n-primary) !important;
    outline: none !important;
    box-shadow: none !important;
}

/* Prevent Bootstrap dropdown flash on toggle */
.navbar-nav .nav-link:focus,
.navbar-nav .nav-link:active,
.navbar-nav .nav-link.show,
.navbar-nav .dropdown-toggle:focus,
.navbar-nav .dropdown-toggle:active {
    background-color: transparent !important;
    outline: none;
    box-shadow: none;
}

.dropdown-menu.show {
    animation: c4n-dropdown-fade 0.15s ease-out;
}
@keyframes c4n-dropdown-fade {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

.dropdown-divider {
    border-color: var(--c4n-border);
}

/* Breadcrumb — plain text, no badges, no icons */
.master-breadcrumb {
    background: var(--c4n-bg);
    border-bottom: 1px solid var(--c4n-border);
    padding: 0.5rem 0;
}

.breadcrumb {
    background: transparent;
    margin: 0;
    padding: 0;
    font-size: 0.82rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
    list-style: none;
}

.breadcrumb-item {
    display: inline-flex;
    align-items: center;
    line-height: 1.4;
}

/* Hide ALL icons inside breadcrumb */
.breadcrumb-item i,
.breadcrumb-item .fas,
.breadcrumb-item .far,
.breadcrumb-item .fal,
.breadcrumb-item .fad,
.breadcrumb-item .fab,
.breadcrumb-item svg {
    display: none !important;
}

.breadcrumb-item a {
    color: var(--c4n-text-muted);
    text-decoration: none;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    transition: color 0.2s ease;
    font-weight: 400;
}

.breadcrumb-item a:hover {
    color: var(--c4n-primary);
    background: none;
    border: none;
    text-decoration: none;
}

.breadcrumb-item.active {
    color: var(--c4n-text);
    font-weight: 500;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
}

.breadcrumb-item + .breadcrumb-item::before {
    content: '/' !important;
    font-family: inherit;
    font-weight: 400;
    font-size: 0.8rem;
    color: var(--c4n-text-muted);
    opacity: 0.4;
    padding: 0 0.5rem;
}

/* Light mode breadcrumb */
[data-theme="light"] .breadcrumb-item a {
    color: var(--c4n-text-muted);
}
[data-theme="light"] .breadcrumb-item.active {
    color: var(--c4n-text);
}

/* Client Alerts Popover */
.client-alerts {
    list-style: none;
    padding: 0;
    margin: 0;
}

.client-alerts li a {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 0.75rem;
    border-radius: var(--c4n-radius-sm);
    color: var(--c4n-text);
}

.client-alerts li a:hover {
    background: var(--c4n-surface-hover);
}

/* --------------------------------------------------------------------------
   7. Cards
   -------------------------------------------------------------------------- */
.card {
    background: var(--c4n-card-bg);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    box-shadow: var(--c4n-card-shadow);
    transition: box-shadow var(--c4n-transition), transform var(--c4n-transition);
    overflow: hidden;
    position: relative;
}

.card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--c4n-primary), var(--c4n-secondary), var(--c4n-accent));
    border-radius: 12px 12px 0 0;
    opacity: 0;
    transition: opacity var(--c4n-transition);
    z-index: 1;
}

.card:hover::before {
    opacity: 1;
}

.card:hover {
    transform: translateY(-4px);
    box-shadow: var(--c4n-card-shadow-hover);
}

[data-theme="light"] .card {
    border: 1px solid var(--c4n-border);
}

.card-header {
    background: var(--c4n-surface);
    border-bottom: 1px solid var(--c4n-border);
    padding: 1rem 1.25rem;
}

.card-header .card-title {
    color: var(--c4n-text);
    font-weight: 600;
    font-size: 1rem;
}

.card-body {
    padding: 1.25rem;
    color: var(--c4n-text);
}

.card-footer {
    background: var(--c4n-surface);
    border-top: 1px solid var(--c4n-border);
    padding: 0.75rem 1.25rem;
}

/* Card accent colors */
.card-accent-blue { border-top: 3px solid var(--c4n-secondary); }
.card-accent-green { border-top: 3px solid var(--c4n-primary); }
.card-accent-red { border-top: 3px solid var(--c4n-danger); }
.card-accent-gold { border-top: 3px solid var(--c4n-warning); }
.card-accent-teal { border-top: 3px solid #14b8a6; }
.card-accent-pomegranate { border-top: 3px solid #ef4444; }
.card-accent-sun-flower { border-top: 3px solid #f59e0b; }
.card-accent-asbestos { border-top: 3px solid #6b7280; }
.card-accent-midnight-blue { border-top: 3px solid var(--c4n-accent); }

/* WHMCS Login Card (standalone, outside auth wrapper) */
.card.mw-540 {
    max-width: 480px;
    margin: 0 auto;
    border-radius: var(--c4n-radius-lg);
    border: 1px solid var(--c4n-border);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

[data-theme="dark"] .card.mw-540 {
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

/* Auth card should NOT lift on hover */
.c4n-auth-card .card:hover {
    transform: none;
}

/* --------------------------------------------------------------------------
   8. Buttons
   -------------------------------------------------------------------------- */
.btn {
    border-radius: var(--c4n-radius-sm);
    font-weight: 500;
    font-size: 0.875rem;
    padding: 0.5rem 1.25rem;
    transition: all var(--c4n-transition);
    border: 1px solid transparent;
    letter-spacing: 0.01em;
}

.btn:focus {
    box-shadow: 0 0 0 3px rgba(var(--c4n-primary-rgb), 0.2);
}

.btn-primary {
    background: linear-gradient(135deg, #00c853, #00b347);
    border: none;
    color: #000;
    font-weight: 600;
    box-shadow: 0 4px 15px rgba(0, 200, 83, 0.3);
}

.btn-primary:hover, .btn-primary:focus {
    background: linear-gradient(135deg, #00e676, #00c853);
    color: #000;
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(0, 200, 83, 0.5);
}

.btn-outline-primary {
    color: var(--c4n-primary);
    border-color: var(--c4n-primary);
    background: transparent;
}

.btn-outline-primary:hover {
    background: rgba(0, 200, 83, 0.1);
    border-color: var(--c4n-primary);
    color: var(--c4n-primary);
    transform: translateY(-2px);
    box-shadow: 0 0 20px rgba(0, 200, 83, 0.2);
}

.btn-secondary {
    background: linear-gradient(135deg, #00b0ff, #0091ea);
    border: none;
    color: #fff;
    box-shadow: 0 4px 15px rgba(0, 176, 255, 0.3);
}

.btn-secondary:hover {
    background: linear-gradient(135deg, #40c4ff, #00b0ff);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(0, 176, 255, 0.5);
}

.btn-default, .btn-light {
    background: var(--c4n-surface);
    border-color: var(--c4n-border);
    color: var(--c4n-text-secondary);
}

.btn-default:hover, .btn-light:hover {
    background: var(--c4n-surface-hover);
    border-color: var(--c4n-border);
    color: var(--c4n-text);
}

.btn-success {
    background: linear-gradient(135deg, #10b981, #059669);
    border: none;
    color: #fff;
    box-shadow: 0 4px 15px rgba(16, 185, 129, 0.3);
}

.btn-success:hover {
    background: linear-gradient(135deg, #34d399, #10b981);
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(16, 185, 129, 0.5);
    color: #fff;
}

.btn-danger {
    background: linear-gradient(135deg, #ef4444, #dc2626);
    border: none;
    color: #fff;
    box-shadow: 0 4px 15px rgba(239, 68, 68, 0.3);
}

.btn-danger:hover {
    background: linear-gradient(135deg, #f87171, #ef4444);
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(239, 68, 68, 0.5);
    color: #fff;
}

.btn-warning {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    border: none;
    color: #000;
    box-shadow: 0 4px 15px rgba(245, 158, 11, 0.3);
}

.btn-warning:hover {
    background: linear-gradient(135deg, #fbbf24, #f59e0b);
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(245, 158, 11, 0.5);
    color: #000;
}

.btn-info {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    border: none;
    color: #fff;
    box-shadow: 0 4px 15px rgba(59, 130, 246, 0.3);
}

.btn-info:hover {
    background: linear-gradient(135deg, #60a5fa, #3b82f6);
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(59, 130, 246, 0.5);
    color: #fff;
}

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

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

.btn-xs, .btn-group-xs > .btn {
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
}

/* BG Color buttons used in WHMCS */
.bg-color-blue { background-color: var(--c4n-secondary) !important; color: #fff !important; }
.bg-color-green { background-color: var(--c4n-primary) !important; color: #000 !important; }
.bg-color-red { background-color: var(--c4n-danger) !important; color: #fff !important; }
.bg-color-gold { background-color: var(--c4n-warning) !important; color: #000 !important; }

/* --------------------------------------------------------------------------
   9. Forms / Inputs
   -------------------------------------------------------------------------- */
.form-control {
    background: var(--c4n-input-bg);
    border: 1px solid var(--c4n-input-border);
    color: var(--c4n-text);
    border-radius: var(--c4n-radius-sm);
    padding: 0.5rem 0.875rem;
    font-size: 0.9rem;
    transition: border-color var(--c4n-transition), box-shadow var(--c4n-transition);
}

.form-control:focus {
    background: var(--c4n-input-bg);
    border-color: var(--c4n-primary);
    box-shadow: 0 0 0 3px rgba(0, 200, 83, 0.2), 0 0 15px rgba(0, 200, 83, 0.1);
    color: var(--c4n-text);
}

.form-control::placeholder {
    color: var(--c4n-text-muted);
}

.form-control-label, label {
    color: var(--c4n-text-secondary);
    font-weight: 500;
    font-size: 0.875rem;
    margin-bottom: 0.35rem;
}

.input-group-text {
    background: var(--c4n-surface);
    border: 1px solid var(--c4n-input-border);
    color: var(--c4n-text-muted);
    border-radius: var(--c4n-radius-sm);
}

.input-group-merge .input-group-text {
    border-right: none;
}

.input-group-merge .form-control {
    border-left: none;
}

/* Input-group: green border on the ENTIRE group (icon + input) when focused */
.input-group:focus-within {
    border-radius: var(--c4n-radius-sm);
    box-shadow: 0 0 0 3px rgba(0, 200, 83, 0.2), 0 0 15px rgba(0, 200, 83, 0.1);
}

.input-group:focus-within .input-group-text {
    border-color: var(--c4n-primary) !important;
}

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

.custom-select {
    background-color: var(--c4n-input-bg);
    border: 1px solid var(--c4n-input-border);
    color: var(--c4n-text);
    border-radius: var(--c4n-radius-sm);
}

.custom-control-input:checked ~ .custom-control-label::before {
    background-color: var(--c4n-primary);
    border-color: var(--c4n-primary);
}

textarea.form-control {
    min-height: 100px;
}

.form-group {
    margin-bottom: 1.25rem;
}

/* --------------------------------------------------------------------------
   10. Tables
   -------------------------------------------------------------------------- */
.table {
    color: var(--c4n-text);
}

.table thead th {
    background: linear-gradient(135deg, var(--c4n-surface), rgba(0, 200, 83, 0.05));
    color: var(--c4n-text-secondary);
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 2px solid var(--c4n-primary);
    padding: 0.75rem 1rem;
    white-space: nowrap;
}

.table td {
    border-top: 1px solid var(--c4n-border);
    padding: 0.75rem 1rem;
    vertical-align: middle;
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: var(--c4n-table-stripe);
}

.table-hover tbody tr:hover {
    background-color: rgba(0, 200, 83, 0.04);
    color: var(--c4n-text);
    box-shadow: inset 3px 0 0 var(--c4n-primary);
}

.table-bordered {
    border: 1px solid var(--c4n-border);
}

.table-bordered td,
.table-bordered th {
    border-color: var(--c4n-border);
}

/* --------------------------------------------------------------------------
   11. Alerts
   -------------------------------------------------------------------------- */
.alert {
    border-radius: var(--c4n-radius);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-left: 4px solid;
    font-size: 0.9rem;
    padding: 1rem 1.25rem;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.alert-success {
    background: rgba(16, 185, 129, 0.1);
    color: var(--c4n-success);
    border-left: 4px solid var(--c4n-success);
}

.alert-danger {
    background: rgba(239, 68, 68, 0.1);
    color: var(--c4n-danger);
    border-left: 4px solid var(--c4n-danger);
}

.alert-warning {
    background: rgba(245, 158, 11, 0.1);
    color: var(--c4n-warning);
    border-left: 4px solid var(--c4n-warning);
}

.alert-info {
    background: rgba(59, 130, 246, 0.1);
    color: var(--c4n-info);
    border-left: 4px solid var(--c4n-info);
}

[data-theme="dark"] .alert-success { color: #34d399; }
[data-theme="dark"] .alert-danger { color: #f87171; }
[data-theme="dark"] .alert-warning { color: #fbbf24; }
[data-theme="dark"] .alert-info { color: #60a5fa; }

/* --------------------------------------------------------------------------
   12. Badges
   -------------------------------------------------------------------------- */
.badge {
    font-weight: 500;
    font-size: 0.75rem;
    padding: 0.3em 0.65em;
    border-radius: 50px;
    letter-spacing: 0.02em;
}

.badge-primary { background: var(--c4n-primary); color: #000; box-shadow: 0 0 8px rgba(0, 200, 83, 0.3); }
.badge-secondary { background: var(--c4n-secondary); color: #fff; box-shadow: 0 0 8px rgba(0, 176, 255, 0.3); }
.badge-success { background: var(--c4n-success); color: #fff; box-shadow: 0 0 8px rgba(16, 185, 129, 0.3); }
.badge-danger { background: var(--c4n-danger); color: #fff; box-shadow: 0 0 8px rgba(239, 68, 68, 0.3); }
.badge-warning { background: var(--c4n-warning); color: #000; box-shadow: 0 0 8px rgba(245, 158, 11, 0.3); }
.badge-info { background: var(--c4n-info); color: #fff; box-shadow: 0 0 8px rgba(59, 130, 246, 0.3); }
.badge-light {
    background: var(--c4n-surface);
    color: var(--c4n-text-secondary);
    border: 1px solid var(--c4n-border);
}
.badge-dark {
    background: var(--c4n-text);
    color: var(--c4n-bg);
}

/* Status badges used in WHMCS */
.status-active, .label-active { background: var(--c4n-success); color: #fff; }
.status-pending, .label-pending { background: var(--c4n-warning); color: #000; }
.status-suspended, .label-suspended { background: var(--c4n-danger); color: #fff; }
.status-terminated, .label-terminated { background: #6b7280; color: #fff; }
.status-cancelled, .label-cancelled { background: #9ca3af; color: #000; }

/* --------------------------------------------------------------------------
   13. Panels (WHMCS-specific)
   -------------------------------------------------------------------------- */
.panel {
    background: var(--c4n-card-bg);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    box-shadow: var(--c4n-card-shadow);
    transition: box-shadow var(--c4n-transition), transform var(--c4n-transition);
}

.panel:hover {
    transform: translateY(-2px);
    box-shadow: var(--c4n-card-shadow-hover);
}

/* Sidebar panels should NOT lift on hover */
.sidebar .panel:hover,
.sidebar .card:hover,
.cart-sidebar .panel:hover,
.cart-sidebar .card:hover {
    transform: none !important;
    box-shadow: var(--c4n-card-shadow) !important;
}

[data-theme="light"] .panel {
    border: 1px solid var(--c4n-border);
}

.panel-heading {
    background: var(--c4n-surface);
    border-bottom: 1px solid var(--c4n-border);
    padding: 1rem 1.25rem;
    border-radius: var(--c4n-radius) var(--c4n-radius) 0 0;
}

.panel-heading .panel-title {
    color: var(--c4n-text);
    font-weight: 600;
}

.panel-body {
    padding: 1.25rem;
    color: var(--c4n-text);
}

.panel-footer {
    background: var(--c4n-surface);
    border-top: 1px solid var(--c4n-border);
    padding: 0.75rem 1.25rem;
    border-radius: 0 0 var(--c4n-radius) var(--c4n-radius);
}

.panel-default > .panel-heading {
    background: var(--c4n-surface);
    color: var(--c4n-text);
}

/* --------------------------------------------------------------------------
   14. List Groups
   -------------------------------------------------------------------------- */
.list-group-item {
    background: var(--c4n-card-bg);
    border-color: var(--c4n-border);
    color: var(--c4n-text);
    padding: 0.75rem 1.25rem;
}

.list-group-item.active {
    background: rgba(var(--c4n-primary-rgb), 0.1);
    border-color: var(--c4n-primary);
    color: var(--c4n-primary);
}

.list-group-item-action:hover {
    background: var(--c4n-surface-hover);
    color: var(--c4n-text);
}

/* --------------------------------------------------------------------------
   15. Modals
   -------------------------------------------------------------------------- */
.modal-content {
    background: var(--c4n-modal-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--c4n-radius-lg);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

[data-theme="light"] .modal-content {
    border: 1px solid var(--c4n-border);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.modal-header {
    border-bottom: 1px solid var(--c4n-border);
    padding: 1.25rem 1.5rem;
}

.modal-header .modal-title {
    color: var(--c4n-text);
    font-weight: 600;
}

.modal-header .close {
    color: var(--c4n-text-muted);
    opacity: 0.7;
}

.modal-header .close:hover {
    color: var(--c4n-text);
    opacity: 1;
}

.modal-body {
    padding: 1.5rem;
    color: var(--c4n-text);
}

.modal-footer {
    border-top: 1px solid var(--c4n-border);
    padding: 1rem 1.5rem;
}

.modal-backdrop {
    background: rgba(0, 0, 0, 0.6);
}

/* Localisation Modal */
.modal-localisation .modal-content {
    background: linear-gradient(135deg, #0d1117 0%, #161b22 100%);
    color: #e6edf3;
}

.modal-localisation .item-selector .item {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--c4n-radius-sm);
    color: #e6edf3;
    padding: 0.5rem 1rem;
    display: block;
    text-align: center;
    margin-bottom: 0.5rem;
    transition: all var(--c4n-transition);
}

.modal-localisation .item-selector .item:hover,
.modal-localisation .item-selector .item.active {
    background: rgba(var(--c4n-primary-rgb), 0.2);
    border-color: var(--c4n-primary);
    color: var(--c4n-primary);
}

/* --------------------------------------------------------------------------
   16. Pagination
   -------------------------------------------------------------------------- */
.pagination {
    gap: 4px;
}

.page-link {
    background: var(--c4n-surface);
    border: 1px solid var(--c4n-border);
    color: var(--c4n-text-secondary);
    border-radius: var(--c4n-radius-sm) !important;
    padding: 0.45rem 0.85rem;
    font-size: 0.875rem;
    font-weight: 500;
}

.page-link:hover {
    background: var(--c4n-surface-hover);
    border-color: var(--c4n-border);
    color: var(--c4n-primary);
}

.page-item.active .page-link {
    background: var(--c4n-primary);
    border-color: var(--c4n-primary);
    color: #000;
}

.page-item.disabled .page-link {
    background: var(--c4n-surface);
    border-color: var(--c4n-border);
    color: var(--c4n-text-muted);
    opacity: 0.5;
}

/* --------------------------------------------------------------------------
   17. Sidebar
   -------------------------------------------------------------------------- */
.sidebar .card,
.sidebar .panel,
.cart-sidebar .card,
.cart-sidebar .panel {
    background: var(--c4n-sidebar-bg);
    border: 1px solid var(--c4n-border);
    border-radius: var(--c4n-radius);
}

.sidebar .panel-title,
.cart-sidebar .panel-title {
    font-size: 0.95rem !important;
    margin: 0;
}

.sidebar .list-group,
.cart-sidebar .list-group {
    font-size: 0.875rem !important;
}

.sidebar .list-group-item,
.cart-sidebar .list-group-item {
    background: transparent;
    border-color: var(--c4n-border-light);
    font-size: 0.875rem;
    padding: 0.6rem 1rem;
}

.sidebar .list-group-item:hover,
.cart-sidebar .list-group-item:hover {
    background: var(--c4n-sidebar-active);
}

.sidebar .list-group-item.active,
.cart-sidebar .list-group-item.active {
    background: rgba(0, 200, 83, 0.1);
    border-left: 3px solid var(--c4n-primary);
    box-shadow: inset 0 0 10px rgba(0, 200, 83, 0.05);
    color: var(--c4n-primary);
    font-weight: 600;
}

.sidebar .list-group-item .badge {
    font-size: 0.7rem;
}

/* --------------------------------------------------------------------------
   18. Tiles (Client Dashboard)
   -------------------------------------------------------------------------- */
.tiles {
    border-radius: var(--c4n-radius);
    overflow: hidden;
    border: 1px solid var(--c4n-border);
}

.tiles .tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1.5rem 1rem;
    background: var(--c4n-card-bg);
    color: var(--c4n-text);
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition: all var(--c4n-transition);
    border-right: 1px solid var(--c4n-border);
    border-bottom: 1px solid var(--c4n-border);
}

.tiles .tile:hover {
    background: var(--c4n-surface-hover);
    transform: translateY(-2px);
}

.tiles .tile i {
    font-size: 1.5rem;
    color: var(--c4n-text-muted);
    margin-bottom: 0.5rem;
}

.tiles .tile .stat {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--c4n-text);
}

.tiles .tile .title {
    font-size: 0.8rem;
    color: var(--c4n-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.tiles .tile .highlight {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
}

/* --------------------------------------------------------------------------
   19. Homepage Action Icons
   -------------------------------------------------------------------------- */
.action-icon-btns a {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1.5rem 1rem;
    background: var(--c4n-card-bg);
    border: 1px solid var(--c4n-border);
    border-radius: var(--c4n-radius);
    color: var(--c4n-text);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 500;
    text-align: center;
    transition: all var(--c4n-transition);
    margin-bottom: 1rem;
}

.action-icon-btns a:hover {
    transform: translateY(-4px);
    box-shadow: var(--c4n-card-shadow-hover);
    border-color: var(--c4n-primary);
    color: var(--c4n-primary);
}

.action-icon-btns .ico-container {
    margin: 0 0 0.75rem 0;
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--c4n-radius);
    background: rgba(var(--c4n-primary-rgb), 0.1);
}

.action-icon-btns .ico-container i {
    font-size: 1.5rem;
    color: var(--c4n-primary);
}

.action-icon-btns .card-accent-teal .ico-container { background: rgba(20, 184, 166, 0.1); }
.action-icon-btns .card-accent-teal .ico-container i { color: #14b8a6; }
.action-icon-btns .card-accent-pomegranate .ico-container { background: rgba(239, 68, 68, 0.1); }
.action-icon-btns .card-accent-pomegranate .ico-container i { color: #ef4444; }
.action-icon-btns .card-accent-sun-flower .ico-container { background: rgba(245, 158, 11, 0.1); }
.action-icon-btns .card-accent-sun-flower .ico-container i { color: #f59e0b; }
.action-icon-btns .card-accent-asbestos .ico-container { background: rgba(107, 114, 128, 0.1); }
.action-icon-btns .card-accent-asbestos .ico-container i { color: #6b7280; }
.action-icon-btns .card-accent-green .ico-container { background: rgba(var(--c4n-primary-rgb), 0.1); }
.action-icon-btns .card-accent-green .ico-container i { color: var(--c4n-primary); }
.action-icon-btns .card-accent-midnight-blue .ico-container { background: rgba(var(--c4n-accent-rgb), 0.1); }
.action-icon-btns .card-accent-midnight-blue .ico-container i { color: var(--c4n-accent); }

/* --------------------------------------------------------------------------
   20. Client Home Cards
   -------------------------------------------------------------------------- */
.client-home-cards .card {
    margin-bottom: 1.25rem;
}

.client-home-cards .card .card-header {
    background: var(--c4n-surface);
    padding: 0.875rem 1.25rem;
}

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

/* --------------------------------------------------------------------------
   21. Domain Search (Homepage)
   -------------------------------------------------------------------------- */
.domain-search-container {
    background: linear-gradient(135deg, #0d1117, #161b22);
    padding: 3rem 0;
}

.domain-search-container h2 {
    color: #e6edf3;
}

.domain-search-container .form-control {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: #e6edf3;
    border-radius: var(--c4n-radius-sm);
    height: 48px;
    font-size: 1rem;
}

.domain-search-container .form-control::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.domain-search-container .btn-primary {
    height: 48px;
}

.domain-pricing-container {
    background: var(--c4n-surface);
    border: 1px solid var(--c4n-border);
    border-radius: var(--c4n-radius);
    padding: 1.5rem;
    margin-top: 1rem;
}

/* --------------------------------------------------------------------------
   22. Footer
   -------------------------------------------------------------------------- */
#footer {
    background: var(--c4n-footer-bg);
    color: var(--c4n-footer-text);
    padding: 3rem 0 1.5rem;
    margin-top: 0;
}

#footer a {
    color: var(--c4n-footer-link);
    transition: color var(--c4n-transition);
}

#footer a:hover {
    color: var(--c4n-footer-link-hover);
}

#footer .nav .nav-link {
    color: var(--c4n-footer-link);
    padding: 0.25rem 0.75rem;
    font-size: 0.875rem;
    position: relative;
}

#footer .nav .nav-link::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0.75rem;
    right: 0.75rem;
    height: 1.5px;
    background: linear-gradient(90deg, var(--c4n-primary), var(--c4n-secondary));
    border-radius: 1px;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
}

#footer .nav .nav-link:hover {
    color: var(--c4n-footer-link-hover);
}

#footer .nav .nav-link:hover::before {
    transform: scaleX(1);
}

#footer .copyright {
    color: var(--c4n-footer-link);
    font-size: 0.8rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 1.5rem;
    margin-top: 1.5rem;
}

/* Mega Footer Styles */
.c4n-footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    margin-bottom: 2rem;
}

@media (max-width: 767px) {
    .c4n-footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .c4n-footer-grid {
        grid-template-columns: 1fr;
    }
}

.c4n-footer-col h5 {
    color: var(--c4n-footer-heading);
    font-size: 0.9rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 1rem;
}

.c4n-footer-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.c4n-footer-col ul li {
    margin-bottom: 0.5rem;
}

.c4n-footer-col ul li a {
    color: var(--c4n-footer-link);
    font-size: 0.875rem;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    position: relative;
    text-decoration: none;
}

.c4n-footer-col ul li a::before {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 1.5px;
    background: linear-gradient(90deg, var(--c4n-primary), var(--c4n-secondary));
    border-radius: 1px;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
}

.c4n-footer-col ul li a:hover {
    color: var(--c4n-footer-link-hover);
}

.c4n-footer-col ul li a:hover::before {
    transform: scaleX(1);
}

.c4n-footer-social {
    display: flex;
    gap: 0.75rem;
    margin-top: 1rem;
}

.c4n-footer-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.08);
    color: var(--c4n-footer-link);
    transition: all var(--c4n-transition);
}

.c4n-footer-social a:hover {
    background: var(--c4n-primary);
    color: #000;
    transform: translateY(-2px);
}

.c4n-footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 1.5rem;
    margin-top: 2rem;
}

.c4n-footer-bottom p {
    color: var(--c4n-footer-link);
    font-size: 0.8rem;
    margin: 0;
}

/* --------------------------------------------------------------------------
   23. Sub-Page Hero
   -------------------------------------------------------------------------- */
.c4n-subhero {
    background: linear-gradient(135deg, #0d1117 0%, #161b22 50%, #0d1117 100%);
    padding: 1.5rem 0 1.25rem;
    margin-top: -1rem;
    margin-bottom: 1rem;
    position: relative;
    overflow: hidden;
}

.c4n-subhero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background:
        radial-gradient(circle at 20% 80%, rgba(0, 200, 83, 0.15) 0%, transparent 50%),
        radial-gradient(circle at 80% 20%, rgba(0, 176, 255, 0.12) 0%, transparent 50%),
        radial-gradient(circle at 50% 50%, rgba(124, 77, 255, 0.06) 0%, transparent 60%);
    pointer-events: none;
}

.c4n-subhero .container {
    position: relative;
    z-index: 1;
}

.c4n-subhero-icon {
    display: none !important;
    /* Icons removed per user request */
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 16px;
    background: rgba(0, 200, 83, 0.1);
    border: 1px solid rgba(0, 200, 83, 0.2);
    backdrop-filter: blur(8px);
    font-size: 1.5rem;
    color: var(--c4n-primary);
    margin-bottom: 0.75rem;
    box-shadow: 0 4px 15px rgba(0, 200, 83, 0.1);
}

.c4n-subhero h1 {
    color: #e6edf3;
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: 0;
    line-height: 1.3;
}

.c4n-subhero p {
    color: #8b949e;
    font-size: 0.9rem;
    margin: 0;
}

/* --------------------------------------------------------------------------
   24. Auth Pages (Login, Register, Password Reset)
   -------------------------------------------------------------------------- */

/* Remove container constraint on auth pages so wrapper can span full width */
body:has(.c4n-auth-wrapper) {
    background: #060a0f !important;
    overflow-x: hidden;
}

[data-theme="light"] body:has(.c4n-auth-wrapper),
body:has(.c4n-auth-wrapper)[data-theme="light"] {
    background: #f0f2f5 !important;
}

#main-body:has(.c4n-auth-wrapper) {
    background: transparent;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    min-height: 0 !important;
}

#main-body:has(.c4n-auth-wrapper) > .container {
    max-width: none;
    padding: 0;
    margin: 0;
}

.c4n-auth-wrapper {
    min-height: calc(100vh - var(--header-height, 90px));
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 1rem;
    background: #060a0f;
    position: relative;
    overflow: hidden;
    width: 100%;
}

/* Animated mesh gradient background */
.c4n-auth-wrapper::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    right: -50%;
    bottom: -50%;
    background:
        radial-gradient(ellipse at 20% 50%, rgba(0, 200, 83, 0.15) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(0, 176, 255, 0.12) 0%, transparent 50%),
        radial-gradient(ellipse at 60% 80%, rgba(124, 77, 255, 0.1) 0%, transparent 50%),
        radial-gradient(ellipse at 40% 30%, rgba(0, 200, 83, 0.08) 0%, transparent 40%);
    pointer-events: none;
    animation: c4n-auth-bg-shift 15s ease-in-out infinite alternate;
}

@keyframes c4n-auth-bg-shift {
    0% { transform: translate(0, 0) rotate(0deg); }
    33% { transform: translate(2%, -2%) rotate(1deg); }
    66% { transform: translate(-1%, 1%) rotate(-0.5deg); }
    100% { transform: translate(1%, -1%) rotate(0.5deg); }
}

/* Subtle grid pattern overlay */
.c4n-auth-wrapper::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
    background-size: 60px 60px;
    pointer-events: none;
}

/* Hide sidebar on auth pages and make content full width */
.row:has(.c4n-auth-wrapper) > .col-lg-4,
.row:has(.c4n-auth-wrapper) > .col-xl-3 {
    display: none !important;
}

.row:has(.c4n-auth-wrapper) > .primary-content {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
}

/* Remove row padding/gap on auth pages */
.row:has(.c4n-auth-wrapper) {
    margin: 0 !important;
}

/* Auth logo — hidden per user request */
.c4n-auth-logo {
    display: none !important;
}

.c4n-auth-logo .c4n-gradient-text {
    font-size: 2.5rem !important;
    filter: drop-shadow(0 4px 15px rgba(0, 200, 83, 0.4));
}

.c4n-auth-card {
    width: 100%;
    max-width: 460px;
    position: relative;
    z-index: 2;
}

/* Premium glass card */
.c4n-auth-card .card,
.c4n-auth-card .card.mw-540 {
    background: rgba(15, 20, 28, 0.75) !important;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 20px;
    box-shadow:
        0 25px 60px rgba(0, 0, 0, 0.5),
        0 0 40px rgba(0, 200, 83, 0.05),
        inset 0 1px 0 rgba(255, 255, 255, 0.05);
    overflow: visible;
}

/* Gradient top accent on auth card */
.c4n-auth-card .card::before,
.c4n-auth-card .card.mw-540::before {
    content: '';
    position: absolute;
    top: 0;
    left: 20%;
    right: 20%;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--c4n-primary), var(--c4n-secondary), transparent);
    border-radius: 0 0 2px 2px;
    opacity: 1 !important;
    z-index: 1;
}

/* Auth card text contrast */
.c4n-auth-card .card h6,
.c4n-auth-card .card .h3 {
    color: #f0f6fc !important;
    font-weight: 700;
}

.c4n-auth-card .card p,
.c4n-auth-card .card .text-muted {
    color: #8b949e !important;
}

.c4n-auth-card .card label,
.c4n-auth-card .card .form-control-label {
    color: #c9d1d9 !important;
    font-weight: 500;
}

.c4n-auth-card .card .form-control {
    background: rgba(13, 17, 23, 0.6) !important;
    border: 1px solid rgba(48, 54, 61, 0.8) !important;
    color: #e6edf3 !important;
}

.c4n-auth-card .card .form-control:focus {
    border-color: var(--c4n-primary) !important;
    box-shadow: 0 0 0 3px rgba(0, 200, 83, 0.2), 0 0 20px rgba(0, 200, 83, 0.1) !important;
}

.c4n-auth-card .card .form-control::placeholder {
    color: #484f58 !important;
}

.c4n-auth-card .card .input-group-text {
    background: rgba(13, 17, 23, 0.6) !important;
    border-color: rgba(48, 54, 61, 0.8) !important;
    color: #8b949e !important;
}

.c4n-auth-card .card a {
    color: var(--c4n-primary);
}

.c4n-auth-card .card a:hover {
    color: #00e676;
}

.c4n-auth-card .card .small.text-muted {
    color: #6e7681 !important;
}

.c4n-auth-card .card .small.text-muted a {
    color: var(--c4n-primary) !important;
}

.c4n-auth-card .card .card-footer {
    background: rgba(13, 17, 23, 0.4) !important;
    border-top: 1px solid rgba(48, 54, 61, 0.5) !important;
}

.c4n-auth-card .card .card-footer small {
    color: #8b949e;
}

.c4n-auth-card .card .btn-reveal-pw {
    background: rgba(13, 17, 23, 0.6) !important;
    border-color: rgba(48, 54, 61, 0.8) !important;
    color: #8b949e !important;
}

.c4n-auth-card .card .btn-reveal-pw:hover {
    color: var(--c4n-primary) !important;
}

/* Checkbox styling */
.c4n-auth-card .card label {
    color: #8b949e !important;
    font-weight: 400;
}

.c4n-auth-card .card .form-group > label,
.c4n-auth-card .card .form-control-label {
    font-weight: 500 !important;
    color: #c9d1d9 !important;
}

/* Light mode auth */
[data-theme="light"] .c4n-auth-wrapper {
    background: #e8ecf1;
}

[data-theme="light"] .c4n-auth-wrapper::before {
    background:
        radial-gradient(ellipse at 20% 50%, rgba(0, 200, 83, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(0, 176, 255, 0.06) 0%, transparent 50%),
        radial-gradient(ellipse at 60% 80%, rgba(124, 77, 255, 0.05) 0%, transparent 50%);
}

[data-theme="light"] .c4n-auth-wrapper::after {
    background-image:
        linear-gradient(rgba(0, 0, 0, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 0, 0, 0.03) 1px, transparent 1px);
}

[data-theme="light"] .c4n-auth-card .card,
[data-theme="light"] .c4n-auth-card .card.mw-540 {
    background: rgba(255, 255, 255, 0.85) !important;
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.12), 0 0 40px rgba(0, 200, 83, 0.04);
}

[data-theme="light"] .c4n-auth-card .card h6,
[data-theme="light"] .c4n-auth-card .card .h3 {
    color: #1f2937 !important;
}

[data-theme="light"] .c4n-auth-card .card p,
[data-theme="light"] .c4n-auth-card .card .text-muted {
    color: #6b7280 !important;
}

[data-theme="light"] .c4n-auth-card .card label,
[data-theme="light"] .c4n-auth-card .card .form-control-label {
    color: #374151 !important;
}

[data-theme="light"] .c4n-auth-card .card .form-control {
    background: rgba(255, 255, 255, 0.9) !important;
    border: 1px solid #d1d5db !important;
    color: #1f2937 !important;
}

[data-theme="light"] .c4n-auth-card .card .form-control::placeholder {
    color: #9ca3af !important;
}

[data-theme="light"] .c4n-auth-card .card .input-group-text {
    background: rgba(255, 255, 255, 0.9) !important;
    border-color: #d1d5db !important;
    color: #6b7280 !important;
}

[data-theme="light"] .c4n-auth-card .card .card-footer {
    background: rgba(249, 250, 251, 0.8) !important;
    border-top: 1px solid #e5e7eb !important;
}

[data-theme="light"] .c4n-auth-logo img {
    filter: drop-shadow(0 4px 15px rgba(0, 0, 0, 0.1));
}

/* Register page — wide card variant */
.c4n-auth-card-wide {
    max-width: 800px;
}

/* ALL cards inside auth wrapper — dark glass treatment */
.c4n-auth-wrapper .card {
    background: rgba(15, 20, 28, 0.75) !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 16px;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.c4n-auth-wrapper .card .card-title,
.c4n-auth-wrapper .card h3 {
    color: #f0f6fc !important;
}

.c4n-auth-wrapper .card p {
    color: #8b949e !important;
}

.c4n-auth-wrapper .card label {
    color: #c9d1d9 !important;
}

/* ALL inputs inside auth wrapper — DARK MODE styling */
[data-theme="dark"] .c4n-auth-wrapper .form-control,
[data-theme="dark"] .c4n-auth-wrapper .custom-select,
[data-theme="dark"] .c4n-auth-wrapper select.form-control,
[data-theme="dark"] .c4n-auth-wrapper #registration .form-control,
[data-theme="dark"] .c4n-auth-wrapper #registration .field,
[data-theme="dark"] .c4n-auth-wrapper #registration select,
[data-theme="dark"] .c4n-auth-wrapper #registration .custom-select,
[data-theme="dark"] #registration .c4n-auth-card-wide .form-control,
[data-theme="dark"] #registration .c4n-auth-card-wide .field,
[data-theme="dark"] #registration .c4n-auth-card-wide select {
    background: rgba(13, 17, 23, 0.6) !important;
    border: 1px solid rgba(48, 54, 61, 0.8) !important;
    color: #e6edf3 !important;
}

[data-theme="dark"] .c4n-auth-wrapper .form-control:focus,
[data-theme="dark"] .c4n-auth-wrapper .custom-select:focus,
[data-theme="dark"] .c4n-auth-wrapper #registration .form-control:focus,
[data-theme="dark"] .c4n-auth-wrapper #registration .field:focus {
    border-color: var(--c4n-primary) !important;
    box-shadow: 0 0 0 3px rgba(0, 200, 83, 0.2), 0 0 20px rgba(0, 200, 83, 0.1) !important;
}

[data-theme="dark"] .c4n-auth-wrapper .form-control::placeholder,
[data-theme="dark"] .c4n-auth-wrapper #registration .form-control::placeholder,
[data-theme="dark"] .c4n-auth-wrapper #registration .field::placeholder {
    color: #484f58 !important;
}

[data-theme="dark"] .c4n-auth-wrapper .input-group-text {
    background: rgba(13, 17, 23, 0.6) !important;
    border-color: rgba(48, 54, 61, 0.8) !important;
    color: #8b949e !important;
}

/* Registration icon labels — dark mode */
[data-theme="dark"] .c4n-auth-wrapper #registration .field-icon i,
[data-theme="dark"] #registration .c4n-auth-card-wide .field-icon i {
    color: #8b949e !important;
}

/* intl-tel-input — z-index fix so dropdown is not clipped by next card */
.c4n-auth-wrapper .card {
    overflow: visible !important;
}

.c4n-auth-wrapper .card .card-body {
    overflow: visible !important;
}

/* First card (Personal Info) must stack above following cards */
.c4n-auth-wrapper .card.mb-4 {
    position: relative;
    z-index: 1;
}

.c4n-auth-wrapper .card.mb-4:first-child,
.c4n-auth-wrapper #containerNewUserSignup > .card:first-child {
    z-index: 10;
}

/* intl-tel-input container */
.c4n-auth-wrapper .iti,
.c4n-auth-wrapper .intl-tel-input {
    z-index: 100;
    position: relative;
}

/* Country list dropdown — must be above everything */
.iti__country-list,
.c4n-auth-wrapper .iti__country-list,
.c4n-auth-wrapper .intl-tel-input .country-list,
.iti--container .iti__country-list {
    z-index: 99999 !important;
}

/* The iti--container (appended to body) needs high z-index */
.iti--container {
    z-index: 99999 !important;
}

/* intl-tel-input phone picker — dark mode */
[data-theme="dark"] .c4n-auth-wrapper .iti__flag-container,
[data-theme="dark"] .c4n-auth-wrapper .iti__selected-flag,
[data-theme="dark"] .c4n-auth-wrapper .intl-tel-input .selected-flag {
    background: rgba(13, 17, 23, 0.6) !important;
    border-color: rgba(48, 54, 61, 0.8) !important;
}

[data-theme="dark"] .c4n-auth-wrapper .iti__country-list,
[data-theme="dark"] .c4n-auth-wrapper .intl-tel-input .country-list {
    background: #161b22 !important;
    border-color: rgba(48, 54, 61, 0.8) !important;
    color: #e6edf3 !important;
}

[data-theme="dark"] .c4n-auth-wrapper .iti__country-list .iti__country:hover,
[data-theme="dark"] .c4n-auth-wrapper .intl-tel-input .country-list .country.highlight {
    background: rgba(0, 200, 83, 0.1) !important;
}

/* Select option elements — dark mode */
[data-theme="dark"] .c4n-auth-wrapper select option,
[data-theme="dark"] #registration select option {
    background: #161b22;
    color: #e6edf3;
}

/* ALL inputs inside auth wrapper — LIGHT MODE styling */
[data-theme="light"] .c4n-auth-wrapper #registration .form-control,
[data-theme="light"] .c4n-auth-wrapper #registration .field,
[data-theme="light"] .c4n-auth-wrapper #registration select,
[data-theme="light"] .c4n-auth-wrapper #registration .custom-select,
[data-theme="light"] #registration .c4n-auth-card-wide .form-control,
[data-theme="light"] #registration .c4n-auth-card-wide .field,
[data-theme="light"] #registration .c4n-auth-card-wide select {
    background: rgba(255, 255, 255, 0.9) !important;
    border: 1px solid #d1d5db !important;
    color: #1f2937 !important;
}

[data-theme="light"] .c4n-auth-wrapper #registration .form-control:focus,
[data-theme="light"] .c4n-auth-wrapper #registration .field:focus {
    border-color: var(--c4n-primary) !important;
    box-shadow: 0 0 0 3px rgba(0, 200, 83, 0.15), 0 0 10px rgba(0, 200, 83, 0.08) !important;
}

[data-theme="light"] .c4n-auth-wrapper #registration .form-control::placeholder,
[data-theme="light"] .c4n-auth-wrapper #registration .field::placeholder {
    color: #9ca3af !important;
}

[data-theme="light"] .c4n-auth-wrapper #registration .field-icon i,
[data-theme="light"] #registration .c4n-auth-card-wide .field-icon i {
    color: #6b7280 !important;
}

[data-theme="light"] .c4n-auth-wrapper .iti__flag-container,
[data-theme="light"] .c4n-auth-wrapper .iti__selected-flag,
[data-theme="light"] .c4n-auth-wrapper .intl-tel-input .selected-flag {
    background: rgba(255, 255, 255, 0.9) !important;
    border-color: #d1d5db !important;
}

[data-theme="light"] .c4n-auth-wrapper select option,
[data-theme="light"] #registration select option {
    background: #ffffff;
    color: #1f2937;
}

/* Bootstrap Switch — Dark Mode */
[data-theme="dark"] .c4n-auth-wrapper .bootstrap-switch,
[data-theme="dark"] .bootstrap-switch {
    background: rgba(13, 17, 23, 0.6);
    border-color: rgba(48, 54, 61, 0.8);
}

[data-theme="dark"] .c4n-auth-wrapper .bootstrap-switch .bootstrap-switch-label,
[data-theme="dark"] .bootstrap-switch .bootstrap-switch-label {
    background: rgba(22, 27, 34, 0.8);
    color: #8b949e;
}

[data-theme="dark"] .c4n-auth-wrapper .bootstrap-switch .bootstrap-switch-handle-off,
[data-theme="dark"] .bootstrap-switch .bootstrap-switch-handle-off {
    background: rgba(48, 54, 61, 0.8);
    color: #8b949e;
}

[data-theme="dark"] .c4n-auth-wrapper .bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-success,
[data-theme="dark"] .bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-success {
    background: var(--c4n-primary);
    color: #000;
}

/* Select dropdowns in dark auth */
[data-theme="dark"] .c4n-auth-wrapper select option {
    background: #161b22;
    color: #e6edf3;
}

/* Password strength meter */
[data-theme="dark"] .c4n-auth-wrapper .pw-strength {
    background: rgba(13, 17, 23, 0.6);
}

/* Password strength progress bar (register page) */
[data-theme="dark"] .progress,
[data-theme="dark"] .c4n-auth-wrapper .progress,
[data-theme="dark"] .password-strength-meter .progress {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 6px;
    height: 8px;
}
[data-theme="dark"] #passwordStrengthBar {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 6px;
    height: 8px;
}
[data-theme="dark"] #passwordStrengthBar .progress-bar {
    border-radius: 6px;
}

/* Linked accounts section */
[data-theme="dark"] .c4n-auth-wrapper .linked-accounts-container {
    color: #8b949e;
}

/* Light mode register overrides */
[data-theme="light"] .c4n-auth-wrapper .card {
    background: rgba(255, 255, 255, 0.85) !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .c4n-auth-wrapper .card .card-title,
[data-theme="light"] .c4n-auth-wrapper .card h3 {
    color: #1f2937 !important;
}

[data-theme="light"] .c4n-auth-wrapper .card p {
    color: #6b7280 !important;
}

[data-theme="light"] .c4n-auth-wrapper .card label {
    color: #374151 !important;
}

[data-theme="light"] .c4n-auth-wrapper .form-control,
[data-theme="light"] .c4n-auth-wrapper .custom-select,
[data-theme="light"] .c4n-auth-wrapper select.form-control {
    background: rgba(255, 255, 255, 0.9) !important;
    border: 1px solid #d1d5db !important;
    color: #1f2937 !important;
}

[data-theme="light"] .c4n-auth-wrapper .input-group-text {
    background: rgba(255, 255, 255, 0.9) !important;
    border-color: #d1d5db !important;
    color: #6b7280 !important;
}

/* --------------------------------------------------------------------------
   25. Support Tickets
   -------------------------------------------------------------------------- */
.ticket-reply {
    background: var(--c4n-card-bg);
    border: 1px solid var(--c4n-border);
    border-radius: var(--c4n-radius);
    padding: 1.25rem;
    margin-bottom: 1rem;
    position: relative;
}

.ticket-reply.staff {
    border-left: 3px solid var(--c4n-primary);
    background: rgba(var(--c4n-primary-rgb), 0.03);
}

.ticket-reply.client {
    border-left: 3px solid var(--c4n-secondary);
}

.ticket-reply .ticket-reply-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.75rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--c4n-border);
}

/* --------------------------------------------------------------------------
   26. Popover Override
   -------------------------------------------------------------------------- */
.popover {
    background: var(--c4n-dropdown-bg);
    border: 1px solid var(--c4n-border);
    border-radius: var(--c4n-radius);
    box-shadow: var(--c4n-card-shadow-hover);
}

.popover-body {
    color: var(--c4n-text);
}

.bs-popover-bottom > .arrow::after {
    border-bottom-color: var(--c4n-dropdown-bg);
}

/* --------------------------------------------------------------------------
   27. Tooltip Override
   -------------------------------------------------------------------------- */
.tooltip-inner {
    background: var(--c4n-text);
    color: var(--c4n-bg);
    border-radius: var(--c4n-radius-sm);
    font-size: 0.8rem;
    padding: 0.35rem 0.75rem;
}

/* --------------------------------------------------------------------------
   28. Password Reveal Button
   -------------------------------------------------------------------------- */
.btn-reveal-pw {
    background: var(--c4n-surface) !important;
    border: 1px solid var(--c4n-input-border) !important;
    color: var(--c4n-text-muted) !important;
}

.btn-reveal-pw:hover {
    color: var(--c4n-primary) !important;
}

/* --------------------------------------------------------------------------
   29. Invoice / Billing Styles
   -------------------------------------------------------------------------- */
.invoice-container {
    background: var(--c4n-card-bg);
    border: 1px solid var(--c4n-border);
    border-radius: var(--c4n-radius);
    padding: 2rem;
}

/* --------------------------------------------------------------------------
   30. Full-page Overlay
   -------------------------------------------------------------------------- */
#fullpage-overlay .outer-wrapper {
    background: var(--c4n-modal-overlay);
}

#fullpage-overlay .inner-wrapper {
    color: var(--c4n-text);
}

/* --------------------------------------------------------------------------
   31. Return-to-Admin Button — small tab on right edge
   -------------------------------------------------------------------------- */
.btn-return-to-admin {
    position: fixed !important;
    top: 180px !important;
    right: 0 !important;
    left: auto !important;
    bottom: auto !important;
    z-index: 9999 !important;
    writing-mode: vertical-rl !important;
    text-orientation: sideways !important;
    transform: none !important;
    background: var(--c4n-warning) !important;
    color: #000 !important;
    border-radius: 6px 0 0 6px !important;
    padding: 6px 4px !important;
    font-size: 0.7rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.02em !important;
    white-space: nowrap !important;
    box-shadow: -2px 2px 8px rgba(0, 0, 0, 0.15) !important;
    width: auto !important;
    height: auto !important;
    line-height: 1.4 !important;
    text-decoration: none !important;
    opacity: 0.7;
    transition: opacity 0.2s ease;
}
.btn-return-to-admin:hover {
    opacity: 1;
    color: #000 !important;
    text-decoration: none !important;
    transform: none !important;
}
.btn-return-to-admin i {
    margin-right: 0;
    margin-bottom: 4px;
    font-size: 0.65rem;
}
footer + .btn-return-to-admin {
    position: fixed !important;
}

/* --------------------------------------------------------------------------
   32. Card Columns (Homepage Product Groups)
   -------------------------------------------------------------------------- */
.card-columns.home {
    column-count: 3;
}

@media (max-width: 991px) {
    .card-columns.home {
        column-count: 2;
    }
}

@media (max-width: 575px) {
    .card-columns.home {
        column-count: 1;
    }
}

/* --------------------------------------------------------------------------
   33. Nav Tabs / Pills
   -------------------------------------------------------------------------- */
.nav-tabs {
    border-bottom: 2px solid var(--c4n-border);
}

.nav-tabs .nav-link {
    color: var(--c4n-text-muted);
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    padding: 0.75rem 1.25rem;
    font-weight: 500;
    font-size: 0.9rem;
    transition: all var(--c4n-transition);
}

.nav-tabs .nav-link:hover {
    color: var(--c4n-primary);
    border-color: transparent;
    border-bottom-color: rgba(var(--c4n-primary-rgb), 0.3);
}

.nav-tabs .nav-link.active {
    background: transparent;
    color: var(--c4n-primary);
    border-color: transparent;
    border-bottom-color: var(--c4n-primary);
}

.nav-pills .nav-link {
    color: var(--c4n-text-secondary);
    border-radius: var(--c4n-radius-sm);
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
}

.nav-pills .nav-link.active {
    background: var(--c4n-primary);
    color: #000;
}

.tab-content {
    padding-top: 1rem;
}

/* --------------------------------------------------------------------------
   34. Accordion
   -------------------------------------------------------------------------- */
.accordion .card {
    border-radius: var(--c4n-radius) !important;
    margin-bottom: 0.5rem;
    overflow: hidden;
}

.accordion .card-header {
    cursor: pointer;
    padding: 0;
}

.accordion .card-header .btn {
    width: 100%;
    text-align: left;
    padding: 1rem 1.25rem;
    color: var(--c4n-text);
    font-weight: 600;
    font-size: 0.95rem;
    text-decoration: none;
}

.accordion .card-header .btn:hover {
    color: var(--c4n-primary);
}

.accordion .card-header .btn.collapsed {
    color: var(--c4n-text-secondary);
    font-weight: 500;
}

/* --------------------------------------------------------------------------
   35. Responsive Adjustments
   -------------------------------------------------------------------------- */
@media (max-width: 991px) {
    #header .navbar .search {
        display: none !important;
    }

    .c4n-main-nav .collapse.show {
        background: var(--c4n-surface);
        border-top: 1px solid var(--c4n-border);
        padding: 1rem;
    }

    .c4n-main-nav .navbar-nav .d-block > a {
        padding: 0.65rem 0;
        border-bottom: 1px solid var(--c4n-border-light);
        font-size: 1.15rem;
    }

    .c4n-main-nav .navbar-nav .d-block > a::after {
        display: none;
    }
}

@media (max-width: 767px) {
    #main-body {
        padding-top: 0.5rem;
    }

    .card-body {
        padding: 1rem;
    }

    h1, .h1 { font-size: 1.75rem; }
    h2, .h2 { font-size: 1.5rem; }

    .c4n-subhero h1 {
        font-size: 1.375rem;
    }
}

/* --------------------------------------------------------------------------
   36. Utility Classes
   -------------------------------------------------------------------------- */
.c4n-gradient-text {
    background: linear-gradient(135deg, var(--c4n-primary), var(--c4n-secondary));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.c4n-glow {
    box-shadow: 0 0 20px rgba(var(--c4n-primary-rgb), 0.3);
}

.c4n-glass {
    background: var(--c4n-nav-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--c4n-nav-border);
}

.c4n-section {
    padding: 4rem 0;
}

.c4n-section h1,
.c4n-section h2,
.c4n-section-alt h1,
.c4n-section-alt h2 {
    font-size: 4.2rem !important;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin-top: 0;
}

.c4n-section-alt {
    padding: 4rem 0;
    background: var(--c4n-bg-alt);
}

/* --------------------------------------------------------------------------
   Homepage Section Backgrounds
   Each section gets its own full-width wrapper with distinct background
   -------------------------------------------------------------------------- */

/* Services "What We Do" — base surface */
.c4n-bg-services {
    background: var(--c4n-bg);
    position: relative;
}

/* AzuraCast Featured — gradient with subtle green/blue glow */
.c4n-bg-azuracast {
    background: var(--c4n-bg-alt);
    position: relative;
    overflow: hidden;
}
.c4n-bg-azuracast::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(ellipse at 20% 50%, rgba(var(--c4n-primary-rgb), 0.04) 0%, transparent 60%),
                radial-gradient(ellipse at 80% 50%, rgba(var(--c4n-secondary-rgb), 0.03) 0%, transparent 60%);
    pointer-events: none;
}

/* Counter/Stats — darkest surface with subtle pattern */
.c4n-bg-counter {
    background: var(--c4n-bg);
    position: relative;
    overflow: hidden;
}
.c4n-bg-counter::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image:
        linear-gradient(rgba(var(--c4n-primary-rgb), 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(var(--c4n-primary-rgb), 0.02) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

/* Products Section — surface with accent glow */
.c4n-bg-products {
    background: var(--c4n-bg-alt);
    position: relative;
    overflow: hidden;
}
.c4n-bg-products::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(ellipse at 50% 50%, rgba(var(--c4n-accent-rgb), 0.03) 0%, transparent 60%);
    pointer-events: none;
}

/* CTA Section — deep dark with purple/green tint */
.c4n-bg-cta {
    background: var(--c4n-bg);
    position: relative;
    overflow: hidden;
}
.c4n-bg-cta::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(ellipse at 30% 80%, rgba(var(--c4n-accent-rgb), 0.04) 0%, transparent 50%),
                radial-gradient(ellipse at 70% 20%, rgba(var(--c4n-primary-rgb), 0.03) 0%, transparent 50%);
    pointer-events: none;
}

/* Light mode adjustments — stronger differentiation */
[data-theme="light"] .c4n-bg-services {
    background: #ffffff;
}
[data-theme="light"] .c4n-bg-azuracast {
    background: #f0f4f8;
}
[data-theme="light"] .c4n-bg-counter {
    background: #ffffff;
}
[data-theme="light"] .c4n-bg-products {
    background: #f5f3ff;
}
[data-theme="light"] .c4n-bg-cta {
    background: #f0f1f3;
}

/* Dark mode — subtle tonal shifts */
[data-theme="dark"] .c4n-bg-services {
    background: #0d1117;
}
[data-theme="dark"] .c4n-bg-azuracast {
    background: #0a0e14;
}
[data-theme="dark"] .c4n-bg-counter {
    background: #0d1117;
}
[data-theme="dark"] .c4n-bg-products {
    background: #0c1018;
}
[data-theme="dark"] .c4n-bg-cta {
    background: #080b10;
}

/* --------------------------------------------------------------------------
   Service Card Images
   -------------------------------------------------------------------------- */
.c4n-service-img {
    width: 100%;
    height: 180px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--c4n-surface);
}

.c4n-service-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.c4n-card-lift:hover .c4n-service-img img {
    transform: scale(1.05);
}

/* --------------------------------------------------------------------------
   AzuraCast Dashboard Image
   -------------------------------------------------------------------------- */
.c4n-azuracast-img {
    border-radius: var(--c4n-radius-lg);
    overflow: hidden;
}

.c4n-azuracast-img img {
    width: 100%;
    height: auto;
    border-radius: var(--c4n-radius-lg);
    filter: drop-shadow(0 20px 60px rgba(0, 0, 0, 0.3));
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.c4n-azuracast-img:hover img {
    transform: scale(1.02);
}

/* --------------------------------------------------------------------------
   37. Markdown Editor — Dark Mode Override
   -------------------------------------------------------------------------- */
.md-editor {
    border-color: var(--c4n-border);
    border-radius: var(--c4n-radius);
    overflow: hidden;
}

.md-editor > .btn-toolbar {
    background-color: var(--c4n-surface) !important;
    border-bottom: 1px solid var(--c4n-border) !important;
    padding: 0.4rem 0.5rem !important;
}

.md-editor > .btn-toolbar .btn {
    color: var(--c4n-text-muted) !important;
    border: none !important;
    background: transparent !important;
    padding: 0.35rem 0.5rem;
    border-radius: var(--c4n-radius-sm);
}

.md-editor > .btn-toolbar .btn:hover {
    color: var(--c4n-primary) !important;
    background: rgba(var(--c4n-primary-rgb), 0.08) !important;
}

.md-editor > .btn-toolbar .btn.active {
    color: var(--c4n-primary) !important;
    background: rgba(var(--c4n-primary-rgb), 0.12) !important;
}

.md-editor > textarea.markdown-editor,
.md-editor > .md-preview {
    background-color: var(--c4n-input-bg) !important;
    border-color: var(--c4n-border) !important;
    color: var(--c4n-text) !important;
}

.md-editor > textarea.markdown-editor::placeholder {
    color: var(--c4n-text-muted);
}

.markdown-editor-status {
    color: var(--c4n-text-muted);
    background: var(--c4n-surface);
}

/* Markdown rendered content — headings, code, tables */
.md-preview h1, .md-preview h2, .md-preview h3, .md-preview h4,
.markdown-content h1, .markdown-content h2, .markdown-content h3, .markdown-content h4 {
    color: var(--c4n-text);
}

.md-preview p, .markdown-content p {
    color: var(--c4n-text-secondary);
}

.md-preview a, .markdown-content a {
    color: var(--c4n-primary);
}

.md-preview blockquote, .markdown-content blockquote {
    border-left: 4px solid var(--c4n-primary);
    background: rgba(var(--c4n-primary-rgb), 0.05);
    color: var(--c4n-text-secondary);
    padding: 0.75rem 1rem;
    border-radius: 0 var(--c4n-radius-sm) var(--c4n-radius-sm) 0;
}

.md-preview pre, .markdown-content pre {
    background: var(--c4n-code-bg);
    color: var(--c4n-code-text);
    border: 1px solid var(--c4n-border);
    border-radius: var(--c4n-radius-sm);
}

.md-preview table, .markdown-content table {
    color: var(--c4n-text);
    border-color: var(--c4n-border);
}

.md-preview table th, .markdown-content table th {
    background: var(--c4n-surface);
    border-color: var(--c4n-border);
}

.md-preview table td, .markdown-content table td {
    border-color: var(--c4n-border);
}

/* --------------------------------------------------------------------------
   38. Announcements — Dark Mode Override
   -------------------------------------------------------------------------- */
.announcements .announcement article {
    background-color: var(--c4n-surface) !important;
    border-left: 4px solid var(--c4n-primary) !important;
    border-radius: 0 var(--c4n-radius-sm) var(--c4n-radius-sm) 0;
    color: var(--c4n-text-secondary);
}

.announcements .announcement article p {
    color: var(--c4n-text-secondary);
}

/* Single announcement view */
.announcements .announcement .card-body,
.announcements .announcement .py-5 {
    color: var(--c4n-text);
}

/* Announcement title link */
.announcements .announcement h3 a,
.announcements .announcement h4 a {
    color: var(--c4n-primary);
}

.announcements .announcement h3 a:hover,
.announcements .announcement h4 a:hover {
    color: var(--c4n-primary-hover);
}

/* Announcement meta info (date, etc.) */
.announcements .announcement .text-muted {
    color: var(--c4n-text-muted) !important;
}

/* --------------------------------------------------------------------------
   39. Universal Dark Mode Form Controls Override
   Ensures ALL form inputs are dark regardless of base theme specificity
   -------------------------------------------------------------------------- */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] textarea.form-control,
[data-theme="dark"] select.form-control,
[data-theme="dark"] .custom-select,
[data-theme="dark"] .field,
[data-theme="dark"] .prepend-icon .field,
[data-theme="dark"] .form-group .form-control,
[data-theme="dark"] .card .form-control,
[data-theme="dark"] .card-body .form-control,
[data-theme="dark"] .card textarea.form-control {
    background-color: rgba(13, 17, 23, 0.8) !important;
    border-color: rgba(48, 54, 61, 0.6) !important;
    color: #e6edf3 !important;
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .field:focus,
[data-theme="dark"] .prepend-icon .field:focus {
    border-color: var(--c4n-primary) !important;
    box-shadow: 0 0 0 3px rgba(0, 200, 83, 0.2), 0 0 15px rgba(0, 200, 83, 0.1) !important;
}

[data-theme="dark"] .form-control::placeholder,
[data-theme="dark"] .field::placeholder {
    color: #8b949e !important;
}

[data-theme="dark"] label,
[data-theme="dark"] .form-control-label,
[data-theme="dark"] .col-form-label {
    color: #b1bac4 !important;
}

[data-theme="dark"] .input-group-text {
    background-color: rgba(22, 27, 34, 0.8) !important;
    border-color: rgba(48, 54, 61, 0.6) !important;
    color: #8b949e !important;
}

/* Captcha area in dark mode */
[data-theme="dark"] .text-center.margin-bottom {
    color: #b1bac4;
}

/* --------------------------------------------------------------------------
   40. EasyMDE Markdown Editor — Dark Mode
   -------------------------------------------------------------------------- */
.EasyMDEContainer {
    border: 1px solid var(--c4n-border) !important;
    border-radius: var(--c4n-radius) !important;
    overflow: hidden;
}

.EasyMDEContainer .editor-toolbar {
    background: var(--c4n-surface) !important;
    border-color: var(--c4n-border) !important;
    opacity: 1;
}

.EasyMDEContainer .editor-toolbar button,
.EasyMDEContainer .editor-toolbar button.active,
.EasyMDEContainer .editor-toolbar i.separator {
    color: var(--c4n-text-secondary) !important;
    border-color: transparent !important;
    background: transparent !important;
}

.EasyMDEContainer .editor-toolbar button:hover,
.EasyMDEContainer .editor-toolbar button.active {
    color: var(--c4n-primary) !important;
    background: rgba(var(--c4n-primary-rgb), 0.1) !important;
}

.EasyMDEContainer .CodeMirror {
    background: var(--c4n-input-bg) !important;
    color: var(--c4n-text) !important;
    border-color: var(--c4n-border) !important;
    border-top: none !important;
    border-bottom: none !important;
}

.EasyMDEContainer .CodeMirror-cursor {
    border-left-color: var(--c4n-primary) !important;
}

.EasyMDEContainer .CodeMirror-selected {
    background: rgba(var(--c4n-primary-rgb), 0.2) !important;
}

.EasyMDEContainer .CodeMirror .CodeMirror-code .cm-comment {
    background: transparent;
}

.EasyMDEContainer .editor-statusbar,
.editor-statusbar,
div.editor-statusbar {
    background: var(--c4n-surface) !important;
    background-color: var(--c4n-surface) !important;
    border-color: var(--c4n-border) !important;
    border-top: 1px solid var(--c4n-border) !important;
    color: var(--c4n-text-muted) !important;
    padding: 4px 10px !important;
}

.EasyMDEContainer .editor-statusbar span,
.editor-statusbar span,
div.editor-statusbar span {
    color: var(--c4n-text-muted) !important;
}

.EasyMDEContainer .editor-preview {
    background: var(--c4n-input-bg) !important;
    color: var(--c4n-text) !important;
}

.EasyMDEContainer .editor-toolbar.fullscreen,
.EasyMDEContainer .CodeMirror-fullscreen,
.EasyMDEContainer .editor-preview-active-side {
    background: var(--c4n-bg) !important;
    color: var(--c4n-text) !important;
}

/* Also handle WHMCS native md-editor wrapper */
.md-editor {
    border: 1px solid var(--c4n-border) !important;
    border-radius: var(--c4n-radius) !important;
    overflow: hidden;
}

.md-editor > .btn-toolbar {
    background: var(--c4n-surface) !important;
    border-bottom: 1px solid var(--c4n-border) !important;
}

.md-editor .md-footer,
.md-editor > .md-header {
    background: var(--c4n-surface) !important;
    border-color: var(--c4n-border) !important;
    color: var(--c4n-text-muted) !important;
}

.md-editor .md-footer * {
    color: var(--c4n-text-muted) !important;
}

/* --------------------------------------------------------------------------
   41. File Input / Custom File Upload — Dark Mode
   -------------------------------------------------------------------------- */
.custom-file-label {
    background-color: var(--c4n-input-bg) !important;
    border-color: var(--c4n-border) !important;
    color: var(--c4n-text-secondary) !important;
}

.custom-file-label::after {
    background-color: var(--c4n-surface) !important;
    border-color: var(--c4n-border) !important;
    color: var(--c4n-text) !important;
}

.custom-file-input:focus ~ .custom-file-label {
    border-color: var(--c4n-primary) !important;
    box-shadow: 0 0 0 3px rgba(var(--c4n-primary-rgb), 0.2) !important;
}

input[type="file"] {
    color: var(--c4n-text-secondary);
}

input[type="file"]::file-selector-button {
    background-color: var(--c4n-surface) !important;
    border: 1px solid var(--c4n-border) !important;
    color: var(--c4n-text) !important;
    border-radius: var(--c4n-radius-sm);
    padding: 0.375rem 0.75rem;
    cursor: pointer;
}

input[type="file"]::file-selector-button:hover {
    background-color: rgba(var(--c4n-primary-rgb), 0.1) !important;
    border-color: var(--c4n-primary) !important;
    color: var(--c4n-primary) !important;
}

/* Empty homepage sections — hide if no content */
.c4n-section-alt:empty {
    display: none;
}

/* --------------------------------------------------------------------------
   40. Print Styles
   -------------------------------------------------------------------------- */
@media print {
    #header,
    #footer,
    .sidebar,
    .master-breadcrumb,
    .c4n-subhero,
    .c4n-theme-toggle {
        display: none !important;
    }

    body {
        background: #fff !important;
        color: #000 !important;
    }

    .card {
        border: 1px solid #ddd !important;
        box-shadow: none !important;
    }
}

/* ==========================================================================
   AzuraCast Dashboard Mockup — EXACT copy from preview
   Scoped via .azuracast-mockup to prevent WHMCS style leakage
   ========================================================================== */

/* WHMCS reset: nuke ALL inherited styles inside the mockup */
.azuracast-mockup div,
.azuracast-mockup span {
    background: none !important;
    background-color: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    min-height: 0 !important;
    max-height: none !important;
    float: none !important;
    text-align: left !important;
    line-height: normal !important;
}

/* Re-apply EXACT preview styles — .azuracast-mockup prefix for specificity (0,2,0 beats reset 0,1,1) */
.azuracast-mockup {
    position: relative;
    width: 85%;
    margin-left: auto;
}

.azuracast-mockup .azuracast-laptop {
    width: 100% !important;
    background: #161b22 !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: 0 25px 80px rgba(0,0,0,0.3) !important;
}

.azuracast-mockup .azuracast-laptop-header {
    height: 36px !important;
    background: #1c2333 !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 12px !important;
    gap: 6px !important;
}

.azuracast-mockup .iso-dot { width: 8px !important; height: 8px !important; border-radius: 50% !important; flex-shrink: 0; }
.azuracast-mockup .iso-dot-r { background: #ff5f57 !important; }
.azuracast-mockup .iso-dot-y { background: #ffbd2e !important; }
.azuracast-mockup .iso-dot-g { background: #28c840 !important; }

.azuracast-mockup .azuracast-dashboard {
    padding: 20px !important;
    background: #161b22 !important;
}

.azuracast-mockup .az-nav {
    display: flex !important;
    gap: 16px !important;
    margin-bottom: 18px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}

.azuracast-mockup .az-nav-item {
    font-size: 11px !important;
    color: #6e7681 !important;
    font-weight: 500 !important;
    padding-bottom: 4px !important;
    cursor: default;
}

.azuracast-mockup .az-nav-item.active {
    color: #00c853 !important;
    border-bottom: 2px solid #00c853 !important;
}

.azuracast-mockup .az-station-card {
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
    border-radius: 10px !important;
    padding: 18px !important;
    margin-bottom: 14px !important;
}

.azuracast-mockup .az-station-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 12px !important;
}

.azuracast-mockup .az-station-name {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #e6edf3 !important;
}

.azuracast-mockup .az-station-badge {
    display: inline-flex !important;
    align-items: center !important;
    padding: 2px 10px !important;
    border-radius: 50px !important;
    background: rgba(0,200,83,0.12) !important;
    color: #00c853 !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
}

.azuracast-mockup .az-station-badge .status-dot {
    width: 6px !important;
    height: 6px !important;
    border-radius: 50% !important;
    background: #00c853 !important;
    display: inline-block !important;
    margin-right: 4px !important;
    animation: c4n-pulse-dot 2s ease-in-out infinite;
}

.azuracast-mockup .az-mini-wave {
    display: flex !important;
    align-items: flex-end !important;
    gap: 1px !important;
    height: 38px !important;
    margin-bottom: 14px !important;
}

.azuracast-mockup .az-mini-wave span {
    flex: 1 !important;
    background: linear-gradient(to top, #00c853, #00b0ff) !important;
    border-radius: 1px !important;
    animation: c4n-wave 1.8s ease-in-out infinite;
    opacity: 0.6 !important;
    min-height: 2px !important;
}

.azuracast-mockup .az-station-stats {
    display: flex !important;
    gap: 16px !important;
}

.azuracast-mockup .az-stat {
    font-size: 9px !important;
    color: #6e7681 !important;
}

.azuracast-mockup .az-stat strong {
    color: #e6edf3 !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    margin-right: 3px !important;
    display: inline !important;
}

/* Keyframes */
@keyframes c4n-pulse-dot {
    0%, 100% { box-shadow: 0 0 0 0 rgba(0,200,83,0.4); }
    50% { box-shadow: 0 0 0 6px rgba(0,200,83,0); }
}
@keyframes c4n-wave {
    0%, 100% { height: 15%; }
    50% { height: 85%; }
}

/* Responsive */
@media (max-width: 991px) {
    .azuracast-mockup {
        max-width: 500px;
        margin: 0 auto;
    }
}

/* ==========================================================================
   CTA Card (Homepage Section)
   ========================================================================== */
.c4n-cta-card {
    max-width: 900px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    align-items: center;
    gap: 40px;
    background: linear-gradient(135deg, #0d1117, #161b22);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: var(--c4n-radius-xl);
    padding: 60px;
    position: relative;
    overflow: hidden;
}

/* Grid pattern overlay */
.c4n-cta-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

.c4n-cta-content {
    position: relative;
    z-index: 1;
}

.c4n-cta-title {
    font-size: 1.8rem;
    font-weight: 800;
    color: #e6edf3;
    margin-bottom: 12px;
}

.c4n-cta-text {
    font-size: 1.15rem;
    color: #8b949e;
    margin-bottom: 2rem;
    max-width: 500px;
    line-height: 1.7;
}

.c4n-cta-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

/* CTA Visual — Spinning Concentric Rings with Center Icon */
.c4n-cta-visual {
    position: relative;
    z-index: 2;
    height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.c4n-cta-abstract {
    position: relative;
    width: 180px;
    height: 180px;
}

.c4n-cta-ring {
    position: absolute;
    border-radius: 50%;
    border: 1px solid;
    animation: c4n-spin-slow 20s linear infinite;
}

.c4n-cta-ring-1 {
    inset: 0;
    border-color: rgba(var(--c4n-primary-rgb), 0.2);
}

.c4n-cta-ring-2 {
    inset: 20px;
    border-color: rgba(var(--c4n-secondary-rgb), 0.2);
    animation-direction: reverse;
    animation-duration: 15s;
}

.c4n-cta-ring-3 {
    inset: 40px;
    border-color: rgba(var(--c4n-accent-rgb), 0.2);
    animation-duration: 10s;
}

.c4n-cta-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--c4n-primary), var(--c4n-secondary));
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    color: #fff;
    box-shadow: 0 0 40px rgba(var(--c4n-primary-rgb), 0.3);
}

.c4n-cta-orbit-dot {
    position: absolute;
    border-radius: 50%;
    animation: c4n-spin-slow 20s linear infinite;
}

@keyframes c4n-spin-slow {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@media (max-width: 767px) {
    .c4n-cta-card {
        grid-template-columns: 1fr;
        padding: 2.5rem 1.5rem;
        text-align: center;
    }
    .c4n-cta-actions {
        justify-content: center;
    }
    .c4n-cta-visual {
        display: none;
    }
    .c4n-cta-title {
        font-size: 1.6rem;
    }
}

/* CTA Card — Light Mode */
[data-theme="light"] .c4n-cta-card {
    background: linear-gradient(135deg, #ffffff, #f0f2f5);
    border-color: rgba(0, 0, 0, 0.08);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
}
[data-theme="light"] .c4n-cta-card::before {
    background-image:
        linear-gradient(rgba(0, 0, 0, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 0, 0, 0.03) 1px, transparent 1px);
}
[data-theme="light"] .c4n-cta-title {
    color: #1f2937;
}
[data-theme="light"] .c4n-cta-text {
    color: #4b5563;
}
[data-theme="light"] .c4n-cta-center {
    background: rgba(0, 200, 83, 0.12);
    box-shadow: 0 0 40px rgba(0, 200, 83, 0.15);
}

/* ==========================================================================
   GLOBAL: Disable ALL hover lift/move effects
   ========================================================================== */
.card:hover,
.panel:hover,
.btn-success:hover,
.btn-danger:hover,
.btn-warning:hover,
.btn-info:hover,
.tiles .tile:hover,
.action-icon-btns a:hover,
.sidebar .panel:hover,
.sidebar .card:hover,
.cart-sidebar .panel:hover,
.cart-sidebar .card:hover,
.c4n-card-lift:hover,
.c4n-hero-btn:hover,
.c4n-ac-feature:hover,
.c4n-ac-gallery-item:hover,
.c4n-ac-stat:hover,
.c4n-ac-badge:hover,
.c4n-ac-int-box:hover,
.c4n-ac-timeline-step:hover,
.c4n-ac-pricing-card:hover,
.c4n-product-card:hover,
.list-group-item:hover,
a.card:hover,
a.panel:hover,
[class*="btn"]:hover:not(.btn-return-to-admin) {
    transform: none !important;
}
