/**
 * VISUAL ENHANCEMENTS - rechnung.best
 * Modern visual modernization layer
 * Inspired by Apple, Stripe, Linear, Vercel
 * Version: 1.0.0 (February 2026)
 *
 * Load AFTER apple-app-enhancements.min.css and trial-banner.css
 */

/* ============================================
   A) KEYFRAME ANIMATIONS
   ============================================ */

@keyframes ve-fade-in-up {
    from {
        opacity: 0;
        transform: translateY(16px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes ve-fade-in-scale {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes ve-stagger-in {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes ve-shimmer {
    0% {
        background-position: -200% 0;
    }
    100% {
        background-position: 200% 0;
    }
}

@keyframes ve-gradient-shift {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

@keyframes ve-pulse-glow {
    0%, 100% {
        opacity: 0.4;
        transform: scale(1);
    }
    50% {
        opacity: 0.7;
        transform: scale(1.05);
    }
}

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

@keyframes ve-counter-in {
    from {
        opacity: 0;
        filter: blur(8px);
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        filter: blur(0);
        transform: translateY(0);
    }
}

/* ============================================
   B) DASHBOARD STAT CARDS (Apple/Stripe Style)
   ============================================ */

.stat-card,
.stats-card,
.dashboard-stat-card,
.stat-box {
    border-radius: 16px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.03) !important;
    border: 1px solid var(--rb-border-light) !important;
    position: relative !important;
    overflow: hidden !important;
    transition: transform 350ms var(--rb-ease-out-expo),
                box-shadow 350ms var(--rb-ease-out-expo) !important;
    animation: ve-fade-in-up 500ms var(--rb-ease-out-expo) both;
}

.stat-card:nth-child(1), .stats-card:nth-child(1), .dashboard-stat-card:nth-child(1) { animation-delay: 0ms; }
.stat-card:nth-child(2), .stats-card:nth-child(2), .dashboard-stat-card:nth-child(2) { animation-delay: 60ms; }
.stat-card:nth-child(3), .stats-card:nth-child(3), .dashboard-stat-card:nth-child(3) { animation-delay: 120ms; }
.stat-card:nth-child(4), .stats-card:nth-child(4), .dashboard-stat-card:nth-child(4) { animation-delay: 180ms; }
.stat-card:nth-child(5), .stats-card:nth-child(5), .dashboard-stat-card:nth-child(5) { animation-delay: 240ms; }
.stat-card:nth-child(6), .stats-card:nth-child(6), .dashboard-stat-card:nth-child(6) { animation-delay: 300ms; }

/* Colored top accent line */
.stat-card::before,
.stats-card::before,
.dashboard-stat-card::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 3px !important;
    background: linear-gradient(90deg, var(--rb-gradient-blue-start), var(--rb-gradient-blue-end)) !important;
    opacity: 0 !important;
    transition: opacity 300ms ease !important;
}

.stat-card:hover::before,
.stats-card:hover::before,
.dashboard-stat-card:hover::before {
    opacity: 1 !important;
}

.stat-card:hover,
.stats-card:hover,
.dashboard-stat-card:hover,
.stat-box:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--rb-shadow-card-hover) !important;
}

/* Stat card accent colors per position */
.stat-card:nth-child(1)::before, .stats-card:nth-child(1)::before { background: linear-gradient(90deg, #2563eb, #6366f1) !important; }
.stat-card:nth-child(2)::before, .stats-card:nth-child(2)::before { background: linear-gradient(90deg, #10b981, #0d9488) !important; }
.stat-card:nth-child(3)::before, .stats-card:nth-child(3)::before { background: linear-gradient(90deg, #f59e0b, #ea580c) !important; }
.stat-card:nth-child(4)::before, .stats-card:nth-child(4)::before { background: linear-gradient(90deg, #7c3aed, #6366f1) !important; }
.stat-card:nth-child(5)::before, .stats-card:nth-child(5)::before { background: linear-gradient(90deg, #ec4899, #f43f5e) !important; }
.stat-card:nth-child(6)::before, .stats-card:nth-child(6)::before { background: linear-gradient(90deg, #06b6d4, #3b82f6) !important; }

/* Stat titles */
.stat-card .stat-label,
.stats-card .stat-label,
.stat-card .stat-title,
.stats-card .stat-title {
    font-size: 12px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color: var(--rb-text-secondary) !important;
    font-weight: 600 !important;
}

/* Stat values */
.stat-card .stat-value,
.stats-card .stat-value,
.stat-card .stat-number,
.stats-card .stat-number {
    font-size: 36px !important;
    font-weight: 700 !important;
    letter-spacing: -0.025em !important;
    line-height: 1.1 !important;
    animation: ve-counter-in 600ms var(--rb-ease-out-expo) both;
    animation-delay: inherit;
}

/* ============================================
   C) PAGE HEADERS WITH GRADIENT TEXT
   ============================================ */

.page-header h1,
.page-title,
.content-header h1,
h1.page-heading {
    background: linear-gradient(135deg, var(--rb-text-primary) 0%, var(--rb-context-dashboard, #2563eb) 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    position: relative !important;
    animation: ve-fade-in-up 500ms var(--rb-ease-out-expo) both !important;
}

.page-header p,
.page-subtitle,
.content-header p {
    animation: ve-fade-in-up 500ms var(--rb-ease-out-expo) 100ms both;
}

/* Page-context gradient text colors */
body[data-page-context="invoices"] .page-header h1,
body[data-page-context="invoices"] .page-title,
body[data-page-context="invoices"] .content-header h1 {
    background: linear-gradient(135deg, var(--rb-text-primary) 0%, #3b82f6 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

body[data-page-context="cashbook"] .page-header h1,
body[data-page-context="cashbook"] .page-title,
body[data-page-context="cashbook"] .content-header h1 {
    background: linear-gradient(135deg, var(--rb-text-primary) 0%, #059669 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

body[data-page-context="customers"] .page-header h1,
body[data-page-context="customers"] .page-title,
body[data-page-context="customers"] .content-header h1 {
    background: linear-gradient(135deg, var(--rb-text-primary) 0%, #0891b2 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

body[data-page-context="offers"] .page-header h1,
body[data-page-context="offers"] .page-title,
body[data-page-context="offers"] .content-header h1 {
    background: linear-gradient(135deg, var(--rb-text-primary) 0%, #d97706 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

body[data-page-context="positions"] .page-header h1,
body[data-page-context="positions"] .page-title,
body[data-page-context="positions"] .content-header h1 {
    background: linear-gradient(135deg, var(--rb-text-primary) 0%, #7c3aed 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

body[data-page-context="export"] .page-header h1,
body[data-page-context="export"] .page-title,
body[data-page-context="export"] .content-header h1 {
    background: linear-gradient(135deg, var(--rb-text-primary) 0%, #ec4899 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

body[data-page-context="settings"] .page-header h1,
body[data-page-context="settings"] .page-title,
body[data-page-context="settings"] .content-header h1 {
    background: linear-gradient(135deg, var(--rb-text-primary) 0%, #6b7280 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

/* ============================================
   D) ENHANCED CARD SYSTEM
   ============================================ */

.card,
.panel,
.content-card,
.data-card,
.section-card {
    border-radius: 14px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04),
                0 2px 8px rgba(0, 0, 0, 0.02) !important;
    border: 1px solid var(--rb-border-light) !important;
    transition: transform 300ms var(--rb-ease-out-expo),
                box-shadow 300ms var(--rb-ease-out-expo),
                border-color 300ms ease !important;
    animation: ve-fade-in-up 500ms var(--rb-ease-out-expo) both;
}

.card:hover,
.panel:hover,
.content-card:hover,
.data-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: var(--rb-shadow-card-hover) !important;
    border-color: rgba(37, 99, 235, 0.15) !important;
}

/* Chart panels */
.chart-panel,
.chart-container,
.analytics-card {
    border-radius: 16px !important;
    border: 1px solid var(--rb-border-light) !important;
    transition: border-color 300ms ease, box-shadow 300ms ease !important;
}

.chart-panel:hover,
.chart-container:hover,
.analytics-card:hover {
    border-color: rgba(37, 99, 235, 0.2) !important;
    box-shadow: var(--rb-shadow-glow-primary) !important;
}

/* ============================================
   E) MODERN DATA TABLES
   ============================================ */

.data-table thead th,
table.table thead th,
.table-responsive table thead th {
    background: transparent !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    font-weight: 600 !important;
    color: var(--rb-text-secondary) !important;
    border-bottom: 2px solid var(--rb-border-light) !important;
    padding: 12px 16px !important;
    position: sticky;
    top: 0;
    z-index: 2;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.data-table tbody tr,
table.table tbody tr,
.table-responsive table tbody tr {
    transition: background-color 200ms ease !important;
    border-left: 3px solid transparent !important;
}

.data-table tbody tr:hover,
table.table tbody tr:hover,
.table-responsive table tbody tr:hover {
    background-color: rgba(37, 99, 235, 0.03) !important;
    border-left-color: var(--rb-context-dashboard, #2563eb) !important;
}

/* Context-specific row hover colors */
body[data-page-context="cashbook"] .data-table tbody tr:hover,
body[data-page-context="cashbook"] table.table tbody tr:hover {
    background-color: rgba(5, 150, 105, 0.03) !important;
    border-left-color: #059669 !important;
}

body[data-page-context="customers"] .data-table tbody tr:hover,
body[data-page-context="customers"] table.table tbody tr:hover {
    background-color: rgba(8, 145, 178, 0.03) !important;
    border-left-color: #0891b2 !important;
}

body[data-page-context="offers"] .data-table tbody tr:hover,
body[data-page-context="offers"] table.table tbody tr:hover {
    background-color: rgba(217, 119, 6, 0.03) !important;
    border-left-color: #d97706 !important;
}

body[data-page-context="positions"] .data-table tbody tr:hover,
body[data-page-context="positions"] table.table tbody tr:hover {
    background-color: rgba(124, 58, 237, 0.03) !important;
    border-left-color: #7c3aed !important;
}

/* Alternating subtle tint */
.data-table tbody tr:nth-child(even),
table.table tbody tr:nth-child(even),
.table-responsive table tbody tr:nth-child(even) {
    background-color: rgba(0, 0, 0, 0.01);
}

/* ============================================
   F) ENHANCED STATUS BADGES
   ============================================ */

.badge,
.status-badge,
.invoice-status {
    position: relative !important;
    padding-left: 20px !important;
    border-radius: 20px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.02em !important;
}

.badge::before,
.status-badge::before,
.invoice-status::before {
    content: '' !important;
    position: absolute !important;
    left: 8px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 6px !important;
    height: 6px !important;
    border-radius: 50% !important;
    background: currentColor !important;
}

/* Badge Colors */
.badge-success, .badge-paid,
.status-badge.paid, .status-badge.success,
.invoice-status.paid {
    background: rgba(5, 150, 105, 0.1) !important;
    color: #059669 !important;
    border: 1px solid rgba(5, 150, 105, 0.2) !important;
}
.badge-success::before, .badge-paid::before,
.status-badge.paid::before, .status-badge.success::before,
.invoice-status.paid::before {
    box-shadow: 0 0 6px rgba(5, 150, 105, 0.4) !important;
}

.badge-warning, .badge-open,
.status-badge.open, .status-badge.warning, .status-badge.pending,
.invoice-status.open {
    background: rgba(217, 119, 6, 0.1) !important;
    color: #d97706 !important;
    border: 1px solid rgba(217, 119, 6, 0.2) !important;
}
.badge-warning::before, .badge-open::before,
.status-badge.open::before, .status-badge.warning::before,
.invoice-status.open::before {
    box-shadow: 0 0 6px rgba(217, 119, 6, 0.4) !important;
}

.badge-secondary, .badge-draft,
.status-badge.draft,
.invoice-status.draft {
    background: rgba(107, 114, 128, 0.1) !important;
    color: #6b7280 !important;
    border: 1px solid rgba(107, 114, 128, 0.2) !important;
}

.badge-danger, .badge-overdue, .badge-cancelled,
.status-badge.overdue, .status-badge.cancelled, .status-badge.storniert,
.invoice-status.overdue, .invoice-status.cancelled {
    background: rgba(220, 38, 38, 0.1) !important;
    color: #dc2626 !important;
    border: 1px solid rgba(220, 38, 38, 0.2) !important;
}
.badge-danger::before, .badge-overdue::before,
.status-badge.overdue::before, .status-badge.cancelled::before,
.invoice-status.overdue::before {
    box-shadow: 0 0 6px rgba(220, 38, 38, 0.4) !important;
}

.badge-info, .badge-partially-paid,
.status-badge.partially-paid,
.invoice-status.partially-paid {
    background: rgba(37, 99, 235, 0.1) !important;
    color: #2563eb !important;
    border: 1px solid rgba(37, 99, 235, 0.2) !important;
}

/* ============================================
   G) NAVIGATION POLISH
   ============================================ */

/* Sidebar glassmorphism is handled in premium-navigation.css */

/* Section titles */
.premium-nav-section-title {
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.1em !important;
}

/* Nav divider gradient */
.premium-nav-divider {
    background: linear-gradient(90deg, transparent, var(--sidebar-border), transparent) !important;
}

/* ============================================
   H) BUTTON MICRO-INTERACTIONS
   ============================================ */

.btn,
.apple-btn,
button[type="submit"],
.action-btn {
    transition: transform 150ms var(--rb-ease-spring),
                box-shadow 200ms ease,
                background-color 200ms ease,
                border-color 200ms ease,
                color 200ms ease !important;
}

.btn:active,
.apple-btn:active,
button[type="submit"]:active,
.action-btn:active {
    transform: scale(0.97) !important;
}

/* Primary button glow */
.btn-primary:hover,
.apple-btn-primary:hover,
.apple-btn.apple-btn-primary:hover {
    box-shadow: 0 4px 16px rgba(37, 99, 235, 0.3),
                0 0 0 1px rgba(37, 99, 235, 0.1) !important;
}

/* Success button glow */
.btn-success:hover,
.apple-btn-success:hover {
    box-shadow: 0 4px 16px rgba(5, 150, 105, 0.3),
                0 0 0 1px rgba(5, 150, 105, 0.1) !important;
}

/* Danger button glow */
.btn-danger:hover,
.apple-btn-danger:hover {
    box-shadow: 0 4px 16px rgba(220, 38, 38, 0.3),
                0 0 0 1px rgba(220, 38, 38, 0.1) !important;
}

/* ============================================
   I) FORM FOCUS ANIMATIONS
   ============================================ */

input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="search"],
input[type="url"],
input[type="date"],
textarea,
select,
.form-control,
.apple-input {
    transition: border-color 200ms ease,
                box-shadow 200ms ease !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="search"]:focus,
input[type="url"]:focus,
input[type="date"]:focus,
textarea:focus,
select:focus,
.form-control:focus,
.apple-input:focus {
    border-color: var(--rb-primary) !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12) !important;
    outline: none !important;
}

/* ============================================
   J) SKELETON LOADING
   ============================================ */

.skeleton,
.skeleton-loading,
.loading-placeholder {
    background: linear-gradient(
        90deg,
        var(--rb-gray-100) 0%,
        var(--rb-gray-200) 40%,
        var(--rb-gray-100) 80%
    ) !important;
    background-size: 200% 100% !important;
    animation: ve-shimmer 1.8s ease-in-out infinite !important;
    border-radius: 8px !important;
}

/* ============================================
   K) DECORATIVE BACKGROUND ORBS
   ============================================ */

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

.main-content::before {
    content: '';
    position: fixed;
    top: -200px;
    right: -200px;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.04) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
    animation: ve-float-orb 20s ease-in-out infinite;
}

.main-content::after {
    content: '';
    position: fixed;
    bottom: -150px;
    left: -150px;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(124, 58, 237, 0.03) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
    animation: ve-float-orb 25s ease-in-out infinite reverse;
}

/* Ensure content sits above orbs */
.main-content > * {
    position: relative;
    z-index: 1;
}

/* Page-context orb colors */
body[data-page-context="cashbook"] .main-content::before {
    background: radial-gradient(circle, rgba(5, 150, 105, 0.04) 0%, transparent 70%);
}
body[data-page-context="cashbook"] .main-content::after {
    background: radial-gradient(circle, rgba(13, 148, 136, 0.03) 0%, transparent 70%);
}

body[data-page-context="customers"] .main-content::before {
    background: radial-gradient(circle, rgba(8, 145, 178, 0.04) 0%, transparent 70%);
}

body[data-page-context="offers"] .main-content::before {
    background: radial-gradient(circle, rgba(217, 119, 6, 0.04) 0%, transparent 70%);
}

body[data-page-context="positions"] .main-content::before {
    background: radial-gradient(circle, rgba(124, 58, 237, 0.04) 0%, transparent 70%);
}

body[data-page-context="export"] .main-content::before {
    background: radial-gradient(circle, rgba(236, 72, 153, 0.04) 0%, transparent 70%);
}

/* ============================================
   L) GRADIENT DIVIDERS
   ============================================ */

hr,
.divider,
.separator {
    border: none !important;
    height: 1px !important;
    background: linear-gradient(90deg, transparent 0%, var(--rb-border-light) 15%, var(--rb-border-light) 85%, transparent 100%) !important;
}

/* ============================================
   M) ACTIVITY FEED TIMELINE
   ============================================ */

.activity-item,
.timeline-item,
.feed-item {
    position: relative !important;
    padding-left: 28px !important;
    transition: background-color 200ms ease !important;
}

.activity-item::before,
.timeline-item::before {
    content: '' !important;
    position: absolute !important;
    left: 8px !important;
    top: 24px !important;
    bottom: -12px !important;
    width: 1px !important;
    background: var(--rb-border-light) !important;
}

.activity-item:last-child::before,
.timeline-item:last-child::before {
    display: none !important;
}

.activity-item::after,
.timeline-item::after {
    content: '' !important;
    position: absolute !important;
    left: 3px !important;
    top: 8px !important;
    width: 12px !important;
    height: 12px !important;
    border-radius: 50% !important;
    background: var(--rb-primary) !important;
    border: 2px solid var(--rb-bg-primary) !important;
}

.activity-item:hover,
.timeline-item:hover {
    background-color: rgba(37, 99, 235, 0.02) !important;
    border-radius: 8px !important;
}

/* ============================================
   N) QUICK ACTIONS ENHANCEMENT
   ============================================ */

.quick-action,
.quick-action-btn,
.action-card {
    min-height: 48px !important;
    border-radius: 12px !important;
    transition: transform 200ms var(--rb-ease-spring),
                box-shadow 200ms ease !important;
}

.quick-action:hover,
.quick-action-btn:hover,
.action-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--rb-shadow-glow-primary) !important;
}

/* ============================================
   O) MODAL ENHANCEMENT
   ============================================ */

.modal-content,
.modal .modal-dialog,
.modal-container {
    border-radius: 20px !important;
    box-shadow: 0 24px 48px -12px rgba(0, 0, 0, 0.18),
                0 0 0 1px rgba(0, 0, 0, 0.05) !important;
    animation: ve-fade-in-scale 250ms var(--rb-ease-out-expo) both !important;
}

/* ============================================
   P) PAGE-CONTEXT STAT CARD ACCENT COLORS
   ============================================ */

/* Invoices: Blue accents */
body[data-page-context="invoices"] .stat-card::before,
body[data-page-context="invoices"] .stats-card::before {
    background: linear-gradient(90deg, #3b82f6, #06b6d4) !important;
}

/* Cashbook: Green accents */
body[data-page-context="cashbook"] .stat-card::before,
body[data-page-context="cashbook"] .stats-card::before {
    background: linear-gradient(90deg, #10b981, #0d9488) !important;
}

/* Customers: Cyan accents */
body[data-page-context="customers"] .stat-card::before,
body[data-page-context="customers"] .stats-card::before {
    background: linear-gradient(90deg, #06b6d4, #3b82f6) !important;
}

/* Offers: Amber accents */
body[data-page-context="offers"] .stat-card::before,
body[data-page-context="offers"] .stats-card::before {
    background: linear-gradient(90deg, #f59e0b, #ea580c) !important;
}

/* Positions: Purple accents */
body[data-page-context="positions"] .stat-card::before,
body[data-page-context="positions"] .stats-card::before {
    background: linear-gradient(90deg, #7c3aed, #6366f1) !important;
}

/* Export: Pink accents */
body[data-page-context="export"] .stat-card::before,
body[data-page-context="export"] .stats-card::before {
    background: linear-gradient(90deg, #ec4899, #f43f5e) !important;
}

/* ============================================
   Q) LANDING PAGE ENHANCEMENT
   ============================================ */

/* Hero animated gradient background */
.hero-section,
.landing-hero {
    position: relative !important;
    overflow: hidden !important;
}

.hero-section::before,
.landing-hero::before {
    content: '' !important;
    position: absolute !important;
    top: -50% !important;
    left: -50% !important;
    width: 200% !important;
    height: 200% !important;
    background: radial-gradient(ellipse at 20% 50%, rgba(37, 99, 235, 0.08) 0%, transparent 50%),
                radial-gradient(ellipse at 80% 20%, rgba(124, 58, 237, 0.06) 0%, transparent 50%),
                radial-gradient(ellipse at 50% 80%, rgba(236, 72, 153, 0.05) 0%, transparent 50%) !important;
    animation: ve-gradient-shift 15s ease-in-out infinite !important;
    background-size: 200% 200% !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

/* Feature cards with colored icon circles */
.feature-card .feature-icon,
.feature-item .feature-icon {
    width: 56px !important;
    height: 56px !important;
    border-radius: 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.1), rgba(99, 102, 241, 0.1)) !important;
    color: #2563eb !important;
    transition: transform 300ms var(--rb-ease-spring) !important;
}

.feature-card:hover .feature-icon,
.feature-item:hover .feature-icon {
    transform: scale(1.1) !important;
}

/* Pricing cards: gradient border on featured */
.pricing-card.featured,
.pricing-card.popular,
.pricing-card.recommended {
    border: 2px solid transparent !important;
    background-image: linear-gradient(white, white), linear-gradient(135deg, #2563eb, #7c3aed, #ec4899) !important;
    background-origin: border-box !important;
    background-clip: padding-box, border-box !important;
}

/* ============================================
   R) LOGIN PAGE ENHANCEMENT
   ============================================ */

/* Stronger glass effect */
.login-container,
.login-card,
.auth-card {
    backdrop-filter: blur(24px) saturate(1.8) !important;
    -webkit-backdrop-filter: blur(24px) saturate(1.8) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    box-shadow: 0 24px 48px -12px rgba(0, 0, 0, 0.15) !important;
}

/* Login button glow */
.login-container .btn-primary,
.login-card .btn-primary,
.auth-card .btn-primary {
    box-shadow: 0 4px 16px rgba(37, 99, 235, 0.3) !important;
}

.login-container .btn-primary:hover,
.login-card .btn-primary:hover,
.auth-card .btn-primary:hover {
    box-shadow: 0 6px 24px rgba(37, 99, 235, 0.4) !important;
}

/* ============================================
   S) REDUCED MOTION COMPLIANCE
   ============================================ */

@media (prefers-reduced-motion: reduce) {
    .stat-card,
    .stats-card,
    .dashboard-stat-card,
    .stat-box,
    .card,
    .panel,
    .content-card,
    .data-card,
    .section-card,
    .stat-card .stat-value,
    .stats-card .stat-value,
    .page-header h1,
    .page-title,
    .content-header h1,
    .page-header p,
    .page-subtitle,
    .content-header p,
    .modal-content,
    .modal-container,
    .quick-action,
    .quick-action-btn,
    .action-card,
    .chart-panel,
    .chart-container,
    .analytics-card,
    .skeleton,
    .skeleton-loading,
    .loading-placeholder,
    .feature-card .feature-icon,
    .feature-item .feature-icon {
        animation: none !important;
        transition: none !important;
    }

    .stat-card:hover,
    .stats-card:hover,
    .dashboard-stat-card:hover,
    .stat-box:hover,
    .card:hover,
    .panel:hover,
    .content-card:hover,
    .data-card:hover,
    .quick-action:hover,
    .quick-action-btn:hover,
    .action-card:hover {
        transform: none !important;
    }

    .main-content::before,
    .main-content::after,
    .hero-section::before,
    .landing-hero::before {
        animation: none !important;
    }

    .btn:active,
    .apple-btn:active,
    button[type="submit"]:active,
    .action-btn:active {
        transform: none !important;
    }
}

/* ============================================
   T) DARK MODE OVERRIDES
   ============================================ */

@media (prefers-color-scheme: dark) {
    /* Stat cards */
    .stat-card,
    .stats-card,
    .dashboard-stat-card,
    .stat-box {
        background: var(--rb-bg-elevated) !important;
        border-color: var(--rb-border-light) !important;
    }

    /* Cards */
    .card,
    .panel,
    .content-card,
    .data-card,
    .section-card {
        background: var(--rb-bg-elevated) !important;
        border-color: var(--rb-border-light) !important;
    }

    .card:hover,
    .panel:hover,
    .content-card:hover,
    .data-card:hover {
        border-color: rgba(96, 165, 250, 0.2) !important;
    }

    /* Gradient text adjustment for dark mode */
    .page-header h1,
    .page-title,
    .content-header h1,
    h1.page-heading {
        background: linear-gradient(135deg, #F5F5F7 0%, #60a5fa 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        background-clip: text !important;
    }

    body[data-page-context="cashbook"] .page-header h1,
    body[data-page-context="cashbook"] .page-title,
    body[data-page-context="cashbook"] .content-header h1 {
        background: linear-gradient(135deg, #F5F5F7 0%, #34d399 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        background-clip: text !important;
    }

    body[data-page-context="customers"] .page-header h1,
    body[data-page-context="customers"] .page-title,
    body[data-page-context="customers"] .content-header h1 {
        background: linear-gradient(135deg, #F5F5F7 0%, #22d3ee 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        background-clip: text !important;
    }

    body[data-page-context="offers"] .page-header h1,
    body[data-page-context="offers"] .page-title,
    body[data-page-context="offers"] .content-header h1 {
        background: linear-gradient(135deg, #F5F5F7 0%, #fbbf24 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        background-clip: text !important;
    }

    body[data-page-context="positions"] .page-header h1,
    body[data-page-context="positions"] .page-title,
    body[data-page-context="positions"] .content-header h1 {
        background: linear-gradient(135deg, #F5F5F7 0%, #a78bfa 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        background-clip: text !important;
    }

    body[data-page-context="export"] .page-header h1,
    body[data-page-context="export"] .page-title,
    body[data-page-context="export"] .content-header h1 {
        background: linear-gradient(135deg, #F5F5F7 0%, #f472b6 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        background-clip: text !important;
    }

    body[data-page-context="invoices"] .page-header h1,
    body[data-page-context="invoices"] .page-title,
    body[data-page-context="invoices"] .content-header h1 {
        background: linear-gradient(135deg, #F5F5F7 0%, #60a5fa 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        background-clip: text !important;
    }

    /* Table header */
    .data-table thead th,
    table.table thead th,
    .table-responsive table thead th {
        background: var(--rb-bg-secondary) !important;
        color: var(--rb-text-secondary) !important;
    }

    /* Table row hover */
    .data-table tbody tr:hover,
    table.table tbody tr:hover,
    .table-responsive table tbody tr:hover {
        background-color: rgba(96, 165, 250, 0.05) !important;
    }

    body[data-page-context="cashbook"] .data-table tbody tr:hover,
    body[data-page-context="cashbook"] table.table tbody tr:hover {
        background-color: rgba(52, 211, 153, 0.05) !important;
    }

    /* Decorative orbs - dimmed */
    .main-content::before {
        background: radial-gradient(circle, rgba(96, 165, 250, 0.03) 0%, transparent 70%) !important;
    }

    .main-content::after {
        background: radial-gradient(circle, rgba(167, 139, 250, 0.02) 0%, transparent 70%) !important;
    }

    body[data-page-context="cashbook"] .main-content::before {
        background: radial-gradient(circle, rgba(52, 211, 153, 0.03) 0%, transparent 70%) !important;
    }

    /* Skeleton loading */
    .skeleton,
    .skeleton-loading,
    .loading-placeholder {
        background: linear-gradient(
            90deg,
            var(--rb-gray-200) 0%,
            var(--rb-gray-300) 40%,
            var(--rb-gray-200) 80%
        ) !important;
    }

    /* Status badges */
    .badge-success, .badge-paid,
    .status-badge.paid, .status-badge.success {
        background: rgba(52, 211, 153, 0.15) !important;
        color: #34d399 !important;
        border-color: rgba(52, 211, 153, 0.25) !important;
    }

    .badge-warning, .badge-open,
    .status-badge.open, .status-badge.warning {
        background: rgba(251, 191, 36, 0.15) !important;
        color: #fbbf24 !important;
        border-color: rgba(251, 191, 36, 0.25) !important;
    }

    .badge-danger, .badge-overdue,
    .status-badge.overdue, .status-badge.cancelled {
        background: rgba(248, 113, 113, 0.15) !important;
        color: #f87171 !important;
        border-color: rgba(248, 113, 113, 0.25) !important;
    }

    .badge-info, .badge-partially-paid,
    .status-badge.partially-paid {
        background: rgba(96, 165, 250, 0.15) !important;
        color: #60a5fa !important;
        border-color: rgba(96, 165, 250, 0.25) !important;
    }

    /* Form focus */
    input[type="text"]:focus,
    input[type="email"]:focus,
    input[type="password"]:focus,
    input[type="number"]:focus,
    textarea:focus,
    select:focus,
    .form-control:focus,
    .apple-input:focus {
        border-color: #60a5fa !important;
        box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.15) !important;
    }

    /* Button glows */
    .btn-primary:hover,
    .apple-btn-primary:hover,
    .apple-btn.apple-btn-primary:hover {
        box-shadow: 0 4px 16px rgba(96, 165, 250, 0.3) !important;
    }

    .btn-success:hover,
    .apple-btn-success:hover {
        box-shadow: 0 4px 16px rgba(52, 211, 153, 0.3) !important;
    }

    .btn-danger:hover,
    .apple-btn-danger:hover {
        box-shadow: 0 4px 16px rgba(248, 113, 113, 0.3) !important;
    }

    /* Pricing featured card dark mode */
    .pricing-card.featured,
    .pricing-card.popular,
    .pricing-card.recommended {
        background-image: linear-gradient(var(--rb-bg-elevated), var(--rb-bg-elevated)),
                          linear-gradient(135deg, #60a5fa, #a78bfa, #f472b6) !important;
    }

    /* Modal */
    .modal-content,
    .modal-container {
        background: var(--rb-bg-elevated) !important;
        box-shadow: 0 24px 48px -12px rgba(0, 0, 0, 0.4),
                    0 0 0 1px rgba(255, 255, 255, 0.05) !important;
    }

    /* Login page glass */
    .login-container,
    .login-card,
    .auth-card {
        border-color: rgba(255, 255, 255, 0.08) !important;
        box-shadow: 0 24px 48px -12px rgba(0, 0, 0, 0.4) !important;
    }

    /* Gradient dividers */
    hr,
    .divider,
    .separator {
        background: linear-gradient(90deg, transparent 0%, var(--rb-border-light) 15%, var(--rb-border-light) 85%, transparent 100%) !important;
    }
}

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

@media (max-width: 768px) {
    /* Reduce stat card animations on mobile */
    .stat-card:hover,
    .stats-card:hover,
    .dashboard-stat-card:hover,
    .stat-box:hover {
        transform: translateY(-2px) !important;
    }

    .card:hover,
    .panel:hover,
    .content-card:hover,
    .data-card:hover {
        transform: translateY(-2px) !important;
    }

    /* Smaller stat values on mobile */
    .stat-card .stat-value,
    .stats-card .stat-value {
        font-size: 28px !important;
    }

    /* Hide decorative orbs on small screens */
    .main-content::before,
    .main-content::after {
        display: none !important;
    }
}

@media (max-width: 480px) {
    .stat-card .stat-value,
    .stats-card .stat-value {
        font-size: 24px !important;
    }

    /* Disable hover transforms on touch */
    .stat-card:hover,
    .stats-card:hover,
    .card:hover,
    .panel:hover {
        transform: none !important;
    }
}

/* ============================================
   PRINT STYLES
   ============================================ */

@media print {
    .main-content::before,
    .main-content::after {
        display: none !important;
    }

    .stat-card,
    .stats-card,
    .card,
    .panel {
        box-shadow: none !important;
        border: 1px solid #ddd !important;
        animation: none !important;
    }

    .page-header h1,
    .page-title,
    .content-header h1 {
        -webkit-text-fill-color: initial !important;
        background: none !important;
        color: #000 !important;
        animation: none !important;
    }
}
