﻿/* ============================================
   COMPLETE COMPANY MANAGEMENT STYLES
   All Components, Modals, and Elements
   Agendrix-inspired professional design
   ============================================ */

/* ====== CSS VARIABLES - LIGHT THEME ====== */
:root {
    /* Primary Colors - Teal */
    --cm-primary: 15, 105, 115;
    --cm-primary-hover: 12, 84, 92;
    --cm-primary-light: 229, 240, 240;
    --cm-primary-dark: 5, 55, 60;
    /* Secondary Colors - Coral */
    --cm-secondary: 245, 160, 140;
    --cm-secondary-hover: 236, 145, 125;
    --cm-secondary-light: 253, 236, 232;
    /* Status Colors */
    --cm-success: 22, 163, 74;
    --cm-success-light: 220, 252, 231;
    --cm-danger: 220, 38, 38;
    --cm-danger-light: 254, 226, 226;
    --cm-warning: 217, 119, 6;
    --cm-warning-light: 254, 243, 199;
    --cm-info: 59, 130, 246;
    --cm-info-light: 219, 234, 254;
    --cm-purple: 147, 51, 234;
    /* Neutral Colors */
    --cm-white: 255, 255, 255;
    --cm-gray-50: 249, 250, 251;
    --cm-gray-100: 243, 244, 246;
    --cm-gray-200: 229, 231, 235;
    --cm-gray-300: 209, 213, 219;
    --cm-gray-400: 156, 163, 175;
    --cm-gray-500: 107, 114, 128;
    --cm-gray-600: 75, 85, 99;
    --cm-gray-700: 55, 65, 81;
    --cm-gray-800: 31, 41, 55;
    --cm-gray-900: 17, 24, 39;
    /* Spacing */
    --cm-space-xs: 0.25rem;
    --cm-space-sm: 0.5rem;
    --cm-space-md: 0.75rem;
    --cm-space-lg: 1rem;
    --cm-space-xl: 1.5rem;
    --cm-space-2xl: 2rem;
    --cm-space-3xl: 3rem;
    /* Border Radius */
    --cm-radius-sm: 0.375rem;
    --cm-radius-md: 0.5rem;
    --cm-radius-lg: 0.75rem;
    --cm-radius-xl: 1rem;
    --cm-radius-2xl: 1.5rem;
    --cm-radius-full: 9999px;
    /* Shadows */
    --cm-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --cm-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --cm-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    --cm-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    --cm-shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.15);
    /* Transitions */
    --cm-transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    --cm-transition-fast: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ====== DARK THEME ====== */
[data-theme="atriver-dark"] {
    --cm-primary: 100, 165, 175;
    --cm-primary-hover: 125, 185, 195;
    --cm-primary-light: 30, 70, 80;
    --cm-primary-dark: 150, 205, 215;
    --cm-secondary: 175, 130, 120;
    --cm-secondary-hover: 200, 160, 150;
    --cm-secondary-light: 40, 20, 15;
    --cm-success: 52, 211, 153;
    --cm-success-light: 6, 78, 59;
    --cm-danger: 248, 113, 113;
    --cm-danger-light: 127, 29, 29;
    --cm-warning: 251, 191, 36;
    --cm-warning-light: 120, 53, 15;
    --cm-info: 96, 165, 250;
    --cm-info-light: 30, 58, 138;
    --cm-purple: 168, 85, 247;
    --cm-white: 17, 24, 39;
    --cm-gray-50: 31, 41, 55;
    --cm-gray-100: 55, 65, 81;
    --cm-gray-200: 75, 85, 99;
    --cm-gray-300: 107, 114, 128;
    --cm-gray-400: 156, 163, 175;
    --cm-gray-500: 209, 213, 219;
    --cm-gray-600: 229, 231, 235;
    --cm-gray-700: 243, 244, 246;
    --cm-gray-800: 249, 250, 251;
    --cm-gray-900: 255, 255, 255;
}

/* ============================================
   REFERRAL SECTION STYLES (RS PREFIX)
   ============================================ */

.rs-section {
    padding: 0;
}

.rs-header {
    margin-bottom: var(--cm-space-2xl);
}

.rs-code-banner {
    display: flex;
    gap: var(--cm-space-2xl);
    padding: var(--cm-space-xl);
    background: linear-gradient(135deg, rgba(var(--cm-primary), 0.05), rgba(var(--cm-primary), 0.02));
    border: 1px solid rgba(var(--cm-primary), 0.15);
    border-radius: var(--cm-radius-lg);
}

.rs-code-display {
    flex: 1;
}

.rs-code-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-700));
    margin-bottom: var(--cm-space-sm);
}

.rs-code-box {
    display: flex;
    align-items: center;
    gap: var(--cm-space-md);
    padding: var(--cm-space-md) var(--cm-space-lg);
    background: rgb(var(--cm-white));
    border: 2px solid rgb(var(--cm-primary));
    border-radius: var(--cm-radius-md);
}

.rs-code-text {
    font-family: 'Monaco', 'Courier New', monospace;
    font-size: 1.25rem;
    font-weight: 700;
    color: rgb(var(--cm-primary));
    letter-spacing: 0.1em;
}

.rs-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
    border: none;
    text-decoration: none;
}

.rs-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    box-shadow: var(--cm-shadow-sm);
}

    .rs-btn-primary:hover {
        background: rgb(var(--cm-primary-hover));
        transform: translateY(-1px);
        box-shadow: var(--cm-shadow-md);
    }

.rs-btn-sm {
    padding: 0.5rem 0.875rem;
    font-size: 0.8125rem;
}

.rs-benefits {
    flex: 1;
}

.rs-benefits-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-lg) 0;
}

.rs-benefits-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-md);
}

.rs-benefit-item {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-700));
}

    .rs-benefit-item i {
        font-size: 1rem;
        flex-shrink: 0;
    }

/* Referral Stats Grid */
.rs-grid {
    display: grid;
    gap: var(--cm-space-lg);
    margin-bottom: var(--cm-space-2xl);
}

.rs-grid-4 {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.rs-stat-card {
    display: flex;
    align-items: center;
    gap: var(--cm-space-lg);
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    transition: var(--cm-transition);
}

    .rs-stat-card:hover {
        box-shadow: var(--cm-shadow-md);
        transform: translateY(-2px);
    }

    .rs-stat-card i {
        font-size: 1.5rem;
        flex-shrink: 0;
    }

.rs-stat-info {
    flex: 1;
}

.rs-stat-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: rgb(var(--cm-gray-600));
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--cm-space-xs) 0;
}

.rs-stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

/* Referral Card */
.rs-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    overflow: hidden;
}

.rs-card-header {
    padding: var(--cm-space-xl);
    border-bottom: 1px solid rgb(var(--cm-gray-200));
    background: rgb(var(--cm-gray-50));
}

.rs-card-body {
    padding: var(--cm-space-xl);
}

.rs-section-title {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

    .rs-section-title i {
        color: rgb(var(--cm-primary));
    }

.rs-share-description {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin-bottom: var(--cm-space-xl);
}

/* Share Options */
.rs-share-options {
    display: flex;
    gap: var(--cm-space-md);
    flex-wrap: wrap;
}

.rs-share-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.75rem 1.25rem;
    border: 1px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-md);
    background: rgb(var(--cm-white));
    color: rgb(var(--cm-gray-700));
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
}

    .rs-share-btn:hover {
        transform: translateY(-2px);
        box-shadow: var(--cm-shadow-md);
    }

.rs-btn-email:hover {
    background: #EA4335;
    color: white;
    border-color: #EA4335;
}

.rs-btn-whatsapp:hover {
    background: #25D366;
    color: white;
    border-color: #25D366;
}

.rs-btn-linkedin:hover {
    background: #0077B5;
    color: white;
    border-color: #0077B5;
}

.rs-btn-twitter:hover {
    background: #1DA1F2;
    color: white;
    border-color: #1DA1F2;
}

.rs-share-link-section {
    margin-top: var(--cm-space-xl);
}

.rs-form-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-700));
    margin-bottom: var(--cm-space-sm);
}

.rs-input-group {
    display: flex;
    gap: var(--cm-space-sm);
}

.rs-form-control {
    flex: 1;
    padding: 0.625rem 1rem;
    border: 1px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-900));
    background: rgb(var(--cm-white));
    font-family: 'Monaco', 'Courier New', monospace;
}

    .rs-form-control:focus {
        outline: none;
        border-color: rgb(var(--cm-primary));
        box-shadow: 0 0 0 3px rgba(var(--cm-primary), 0.1);
    }

/* Utility Classes */
.rs-text-primary {
    color: rgb(var(--cm-primary));
}

.rs-text-success {
    color: rgb(var(--cm-success));
}

.rs-text-warning {
    color: rgb(var(--cm-warning));
}

.rs-text-info {
    color: rgb(var(--cm-info));
}

.rs-mb-4 {
    margin-bottom: var(--cm-space-lg);
}

.rs-mb-6 {
    margin-bottom: var(--cm-space-2xl);
}

.rs-mt-4 {
    margin-top: var(--cm-space-lg);
}

/* ============================================
   COMPANY MEMBERS STYLES (CMEM PREFIX)
   ============================================ */

.cmem-section {
    animation: fadeInUp 0.3s ease-out;
}

.cmem-header {
    margin-bottom: var(--cm-space-xl);
}

.cmem-header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.cmem-section-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.cmem-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
    border: none;
}

.cmem-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    box-shadow: var(--cm-shadow-sm);
}

    .cmem-btn-primary:hover {
        background: rgb(var(--cm-primary-hover));
        transform: translateY(-1px);
        box-shadow: var(--cm-shadow-md);
    }

.cmem-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--cm-space-lg);
}

.cmem-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    padding: var(--cm-space-xl);
    box-shadow: var(--cm-shadow-sm);
    transition: var(--cm-transition);
}

    .cmem-card:hover {
        box-shadow: var(--cm-shadow-md);
        transform: translateY(-2px);
    }

.cmem-card-header {
    display: flex;
    align-items: flex-start;
    gap: var(--cm-space-lg);
    margin-bottom: var(--cm-space-lg);
}

.cmem-avatar {
    width: 3rem;
    height: 3rem;
    background: linear-gradient(135deg, rgba(var(--cm-primary), 0.1), rgba(var(--cm-primary), 0.05));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .cmem-avatar i {
        font-size: 1.25rem;
        color: rgb(var(--cm-primary));
    }

.cmem-info {
    flex: 1;
    min-width: 0;
}

.cmem-name {
    font-size: 1rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-xs) 0;
}

.cmem-email {
    font-size: 0.8125rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
    word-break: break-all;
}

.cmem-badge-wrapper {
    flex-shrink: 0;
}

.cmem-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    border-radius: var(--cm-radius-full);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.cmem-badge-primary {
    background: rgba(var(--cm-primary), 0.1);
    color: rgb(var(--cm-primary));
}

.cmem-badge-warning {
    background: rgba(var(--cm-warning), 0.1);
    color: rgb(var(--cm-warning));
}

.cmem-badge-gray {
    background: rgb(var(--cm-gray-100));
    color: rgb(var(--cm-gray-700));
}

.cmem-stats {
    padding: var(--cm-space-lg) 0;
    border-top: 1px solid rgb(var(--cm-gray-200));
    border-bottom: 1px solid rgb(var(--cm-gray-200));
    margin-bottom: var(--cm-space-lg);
}

.cmem-stat {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 0.8125rem;
    color: rgb(var(--cm-gray-600));
    margin-bottom: var(--cm-space-sm);
}

    .cmem-stat:last-child {
        margin-bottom: 0;
    }

    .cmem-stat i {
        font-size: 0.875rem;
        color: rgb(var(--cm-gray-400));
    }

.cmem-actions {
    display: flex;
    gap: var(--cm-space-sm);
}

.cmem-btn-sm {
    padding: 0.5rem 0.875rem;
    font-size: 0.8125rem;
}

.cmem-btn-outline {
    background: transparent;
    color: rgb(var(--cm-gray-700));
    border: 1px solid rgb(var(--cm-gray-300));
}

    .cmem-btn-outline:hover {
        background: rgb(var(--cm-gray-50));
        border-color: rgb(var(--cm-gray-400));
    }

.cmem-btn-danger {
    background: transparent;
    color: rgb(var(--cm-danger));
    border: 1px solid rgb(var(--cm-danger));
}

    .cmem-btn-danger:hover {
        background: rgb(var(--cm-danger));
        color: white;
    }

.cmem-empty-state {
    padding: var(--cm-space-3xl);
    text-align: center;
}

.cmem-empty-icon {
    font-size: 3rem;
    color: rgb(var(--cm-gray-400));
    margin-bottom: var(--cm-space-lg);
}

.cmem-empty-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-sm) 0;
}

.cmem-empty-text {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0 0 var(--cm-space-xl) 0;
}

.cmem-mb-4 {
    margin-bottom: var(--cm-space-lg);
}

.cmem-mt-4 {
    margin-top: var(--cm-space-lg);
}

/* ============================================
   COMPANY GROUPS STYLES (CGRP PREFIX)
   ============================================ */

.cgrp-section {
    animation: fadeInUp 0.3s ease-out;
}

.cgrp-header {
    margin-bottom: var(--cm-space-xl);
}

.cgrp-header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.cgrp-section-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.cgrp-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
    border: none;
}

.cgrp-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    box-shadow: var(--cm-shadow-sm);
}

    .cgrp-btn-primary:hover {
        background: rgb(var(--cm-primary-hover));
        transform: translateY(-1px);
        box-shadow: var(--cm-shadow-md);
    }

.cgrp-grid {
    display: grid;
    gap: var(--cm-space-lg);
}

.cgrp-grid-3 {
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

.cgrp-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    padding: var(--cm-space-xl);
    box-shadow: var(--cm-shadow-sm);
    transition: var(--cm-transition);
}

    .cgrp-card:hover {
        box-shadow: var(--cm-shadow-md);
        transform: translateY(-2px);
    }

.cgrp-card-header {
    display: flex;
    align-items: center;
    gap: var(--cm-space-md);
    margin-bottom: var(--cm-space-lg);
}

.cgrp-icon {
    width: 2.5rem;
    height: 2.5rem;
    background: linear-gradient(135deg, rgba(var(--cm-primary), 0.1), rgba(var(--cm-primary), 0.05));
    border-radius: var(--cm-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .cgrp-icon i {
        font-size: 1.125rem;
        color: rgb(var(--cm-primary));
    }

.cgrp-name {
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.cgrp-description {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0 0 var(--cm-space-lg) 0;
    line-height: 1.5;
}

.cgrp-stats {
    padding: var(--cm-space-md) 0;
    border-top: 1px solid rgb(var(--cm-gray-200));
    border-bottom: 1px solid rgb(var(--cm-gray-200));
    margin-bottom: var(--cm-space-lg);
}

.cgrp-stat {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 0.8125rem;
    color: rgb(var(--cm-gray-600));
    margin-bottom: var(--cm-space-sm);
}

    .cgrp-stat:last-child {
        margin-bottom: 0;
    }

    .cgrp-stat i {
        font-size: 0.875rem;
        color: rgb(var(--cm-gray-400));
    }

.cgrp-actions {
    display: flex;
    gap: var(--cm-space-sm);
}

.cgrp-btn-sm {
    padding: 0.5rem 0.875rem;
    font-size: 0.8125rem;
}

.cgrp-btn-outline {
    background: transparent;
    color: rgb(var(--cm-gray-700));
    border: 1px solid rgb(var(--cm-gray-300));
}

    .cgrp-btn-outline:hover {
        background: rgb(var(--cm-gray-50));
        border-color: rgb(var(--cm-gray-400));
    }

.cgrp-btn-success {
    background: transparent;
    color: rgb(var(--cm-success));
    border: 1px solid rgb(var(--cm-success));
}

    .cgrp-btn-success:hover {
        background: rgb(var(--cm-success));
        color: white;
    }

.cgrp-empty-state {
    padding: var(--cm-space-3xl);
    text-align: center;
}

.cgrp-empty-icon {
    font-size: 3rem;
    color: rgb(var(--cm-gray-400));
    margin-bottom: var(--cm-space-lg);
}

.cgrp-empty-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-sm) 0;
}

.cgrp-empty-text {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0 0 var(--cm-space-xl) 0;
}

.cgrp-mb-4 {
    margin-bottom: var(--cm-space-lg);
}

.cgrp-mt-4 {
    margin-top: var(--cm-space-lg);
}

/* ============================================
   COMPANY INVITATIONS STYLES (CINV PREFIX)
   ============================================ */

.cinv-section {
    animation: fadeInUp 0.3s ease-out;
}

.cinv-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    overflow: hidden;
}

.cinv-card-header {
    padding: var(--cm-space-xl);
    border-bottom: 1px solid rgb(var(--cm-gray-200));
    background: rgb(var(--cm-gray-50));
}

.cinv-card-body {
    padding: var(--cm-space-xl);
}

.cinv-section-title {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

    .cinv-section-title i {
        color: rgb(var(--cm-primary));
    }

.cinv-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.125rem 0.5rem;
    border-radius: var(--cm-radius-full);
    font-size: 0.6875rem;
    font-weight: 600;
    margin-left: var(--cm-space-sm);
}

.cinv-badge-warning {
    background: rgba(var(--cm-warning), 0.1);
    color: rgb(var(--cm-warning));
}

.cinv-badge-success {
    background: rgba(var(--cm-success), 0.1);
    color: rgb(var(--cm-success));
}

.cinv-badge-danger {
    background: rgba(var(--cm-danger), 0.1);
    color: rgb(var(--cm-danger));
}

.cinv-badge-gray {
    background: rgb(var(--cm-gray-100));
    color: rgb(var(--cm-gray-700));
}

.cinv-list {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-md);
}

.cinv-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-gray-50));
    border-radius: var(--cm-radius-md);
    transition: var(--cm-transition);
}

    .cinv-item:hover {
        background: rgba(var(--cm-primary), 0.03);
    }

.cinv-item-info {
    flex: 1;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--cm-space-xl);
}

.cinv-recipient {
    display: flex;
    align-items: center;
    gap: var(--cm-space-md);
}

    .cinv-recipient i {
        font-size: 1rem;
        color: rgb(var(--cm-gray-400));
    }

.cinv-recipient-details {
    display: flex;
    flex-direction: column;
}

.cinv-recipient-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.cinv-recipient-email {
    font-size: 0.75rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.cinv-meta {
    display: flex;
    align-items: center;
    gap: var(--cm-space-lg);
}

.cinv-date {
    font-size: 0.8125rem;
    color: rgb(var(--cm-gray-600));
}

.cinv-expiry {
    font-size: 0.75rem;
}

.cinv-text-warning {
    color: rgb(var(--cm-warning));
}

.cinv-actions {
    display: flex;
    gap: var(--cm-space-sm);
}

.cinv-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.5rem 0.875rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.8125rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
    border: none;
}

.cinv-btn-sm {
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
}

.cinv-btn-outline {
    background: transparent;
    color: rgb(var(--cm-gray-700));
    border: 1px solid rgb(var(--cm-gray-300));
}

    .cinv-btn-outline:hover {
        background: rgb(var(--cm-gray-50));
        border-color: rgb(var(--cm-gray-400));
    }

.cinv-btn-danger {
    background: transparent;
    color: rgb(var(--cm-danger));
    border: 1px solid rgb(var(--cm-danger));
}

    .cinv-btn-danger:hover {
        background: rgb(var(--cm-danger));
        color: white;
    }

.cinv-btn-link {
    background: transparent;
    color: rgb(var(--cm-primary));
    border: none;
    padding: 0;
    text-decoration: underline;
}

    .cinv-btn-link:hover {
        color: rgb(var(--cm-primary-hover));
    }

.cinv-empty-state {
    padding: var(--cm-space-2xl);
    text-align: center;
}

.cinv-empty-icon {
    font-size: 2rem;
    color: rgb(var(--cm-gray-400));
    margin-bottom: var(--cm-space-md);
}

.cinv-empty-text {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

/* Invitation Table */
.cinv-table-wrapper {
    overflow-x: auto;
}

.cinv-table {
    width: 100%;
    border-collapse: collapse;
}

    .cinv-table thead {
        background: rgb(var(--cm-gray-50));
        border-bottom: 1px solid rgb(var(--cm-gray-200));
    }

    .cinv-table th {
        padding: 0.75rem 1rem;
        text-align: left;
        font-size: 0.75rem;
        font-weight: 600;
        color: rgb(var(--cm-gray-600));
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }

    .cinv-table tbody tr {
        border-bottom: 1px solid rgb(var(--cm-gray-100));
        transition: var(--cm-transition);
    }

        .cinv-table tbody tr:hover {
            background: rgb(var(--cm-gray-50));
        }

    .cinv-table td {
        padding: 1rem;
        font-size: 0.875rem;
        color: rgb(var(--cm-gray-700));
    }

.cinv-recipient-cell {
    display: flex;
    flex-direction: column;
}

.cinv-recipient-name-table {
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 0.125rem 0;
}

.cinv-recipient-email-table {
    font-size: 0.75rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

/* Quick Invite */
.cinv-quick-form {
    padding: var(--cm-space-xl);
}

.cinv-input-group {
    display: flex;
    gap: var(--cm-space-sm);
}

.cinv-form-control {
    flex: 1;
    padding: 0.625rem 1rem;
    border: 1px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-900));
    background: rgb(var(--cm-white));
}

    .cinv-form-control:focus {
        outline: none;
        border-color: rgb(var(--cm-primary));
        box-shadow: 0 0 0 3px rgba(var(--cm-primary), 0.1);
    }

.cinv-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    box-shadow: var(--cm-shadow-sm);
}

    .cinv-btn-primary:hover:not(:disabled) {
        background: rgb(var(--cm-primary-hover));
        transform: translateY(-1px);
        box-shadow: var(--cm-shadow-md);
    }

    .cinv-btn-primary:disabled {
        opacity: 0.5;
        cursor: not-allowed;
    }

.cinv-mb-4 {
    margin-bottom: var(--cm-space-lg);
}

.cinv-mt-4 {
    margin-top: var(--cm-space-lg);
}

/* ============================================
   COMPANY REFERRALS STYLES (CRF PREFIX)
   ============================================ */

.crf-section {
    animation: fadeInUp 0.3s ease-out;
}

.crf-banner {
    background: linear-gradient(135deg, rgba(var(--cm-success), 0.08), rgba(var(--cm-success), 0.03));
    border: 1px solid rgba(var(--cm-success), 0.2);
    border-radius: var(--cm-radius-lg);
    padding: var(--cm-space-2xl);
    margin-bottom: var(--cm-space-2xl);
}

.crf-banner-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--cm-space-2xl);
}

.crf-banner-left {
    flex: 1;
}

.crf-banner-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-sm) 0;
}

.crf-banner-subtitle {
    font-size: 0.9375rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.crf-banner-right {
    flex-shrink: 0;
}

.crf-code-box {
    background: rgb(var(--cm-white));
    border: 2px solid rgb(var(--cm-success));
    border-radius: var(--cm-radius-lg);
    padding: var(--cm-space-lg);
}

.crf-code-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-600));
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--cm-space-sm) 0;
}

.crf-code-display {
    display: flex;
    align-items: center;
    gap: var(--cm-space-md);
}

.crf-code-text {
    font-family: 'Monaco', 'Courier New', monospace;
    font-size: 1.5rem;
    font-weight: 700;
    color: rgb(var(--cm-success));
    letter-spacing: 0.1em;
}

.crf-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
    border: none;
}

.crf-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    box-shadow: var(--cm-shadow-sm);
}

    .crf-btn-primary:hover {
        background: rgb(var(--cm-primary-hover));
        transform: translateY(-1px);
        box-shadow: var(--cm-shadow-md);
    }

.crf-btn-sm {
    padding: 0.5rem 0.875rem;
    font-size: 0.8125rem;
}

/* Referral Metrics */
.crf-grid {
    display: grid;
    gap: var(--cm-space-lg);
    margin-bottom: var(--cm-space-2xl);
}

.crf-grid-5 {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.crf-metric-card {
    display: flex;
    align-items: center;
    gap: var(--cm-space-md);
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    transition: var(--cm-transition);
}

    .crf-metric-card:hover {
        box-shadow: var(--cm-shadow-md);
        transform: translateY(-2px);
    }

.crf-metric-icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--cm-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .crf-metric-icon i {
        font-size: 1.125rem;
    }

.crf-bg-primary {
    background: rgba(var(--cm-primary), 0.1);
}

.crf-bg-success {
    background: rgba(var(--cm-success), 0.1);
}

.crf-bg-warning {
    background: rgba(var(--cm-warning), 0.1);
}

.crf-bg-info {
    background: rgba(var(--cm-info), 0.1);
}

.crf-bg-purple {
    background: rgba(var(--cm-purple), 0.1);
}

.crf-text-primary {
    color: rgb(var(--cm-primary));
}

.crf-text-success {
    color: rgb(var(--cm-success));
}

.crf-text-warning {
    color: rgb(var(--cm-warning));
}

.crf-text-info {
    color: rgb(var(--cm-info));
}

.crf-text-purple {
    color: rgb(var(--cm-purple));
}

.crf-metric-content {
    flex: 1;
}

.crf-metric-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: rgb(var(--cm-gray-600));
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--cm-space-xs) 0;
}

.crf-metric-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

/* Referred Companies List */
.crf-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    overflow: hidden;
}

.crf-card-header {
    padding: var(--cm-space-xl);
    border-bottom: 1px solid rgb(var(--cm-gray-200));
    background: rgb(var(--cm-gray-50));
}

.crf-header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.crf-card-body {
    padding: var(--cm-space-xl);
}

.crf-section-title {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

    .crf-section-title i {
        color: rgb(var(--cm-primary));
    }

.crf-table-wrapper {
    overflow-x: auto;
}

.crf-table {
    width: 100%;
    border-collapse: collapse;
}

    .crf-table thead {
        background: rgb(var(--cm-gray-50));
        border-bottom: 1px solid rgb(var(--cm-gray-200));
    }

    .crf-table th {
        padding: 0.75rem 1rem;
        text-align: left;
        font-size: 0.75rem;
        font-weight: 600;
        color: rgb(var(--cm-gray-600));
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }

    .crf-table tbody tr {
        border-bottom: 1px solid rgb(var(--cm-gray-100));
        transition: var(--cm-transition);
    }

        .crf-table tbody tr:hover {
            background: rgb(var(--cm-gray-50));
        }

    .crf-table td {
        padding: 1rem;
        font-size: 0.875rem;
        color: rgb(var(--cm-gray-700));
    }

.crf-company-cell {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
}

    .crf-company-cell i {
        color: rgb(var(--cm-primary));
    }

.crf-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    border-radius: var(--cm-radius-full);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.crf-badge-success {
    background: rgba(var(--cm-success), 0.1);
    color: rgb(var(--cm-success));
}

.crf-badge-warning {
    background: rgba(var(--cm-warning), 0.1);
    color: rgb(var(--cm-warning));
}

.crf-badge-info {
    background: rgba(var(--cm-info), 0.1);
    color: rgb(var(--cm-info));
}

.crf-badge-gray {
    background: rgb(var(--cm-gray-100));
    color: rgb(var(--cm-gray-700));
}

.crf-credits-earned {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-xs);
    color: rgb(var(--cm-success));
    font-weight: 600;
}

.crf-empty-state {
    padding: var(--cm-space-3xl);
    text-align: center;
}

.crf-empty-icon {
    font-size: 3rem;
    color: rgb(var(--cm-gray-400));
    margin-bottom: var(--cm-space-lg);
}

.crf-empty-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-sm) 0;
}

.crf-empty-text {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0 0 var(--cm-space-xl) 0;
}

/* Share Methods */
.crf-share-methods {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-xl);
}

.crf-share-method {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-md);
}

.crf-share-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.crf-input-group {
    display: flex;
    gap: var(--cm-space-sm);
}

.crf-form-control {
    flex: 1;
    padding: 0.625rem 1rem;
    border: 1px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-900));
    background: rgb(var(--cm-white));
    font-family: 'Monaco', 'Courier New', monospace;
}

    .crf-form-control:focus {
        outline: none;
        border-color: rgb(var(--cm-primary));
        box-shadow: 0 0 0 3px rgba(var(--cm-primary), 0.1);
    }

.crf-share-buttons {
    display: flex;
    gap: var(--cm-space-md);
    flex-wrap: wrap;
}

.crf-share-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.75rem 1.25rem;
    border: 1px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-md);
    background: rgb(var(--cm-white));
    color: rgb(var(--cm-gray-700));
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
}

.crf-btn-email:hover {
    background: #EA4335;
    color: white;
    border-color: #EA4335;
}

.crf-btn-linkedin:hover {
    background: #0077B5;
    color: white;
    border-color: #0077B5;
}

.crf-btn-whatsapp:hover {
    background: #25D366;
    color: white;
    border-color: #25D366;
}

.crf-mb-6 {
    margin-bottom: var(--cm-space-2xl);
}

.crf-mt-4 {
    margin-top: var(--cm-space-lg);
}

/* ============================================
   COMPANY CREDITS STYLES (CCR PREFIX)
   ============================================ */

.ccr-section {
    animation: fadeInUp 0.3s ease-out;
}

.ccr-header {
    margin-bottom: var(--cm-space-xl);
}

.ccr-header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ccr-section-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.ccr-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
    border: none;
}

.ccr-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    box-shadow: var(--cm-shadow-sm);
}

    .ccr-btn-primary:hover {
        background: rgb(var(--cm-primary-hover));
        transform: translateY(-1px);
        box-shadow: var(--cm-shadow-md);
    }

/* Credit Overview */
.ccr-grid {
    display: grid;
    gap: var(--cm-space-lg);
    margin-bottom: var(--cm-space-2xl);
}

.ccr-grid-3 {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.ccr-credit-card {
    display: flex;
    align-items: center;
    gap: var(--cm-space-lg);
    padding: var(--cm-space-xl);
    background: rgb(var(--cm-white));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    transition: var(--cm-transition);
    position: relative;
    overflow: hidden;
}

    .ccr-credit-card::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 3px;
        background: linear-gradient(90deg, transparent, currentColor, transparent);
    }

.ccr-card-total {
    border: 1px solid rgba(var(--cm-primary), 0.2);
}

    .ccr-card-total::before {
        background: linear-gradient(90deg, transparent, rgb(var(--cm-primary)), transparent);
    }

.ccr-card-available {
    border: 1px solid rgba(var(--cm-success), 0.2);
}

    .ccr-card-available::before {
        background: linear-gradient(90deg, transparent, rgb(var(--cm-success)), transparent);
    }

.ccr-card-allocated {
    border: 1px solid rgba(var(--cm-warning), 0.2);
}

    .ccr-card-allocated::before {
        background: linear-gradient(90deg, transparent, rgb(var(--cm-warning)), transparent);
    }

.ccr-credit-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--cm-shadow-md);
}

.ccr-credit-icon {
    width: 3rem;
    height: 3rem;
    background: linear-gradient(135deg, rgba(var(--cm-primary), 0.1), rgba(var(--cm-primary), 0.05));
    border-radius: var(--cm-radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .ccr-credit-icon i {
        font-size: 1.25rem;
        color: rgb(var(--cm-primary));
    }

.ccr-card-available .ccr-credit-icon {
    background: linear-gradient(135deg, rgba(var(--cm-success), 0.1), rgba(var(--cm-success), 0.05));
}

    .ccr-card-available .ccr-credit-icon i {
        color: rgb(var(--cm-success));
    }

.ccr-card-allocated .ccr-credit-icon {
    background: linear-gradient(135deg, rgba(var(--cm-warning), 0.1), rgba(var(--cm-warning), 0.05));
}

    .ccr-card-allocated .ccr-credit-icon i {
        color: rgb(var(--cm-warning));
    }

.ccr-credit-info {
    flex: 1;
}

.ccr-credit-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: rgb(var(--cm-gray-600));
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--cm-space-xs) 0;
}

.ccr-credit-value {
    font-size: 2rem;
    font-weight: 700;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

/* Group Allocations */
.ccr-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    overflow: hidden;
}

.ccr-card-header {
    padding: var(--cm-space-xl);
    border-bottom: 1px solid rgb(var(--cm-gray-200));
    background: rgb(var(--cm-gray-50));
}

.ccr-card-body {
    padding: var(--cm-space-xl);
}

.ccr-allocation-list {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-md);
}

.ccr-allocation-item {
    display: flex;
    align-items: center;
    gap: var(--cm-space-lg);
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-gray-50));
    border-radius: var(--cm-radius-md);
    transition: var(--cm-transition);
}

    .ccr-allocation-item:hover {
        background: rgba(var(--cm-primary), 0.03);
    }

.ccr-allocation-info {
    flex: 1;
}

.ccr-group-name {
    font-size: 0.9375rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-xs) 0;
}

.ccr-group-members {
    font-size: 0.75rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.ccr-allocation-credits {
    flex-shrink: 0;
}

.ccr-credits-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-xs);
    padding: 0.375rem 0.75rem;
    background: linear-gradient(135deg, rgba(var(--cm-primary), 0.1), rgba(var(--cm-primary), 0.05));
    border: 1px solid rgba(var(--cm-primary), 0.2);
    border-radius: var(--cm-radius-full);
    font-size: 0.875rem;
    font-weight: 600;
    color: rgb(var(--cm-primary));
}

.ccr-allocation-actions {
    display: flex;
    gap: var(--cm-space-sm);
}

.ccr-btn-sm {
    padding: 0.5rem 0.875rem;
    font-size: 0.8125rem;
}

.ccr-btn-outline {
    background: transparent;
    color: rgb(var(--cm-gray-700));
    border: 1px solid rgb(var(--cm-gray-300));
}

    .ccr-btn-outline:hover {
        background: rgb(var(--cm-gray-50));
        border-color: rgb(var(--cm-gray-400));
    }

/* Credit Packages */
.ccr-grid-4 {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.ccr-package-card {
    position: relative;
    padding: var(--cm-space-xl);
    background: rgb(var(--cm-white));
    border: 2px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    text-align: center;
    transition: var(--cm-transition);
}

    .ccr-package-card:hover {
        transform: translateY(-4px);
        box-shadow: var(--cm-shadow-lg);
        border-color: rgb(var(--cm-primary));
    }

.ccr-package-popular {
    border-color: rgb(var(--cm-primary));
    background: linear-gradient(135deg, rgba(var(--cm-primary), 0.03), rgba(var(--cm-primary), 0.01));
}

.ccr-popular-badge {
    position: absolute;
    top: -0.625rem;
    left: 50%;
    transform: translateX(-50%);
    padding: 0.25rem 0.75rem;
    background: linear-gradient(135deg, rgb(var(--cm-primary)), rgb(var(--cm-primary-hover)));
    color: white;
    border-radius: var(--cm-radius-full);
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.ccr-package-name {
    font-size: 0.9375rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-lg) 0;
}

.ccr-package-credits {
    margin-bottom: var(--cm-space-md);
}

.ccr-credits-amount {
    font-size: 2rem;
    font-weight: 700;
    color: rgb(var(--cm-gray-900));
}

.ccr-credits-label {
    display: block;
    font-size: 0.75rem;
    color: rgb(var(--cm-gray-600));
    margin-top: var(--cm-space-xs);
}

.ccr-package-price {
    margin-bottom: var(--cm-space-lg);
}

.ccr-price-currency {
    font-size: 1rem;
    color: rgb(var(--cm-gray-600));
    margin-right: var(--cm-space-xs);
}

.ccr-price-amount {
    font-size: 1.5rem;
    font-weight: 700;
    color: rgb(var(--cm-primary));
}

.ccr-package-bonus {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.375rem 0.75rem;
    background: rgba(var(--cm-success), 0.1);
    color: rgb(var(--cm-success));
    border-radius: var(--cm-radius-full);
    font-size: 0.75rem;
    font-weight: 600;
    margin-bottom: var(--cm-space-lg);
}

.ccr-btn-block {
    width: 100%;
}

.ccr-empty-state {
    padding: var(--cm-space-2xl);
    text-align: center;
}

.ccr-empty-text {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.ccr-mb-4 {
    margin-bottom: var(--cm-space-lg);
}

.ccr-mb-6 {
    margin-bottom: var(--cm-space-2xl);
}

.ccr-mt-6 {
    margin-top: var(--cm-space-2xl);
}

/* ============================================
   COMPANY TRANSACTIONS STYLES (CTR PREFIX)
   ============================================ */

.ctr-section {
    animation: fadeInUp 0.3s ease-out;
}

.ctr-header {
    margin-bottom: var(--cm-space-xl);
}

.ctr-header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ctr-section-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.ctr-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
}

.ctr-btn-outline {
    background: transparent;
    color: rgb(var(--cm-gray-700));
    border: 1px solid rgb(var(--cm-gray-300));
}

    .ctr-btn-outline:hover {
        background: rgb(var(--cm-gray-50));
        border-color: rgb(var(--cm-gray-400));
    }

/* Filters */
.ctr-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
}

.ctr-card-body {
    padding: var(--cm-space-xl);
}

.ctr-card-body-table {
    padding: 0;
}

.ctr-filters-row {
    display: flex;
    gap: var(--cm-space-lg);
    align-items: flex-end;
}

.ctr-filter-group {
    flex: 1;
}

.ctr-filter-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-700));
    margin-bottom: var(--cm-space-sm);
}

.ctr-form-control {
    width: 100%;
    padding: 0.625rem 1rem;
    border: 1px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-900));
    background: rgb(var(--cm-white));
}

    .ctr-form-control:focus {
        outline: none;
        border-color: rgb(var(--cm-primary));
        box-shadow: 0 0 0 3px rgba(var(--cm-primary), 0.1);
    }

.ctr-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    border: none;
    box-shadow: var(--cm-shadow-sm);
}

    .ctr-btn-primary:hover {
        background: rgb(var(--cm-primary-hover));
        transform: translateY(-1px);
        box-shadow: var(--cm-shadow-md);
    }

/* Transactions Table */
.ctr-table-wrapper {
    overflow-x: auto;
}

.ctr-table {
    width: 100%;
    border-collapse: collapse;
}

    .ctr-table thead {
        background: rgb(var(--cm-gray-50));
        border-bottom: 1px solid rgb(var(--cm-gray-200));
    }

    .ctr-table th {
        padding: 0.75rem 1rem;
        text-align: left;
        font-size: 0.75rem;
        font-weight: 600;
        color: rgb(var(--cm-gray-600));
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }

    .ctr-table tbody tr {
        border-bottom: 1px solid rgb(var(--cm-gray-100));
        transition: var(--cm-transition);
    }

        .ctr-table tbody tr:hover {
            background: rgb(var(--cm-gray-50));
        }

.ctr-row-credit {
    background: rgba(var(--cm-success), 0.02);
}

.ctr-row-debit {
    background: rgba(var(--cm-danger), 0.02);
}

.ctr-table td {
    padding: 1rem;
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-700));
}

.ctr-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    border-radius: var(--cm-radius-full);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.ctr-badge-success {
    background: rgba(var(--cm-success), 0.1);
    color: rgb(var(--cm-success));
}

.ctr-badge-danger {
    background: rgba(var(--cm-danger), 0.1);
    color: rgb(var(--cm-danger));
}

.ctr-badge-info {
    background: rgba(var(--cm-info), 0.1);
    color: rgb(var(--cm-info));
}

.ctr-badge-warning {
    background: rgba(var(--cm-warning), 0.1);
    color: rgb(var(--cm-warning));
}

.ctr-badge-secondary {
    background: rgb(var(--cm-gray-100));
    color: rgb(var(--cm-gray-700));
}

.ctr-code {
    padding: 0.125rem 0.375rem;
    background: rgb(var(--cm-gray-100));
    border-radius: var(--cm-radius-sm);
    font-family: 'Monaco', 'Courier New', monospace;
    font-size: 0.75rem;
    color: rgb(var(--cm-gray-700));
}

.ctr-text-right {
    text-align: right;
}

.ctr-text-success {
    color: rgb(var(--cm-success));
}

.ctr-text-danger {
    color: rgb(var(--cm-danger));
}

.ctr-font-semibold {
    font-weight: 600;
}

.ctr-pagination-info {
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-gray-50));
    border-top: 1px solid rgb(var(--cm-gray-200));
    text-align: center;
}

.ctr-text-gray {
    color: rgb(var(--cm-gray-600));
}

/* Transaction Summary */
.ctr-card-header {
    padding: var(--cm-space-xl);
    border-bottom: 1px solid rgb(var(--cm-gray-200));
    background: rgb(var(--cm-gray-50));
}

.ctr-grid {
    display: grid;
    gap: var(--cm-space-lg);
}

.ctr-grid-4 {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.ctr-summary-stat {
    text-align: center;
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-gray-50));
    border-radius: var(--cm-radius-md);
}

.ctr-stat-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: rgb(var(--cm-gray-600));
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--cm-space-sm) 0;
}

.ctr-stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0;
}

.ctr-text-primary {
    color: rgb(var(--cm-primary));
}

.ctr-text-warning {
    color: rgb(var(--cm-warning));
}

.ctr-empty-state {
    padding: var(--cm-space-3xl);
    text-align: center;
}

.ctr-empty-icon {
    font-size: 3rem;
    color: rgb(var(--cm-gray-400));
    margin-bottom: var(--cm-space-lg);
}

.ctr-empty-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-sm) 0;
}

.ctr-empty-text {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.ctr-mb-4 {
    margin-bottom: var(--cm-space-lg);
}

.ctr-mt-4 {
    margin-top: var(--cm-space-lg);
}

/* ============================================
   COMPANY SETTINGS STYLES (CSE PREFIX)
   ============================================ */

.cse-section {
    animation: fadeInUp 0.3s ease-out;
}

.cse-tabs {
    display: flex;
    gap: var(--cm-space-xs);
    background: rgb(var(--cm-white));
    padding: var(--cm-space-sm);
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    margin-bottom: var(--cm-space-xl);
}

.cse-tab {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    background: transparent;
    border: none;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    color: rgb(var(--cm-gray-600));
    cursor: pointer;
    transition: var(--cm-transition);
}

    .cse-tab:hover {
        background: rgb(var(--cm-gray-50));
        color: rgb(var(--cm-gray-900));
    }

.cse-tab-active {
    background: rgb(var(--cm-primary));
    color: white;
    font-weight: 600;
}

.cse-tab i {
    font-size: 0.875rem;
}

.cse-content {
    animation: fadeInUp 0.2s ease-out;
}

/* General Settings */
.cse-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    overflow: hidden;
}

.cse-card-header {
    padding: var(--cm-space-xl);
    border-bottom: 1px solid rgb(var(--cm-gray-200));
    background: rgb(var(--cm-gray-50));
}

.cse-card-body {
    padding: var(--cm-space-xl);
}

.cse-section-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.cse-form-section {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-xl);
}

.cse-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--cm-space-lg);
}

.cse-col-md-6 {
    grid-column: span 1;
}

.cse-form-group {
    display: flex;
    flex-direction: column;
}

.cse-form-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-700));
    margin-bottom: var(--cm-space-sm);
}

.cse-form-control {
    width: 100%;
    padding: 0.625rem 1rem;
    border: 1px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-900));
    background: rgb(var(--cm-white));
}

    .cse-form-control:focus {
        outline: none;
        border-color: rgb(var(--cm-primary));
        box-shadow: 0 0 0 3px rgba(var(--cm-primary), 0.1);
    }

textarea.cse-form-control {
    resize: vertical;
    min-height: 6rem;
}

.cse-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
    border: none;
}

.cse-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    box-shadow: var(--cm-shadow-sm);
}

    .cse-btn-primary:hover {
        background: rgb(var(--cm-primary-hover));
        transform: translateY(-1px);
        box-shadow: var(--cm-shadow-md);
    }

/* Notification Settings */
.cse-notification-settings {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-lg);
}

.cse-notification-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-gray-50));
    border-radius: var(--cm-radius-md);
    transition: var(--cm-transition);
}

    .cse-notification-item:hover {
        background: rgba(var(--cm-primary), 0.03);
    }

.cse-notification-info {
    flex: 1;
}

.cse-notification-title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-xs) 0;
}

.cse-notification-description {
    font-size: 0.8125rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.cse-notification-toggle {
    flex-shrink: 0;
}

/* Toggle Switch */
.cse-toggle {
    position: relative;
    display: inline-block;
    width: 3rem;
    height: 1.75rem;
}

    .cse-toggle input {
        opacity: 0;
        width: 0;
        height: 0;
    }

.cse-toggle-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgb(var(--cm-gray-300));
    transition: var(--cm-transition);
    border-radius: var(--cm-radius-full);
}

    .cse-toggle-slider:before {
        position: absolute;
        content: "";
        height: 1.25rem;
        width: 1.25rem;
        left: 0.25rem;
        bottom: 0.25rem;
        background-color: white;
        transition: var(--cm-transition);
        border-radius: 50%;
    }

.cse-toggle input:checked + .cse-toggle-slider {
    background-color: rgb(var(--cm-primary));
}

    .cse-toggle input:checked + .cse-toggle-slider:before {
        transform: translateX(1.25rem);
    }

/* Permission Settings */
.cse-permission-settings {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-lg);
}

.cse-form-check {
    display: flex;
    align-items: flex-start;
    gap: var(--cm-space-md);
}

.cse-form-check-input {
    width: 1.125rem;
    height: 1.125rem;
    border: 2px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-sm);
    cursor: pointer;
    margin-top: 0.125rem;
    appearance: none;
    transition: var(--cm-transition);
}

    .cse-form-check-input:checked {
        background: rgb(var(--cm-primary));
        border-color: rgb(var(--cm-primary));
    }

        .cse-form-check-input:checked::after {
            content: '\2713';
            display: block;
            text-align: center;
            color: white;
            font-size: 0.75rem;
            line-height: 1.125rem;
            font-weight: 700;
        }

.cse-form-check-label {
    flex: 1;
    cursor: pointer;
}

    .cse-form-check-label strong {
        display: block;
        font-size: 0.9375rem;
        color: rgb(var(--cm-gray-900));
        margin-bottom: var(--cm-space-xs);
    }

.cse-form-check-description {
    font-size: 0.8125rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.cse-form-hint {
    display: block;
    font-size: 0.75rem;
    color: rgb(var(--cm-gray-500));
    margin-top: var(--cm-space-xs);
}

/* Danger Zone */
.cse-border-danger {
    border-color: rgba(var(--cm-danger), 0.3);
}

.cse-bg-danger {
    background: rgba(var(--cm-danger), 0.05);
}

.cse-text-danger {
    color: rgb(var(--cm-danger));
}

.cse-danger-actions {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-xl);
}

.cse-danger-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-gray-50));
    border-radius: var(--cm-radius-md);
    border: 1px solid rgba(var(--cm-danger), 0.1);
}

.cse-danger-info {
    flex: 1;
}

.cse-danger-title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-xs) 0;
}

.cse-danger-description {
    font-size: 0.8125rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.cse-btn-warning {
    background: rgb(var(--cm-warning));
    color: white;
}

    .cse-btn-warning:hover {
        background: rgba(var(--cm-warning), 0.9);
        transform: translateY(-1px);
    }

.cse-btn-danger {
    background: rgb(var(--cm-danger));
    color: white;
}

    .cse-btn-danger:hover {
        background: rgba(var(--cm-danger), 0.9);
        transform: translateY(-1px);
    }

.cse-mb-3 {
    margin-bottom: var(--cm-space-md);
}

.cse-mt-3 {
    margin-top: var(--cm-space-md);
}

.cse-mt-4 {
    margin-top: var(--cm-space-lg);
}

/* ============================================
   MODAL STYLES (JCM, CCM, IMM PREFIX)
   ============================================ */

/* Modal Backdrop */
.jcm-modal-backdrop,
.ccm-modal-backdrop,
.imm-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--cm-space-xl);
    animation: modalFadeIn 0.2s ease-out;
}

@keyframes modalFadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* Modal Content */
.jcm-modal-content,
.ccm-modal-content,
.imm-modal-content {
    position: relative;
    width: 100%;
    max-width: 500px;
    max-height: calc(100vh - 3rem);
    background: rgb(var(--cm-white));
    border-radius: var(--cm-radius-xl);
    box-shadow: var(--cm-shadow-2xl);
    overflow-y: auto;
    animation: modalScaleIn 0.25s ease-out;
}

.ccm-modal-lg {
    max-width: 700px;
}

@keyframes modalScaleIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* Modal Header */
.jcm-modal-header,
.ccm-modal-header,
.imm-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--cm-space-xl);
    border-bottom: 1px solid rgb(var(--cm-gray-200));
}

.jcm-modal-title,
.ccm-modal-title,
.imm-modal-title {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 1.25rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

    .jcm-modal-title i,
    .ccm-modal-title i,
    .imm-modal-title i {
        color: rgb(var(--cm-primary));
    }

.jcm-modal-close,
.ccm-modal-close,
.imm-modal-close {
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    border-radius: var(--cm-radius-md);
    color: rgb(var(--cm-gray-400));
    cursor: pointer;
    transition: var(--cm-transition);
}

    .jcm-modal-close:hover,
    .ccm-modal-close:hover,
    .imm-modal-close:hover {
        background: rgb(var(--cm-gray-100));
        color: rgb(var(--cm-gray-600));
    }

/* Modal Body */
.jcm-modal-body,
.ccm-modal-body,
.imm-modal-body {
    padding: var(--cm-space-xl);
}

/* Modal Footer */
.jcm-modal-footer,
.ccm-modal-footer,
.imm-modal-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--cm-space-md);
    padding: var(--cm-space-xl);
    border-top: 1px solid rgb(var(--cm-gray-200));
}

/* Join Company Modal Specific */
.jcm-tabs {
    display: flex;
    gap: var(--cm-space-xs);
    background: rgb(var(--cm-gray-50));
    padding: var(--cm-space-xs);
    border-radius: var(--cm-radius-md);
    margin-bottom: var(--cm-space-xl);
}

.jcm-tab {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem;
    background: transparent;
    border: none;
    border-radius: var(--cm-radius-sm);
    font-size: 0.875rem;
    font-weight: 500;
    color: rgb(var(--cm-gray-600));
    cursor: pointer;
    transition: var(--cm-transition);
}

    .jcm-tab:hover {
        background: rgb(var(--cm-white));
        color: rgb(var(--cm-gray-900));
    }

.jcm-tab-active {
    background: rgb(var(--cm-white));
    color: rgb(var(--cm-primary));
    font-weight: 600;
    box-shadow: var(--cm-shadow-sm);
}

.jcm-form-section {
    display: flex;
    flex-direction: column;
}

.jcm-mb-4,
.ccm-mb-4,
.imm-mb-4 {
    margin-bottom: var(--cm-space-lg);
}

.jcm-mb-3,
.ccm-mb-3 {
    margin-bottom: var(--cm-space-md);
}

.jcm-mt-4,
.ccm-mt-4,
.imm-mt-4 {
    margin-top: var(--cm-space-lg);
}

.jcm-text-gray {
    color: rgb(var(--cm-gray-600));
}

.jcm-form-group,
.ccm-form-group,
.imm-form-group {
    margin-bottom: var(--cm-space-xl);
}

.jcm-form-label,
.ccm-form-label,
.imm-form-label {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 0.875rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-700));
    margin-bottom: var(--cm-space-sm);
}

    .jcm-form-label i,
    .ccm-form-label i,
    .imm-form-label i {
        color: rgb(var(--cm-primary));
    }

.ccm-required::after,
.imm-required::after {
    content: '*';
    color: rgb(var(--cm-danger));
    margin-left: var(--cm-space-xs);
}

.jcm-form-control,
.ccm-form-control,
.imm-form-control {
    width: 100%;
    padding: 0.625rem 1rem;
    border: 1px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-900));
    background: rgb(var(--cm-white));
}

    .jcm-form-control:focus,
    .ccm-form-control:focus,
    .imm-form-control:focus {
        outline: none;
        border-color: rgb(var(--cm-primary));
        box-shadow: 0 0 0 3px rgba(var(--cm-primary), 0.1);
    }

textarea.jcm-form-control,
textarea.ccm-form-control,
textarea.imm-form-control {
    resize: vertical;
    min-height: 6rem;
}

.jcm-btn,
.ccm-btn,
.imm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
}

.jcm-btn-primary,
.ccm-btn-primary,
.imm-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    border: none;
    box-shadow: var(--cm-shadow-sm);
}

    .jcm-btn-primary:hover:not(:disabled),
    .ccm-btn-primary:hover:not(:disabled),
    .imm-btn-primary:hover:not(:disabled) {
        background: rgb(var(--cm-primary-hover));
        transform: translateY(-1px);
        box-shadow: var(--cm-shadow-md);
    }

.jcm-btn-secondary,
.ccm-btn-secondary,
.imm-btn-secondary {
    background: rgb(var(--cm-white));
    color: rgb(var(--cm-gray-700));
    border: 1px solid rgb(var(--cm-gray-300));
}

    .jcm-btn-secondary:hover:not(:disabled),
    .ccm-btn-secondary:hover:not(:disabled),
    .imm-btn-secondary:hover:not(:disabled) {
        background: rgb(var(--cm-gray-50));
        border-color: rgb(var(--cm-gray-400));
    }

.jcm-btn:disabled,
.ccm-btn:disabled,
.imm-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Alerts */
.jcm-alert,
.ccm-alert,
.imm-alert {
    display: flex;
    align-items: flex-start;
    gap: var(--cm-space-md);
    padding: var(--cm-space-lg);
    border-radius: var(--cm-radius-md);
    border: 1px solid;
    margin-top: var(--cm-space-md);
    font-size: 0.875rem;
}

.jcm-alert-danger,
.ccm-alert-danger,
.imm-alert-danger {
    background: rgba(var(--cm-danger), 0.05);
    border-color: rgba(var(--cm-danger), 0.2);
    color: rgb(var(--cm-danger));
}

.jcm-alert i,
.ccm-alert i,
.imm-alert i {
    flex-shrink: 0;
}

.imm-alert-success {
    background: rgba(var(--cm-success), 0.05);
    border-color: rgba(var(--cm-success), 0.2);
    color: rgb(var(--cm-success));
}

/* Create Company Modal Specific */
.ccm-section-subtitle {
    font-size: 0.9375rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-lg) 0;
}

.ccm-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--cm-space-lg);
}

.ccm-col-md-6 {
    grid-column: span 1;
}

.ccm-form-hint {
    display: block;
    font-size: 0.75rem;
    color: rgb(var(--cm-gray-500));
    margin-top: var(--cm-space-xs);
}

.ccm-form-check {
    display: flex;
    align-items: flex-start;
    gap: var(--cm-space-md);
}

.ccm-form-check-input {
    width: 1.125rem;
    height: 1.125rem;
    border: 2px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-sm);
    cursor: pointer;
    margin-top: 0.125rem;
    appearance: none;
}

    .ccm-form-check-input:checked {
        background: rgb(var(--cm-primary));
        border-color: rgb(var(--cm-primary));
    }

        .ccm-form-check-input:checked::after {
            content: '\2713';
            display: block;
            text-align: center;
            color: white;
            font-size: 0.75rem;
            line-height: 1.125rem;
            font-weight: 700;
        }

.ccm-form-check-label {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-700));
    cursor: pointer;
}

    .ccm-form-check-label a {
        color: rgb(var(--cm-primary));
        text-decoration: none;
    }

        .ccm-form-check-label a:hover {
            text-decoration: underline;
        }

/* Invite Member Modal Specific */
.imm-invite-options {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-xl);
}

.imm-invite-option {
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-gray-50));
    border-radius: var(--cm-radius-lg);
}

.imm-invite-active {
    background: linear-gradient(135deg, rgba(var(--cm-primary), 0.05), rgba(var(--cm-primary), 0.02));
    border: 1px solid rgba(var(--cm-primary), 0.15);
}

.imm-option-header {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    margin-bottom: var(--cm-space-lg);
}

    .imm-option-header i {
        color: rgb(var(--cm-primary));
    }

.imm-option-title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.imm-code-display {
    display: flex;
    align-items: center;
    gap: var(--cm-space-md);
    padding: var(--cm-space-md);
    background: rgb(var(--cm-white));
    border: 2px solid rgb(var(--cm-primary));
    border-radius: var(--cm-radius-md);
    margin-bottom: var(--cm-space-md);
}

.imm-code-text {
    font-family: 'Monaco', 'Courier New', monospace;
    font-size: 1.25rem;
    font-weight: 700;
    color: rgb(var(--cm-primary));
    letter-spacing: 0.1em;
}

.imm-btn-sm {
    padding: 0.5rem 0.875rem;
    font-size: 0.8125rem;
}

.imm-code-description {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.imm-divider-text {
    text-align: center;
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-500));
    margin: var(--cm-space-lg) 0;
    position: relative;
}

    .imm-divider-text::before,
    .imm-divider-text::after {
        content: '';
        position: absolute;
        top: 50%;
        width: calc(50% - 2rem);
        height: 1px;
        background: rgb(var(--cm-gray-200));
    }

    .imm-divider-text::before {
        left: 0;
    }

    .imm-divider-text::after {
        right: 0;
    }

.imm-form-title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-lg) 0;
}

.imm-form-check {
    display: flex;
    align-items: flex-start;
    gap: var(--cm-space-md);
}

.imm-form-check-input {
    width: 1.125rem;
    height: 1.125rem;
    border: 2px solid rgb(var(--cm-gray-300));
    border-radius: var(--cm-radius-sm);
    cursor: pointer;
    margin-top: 0.125rem;
    appearance: none;
}

    .imm-form-check-input:checked {
        background: rgb(var(--cm-primary));
        border-color: rgb(var(--cm-primary));
    }

        .imm-form-check-input:checked::after {
            content: '\2713';
            display: block;
            text-align: center;
            color: white;
            font-size: 0.75rem;
            line-height: 1.125rem;
            font-weight: 700;
        }

.imm-form-check-label {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-700));
    cursor: pointer;
}

.fa-spinner.fa-spin {
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}


/* ============================================
   COMPANY MANAGEMENT - MISSING STYLES
   Completes the BizGo-Master.css styling system
   ============================================ */

/* ====== PAGE STRUCTURE ====== */
.cm-page-container {
    min-height: 100vh;
    background: rgb(var(--cm-gray-50));
    padding: 0rem 1.5rem 2rem;
}

.cm-page-header {
    margin-bottom: var(--cm-space-2xl);
}

.cm-page-title {
    font-size: 1.75rem;
    font-weight: 700;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-sm) 0;
    letter-spacing: -0.03em;
}

.cm-page-subtitle {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

/* ====== BREADCRUMB ====== */
.cm-breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--cm-space-md);
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin-bottom: var(--cm-space-xl);
}

    .cm-breadcrumb a {
        color: rgb(var(--cm-gray-600));
        text-decoration: none;
        transition: var(--cm-transition);
    }

        .cm-breadcrumb a:hover {
            color: rgb(var(--cm-primary));
        }

    .cm-breadcrumb span:not(:last-child) {
        color: rgb(var(--cm-gray-400));
    }

/* ====== GRID LAYOUTS ====== */
.cm-grid {
    display: grid;
    gap: var(--cm-space-lg);
}

.cm-grid-3 {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

/* ====== CARDS ====== */
.cm-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    padding: var(--cm-space-xl);
    transition: var(--cm-transition);
}

    .cm-card:hover {
        box-shadow: var(--cm-shadow-md);
    }

.cm-card-compact {
    padding: var(--cm-space-xl) var(--cm-space-lg);
}

.cm-card-icon {
    font-size: 2.5rem;
    margin-bottom: var(--cm-space-lg);
    display: block;
}

.cm-card-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-sm) 0;
}

.cm-card-text {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
    line-height: 1.5;
}

/* ====== SECTIONS ====== */
.cm-standalone-section {
    animation: fadeInUp 0.3s ease-out;
}

.cm-auth-required {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 50vh;
    padding: var(--cm-space-3xl);
    text-align: center;
}

.cm-no-company {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--cm-space-3xl);
    text-align: center;
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
}

.cm-empty-icon {
    font-size: 3rem;
    color: rgb(var(--cm-gray-400));
    margin-bottom: var(--cm-space-lg);
}

.cm-empty-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-sm) 0;
}

.cm-empty-text {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0 0 var(--cm-space-xl) 0;
}

.cm-action-buttons {
    display: flex;
    gap: var(--cm-space-md);
    margin-top: var(--cm-space-xl);
    flex-wrap: wrap;
    justify-content: center;
}

/* ====== COMPANY WRAPPER ====== */
.cm-company-wrapper {
    animation: fadeInUp 0.3s ease-out;
}

.cm-company-header {
    background: linear-gradient(135deg, rgba(var(--cm-primary), 0.03), rgba(var(--cm-primary), 0.01));
    border: 1px solid rgba(var(--cm-primary), 0.1);
    border-radius: var(--cm-radius-lg);
    padding: var(--cm-space-2xl);
    margin-bottom: var(--cm-space-2xl);
}

.cm-header-content {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--cm-space-xl);
}

.cm-header-left {
    flex: 1;
}

.cm-company-name {
    font-size: 1.5rem;
    font-weight: 700;
    color: rgb(var(--cm-gray-900));
    margin: 0 0 var(--cm-space-sm) 0;
}

.cm-company-description {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0 0 var(--cm-space-lg) 0;
}

.cm-stats-row {
    display: flex;
    gap: var(--cm-space-xl);
    flex-wrap: wrap;
}

.cm-stat-item {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-700));
}

    .cm-stat-item i {
        font-size: 1rem;
        color: rgb(var(--cm-primary));
    }

.cm-header-actions {
    display: flex;
    gap: var(--cm-space-sm);
}

/* ====== BUTTONS ====== */
.cm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--cm-transition);
    text-decoration: none;
    border: none;
}

.cm-btn-primary {
    background: rgb(var(--cm-primary));
    color: white;
    box-shadow: var(--cm-shadow-sm);
}

    .cm-btn-primary:hover:not(:disabled) {
        background: rgb(var(--cm-primary-hover));
        box-shadow: var(--cm-shadow-md);
        transform: translateY(-1px);
    }

.cm-btn-secondary {
    background: rgb(var(--cm-white));
    color: rgb(var(--cm-gray-700));
    border: 1px solid rgb(var(--cm-gray-300));
}

    .cm-btn-secondary:hover:not(:disabled) {
        background: rgb(var(--cm-gray-50));
        border-color: rgb(var(--cm-gray-400));
    }

.cm-btn-white {
    background: rgb(var(--cm-white));
    color: rgb(var(--cm-gray-700));
    border: 1px solid rgb(var(--cm-gray-200));
    box-shadow: var(--cm-shadow-sm);
}

    .cm-btn-white:hover:not(:disabled) {
        background: rgb(var(--cm-gray-50));
        border-color: rgb(var(--cm-gray-300));
    }

.cm-btn-sm {
    padding: 0.5rem 0.875rem;
    font-size: 0.8125rem;
}

.cm-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ====== TABS ====== */
.cm-tabs {
    display: flex;
    gap: var(--cm-space-xs);
    background: rgb(var(--cm-white));
    padding: var(--cm-space-sm);
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    margin-bottom: var(--cm-space-xl);
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: rgb(var(--cm-gray-300)) transparent;
}

    .cm-tabs::-webkit-scrollbar {
        height: 4px;
    }

    .cm-tabs::-webkit-scrollbar-track {
        background: transparent;
    }

    .cm-tabs::-webkit-scrollbar-thumb {
        background: rgb(var(--cm-gray-300));
        border-radius: var(--cm-radius-full);
    }

.cm-tab {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: 0.625rem 1rem;
    background: transparent;
    border: none;
    border-radius: var(--cm-radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    color: rgb(var(--cm-gray-600));
    cursor: pointer;
    transition: var(--cm-transition);
    white-space: nowrap;
    flex-shrink: 0;
}

    .cm-tab:hover:not(.cm-tab-active) {
        background: rgb(var(--cm-gray-50));
        color: rgb(var(--cm-gray-900));
    }

.cm-tab-active {
    background: rgb(var(--cm-primary));
    color: white;
    font-weight: 600;
}

.cm-tab i {
    font-size: 0.875rem;
}

.cm-tab-content {
    animation: fadeInUp 0.2s ease-out;
}

/* ====== BADGES ====== */
.cm-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.25rem;
    padding: 0.25rem 0.5rem;
    background: rgb(var(--cm-gray-100));
    color: rgb(var(--cm-gray-700));
    border-radius: var(--cm-radius-full);
    font-size: 0.6875rem;
    font-weight: 600;
    margin-left: var(--cm-space-sm);
}

.cm-badge-gray {
    background: rgb(var(--cm-gray-100));
    color: rgb(var(--cm-gray-700));
}

.cm-badge-warning {
    background: rgba(var(--cm-warning), 0.1);
    color: rgb(var(--cm-warning));
}

.cm-badge-success {
    background: rgba(var(--cm-success), 0.1);
    color: rgb(var(--cm-success));
}

.cm-tab-active .cm-badge {
    background: rgba(255, 255, 255, 0.25);
    color: white;
}

/* ====== COMPANY OVERVIEW STYLES (CO PREFIX) ====== */
.co-dashboard {
    animation: fadeInUp 0.3s ease-out;
}

.co-grid {
    display: grid;
    gap: var(--cm-space-lg);
    margin-bottom: var(--cm-space-2xl);
}

.co-grid-4 {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.co-stat-card {
    display: flex;
    align-items: center;
    gap: var(--cm-space-lg);
    padding: var(--cm-space-xl);
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    transition: var(--cm-transition);
}

    .co-stat-card:hover {
        transform: translateY(-2px);
        box-shadow: var(--cm-shadow-md);
    }

.co-stat-icon {
    width: 3rem;
    height: 3rem;
    border-radius: var(--cm-radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .co-stat-icon i {
        font-size: 1.25rem;
    }

.co-bg-primary {
    background: rgba(var(--cm-primary), 0.1);
}

.co-bg-success {
    background: rgba(var(--cm-success), 0.1);
}

.co-bg-warning {
    background: rgba(var(--cm-warning), 0.1);
}

.co-bg-info {
    background: rgba(var(--cm-info), 0.1);
}

.co-text-primary {
    color: rgb(var(--cm-primary));
}

.co-text-success {
    color: rgb(var(--cm-success));
}

.co-text-warning {
    color: rgb(var(--cm-warning));
}

.co-text-info {
    color: rgb(var(--cm-info));
}

.co-stat-content {
    flex: 1;
}

.co-stat-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: rgb(var(--cm-gray-600));
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--cm-space-xs) 0;
}

.co-stat-value {
    font-size: 1.75rem;
    font-weight: 700;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

.co-stat-change {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-xs);
    font-size: 0.75rem;
    font-weight: 600;
    margin-top: var(--cm-space-xs);
}

.co-positive {
    color: rgb(var(--cm-success));
}

.co-negative {
    color: rgb(var(--cm-danger));
}

.co-stat-subtitle {
    font-size: 0.75rem;
    color: rgb(var(--cm-gray-500));
    margin-top: var(--cm-space-xs);
}

.co-row {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--cm-space-xl);
}

.co-col-lg-8 {
    grid-column: span 1;
}

.co-col-lg-4 {
    grid-column: span 1;
}

.co-card {
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-lg);
    box-shadow: var(--cm-shadow-sm);
    overflow: hidden;
}

.co-card-header {
    padding: var(--cm-space-xl);
    border-bottom: 1px solid rgb(var(--cm-gray-200));
    background: rgb(var(--cm-gray-50));
}

.co-card-body {
    padding: var(--cm-space-xl);
}

.co-section-title {
    display: flex;
    align-items: center;
    gap: var(--cm-space-sm);
    font-size: 1.125rem;
    font-weight: 600;
    color: rgb(var(--cm-gray-900));
    margin: 0;
}

    .co-section-title i {
        color: rgb(var(--cm-primary));
    }

.co-activity-timeline {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-lg);
}

.co-activity-item {
    display: flex;
    gap: var(--cm-space-md);
    position: relative;
}

    .co-activity-item::before {
        content: '';
        position: absolute;
        left: 1rem;
        top: 2.5rem;
        bottom: -1rem;
        width: 2px;
        background: rgb(var(--cm-gray-200));
    }

    .co-activity-item:last-child::before {
        display: none;
    }

.co-activity-icon {
    width: 2rem;
    height: 2rem;
    border-radius: var(--cm-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background: rgb(var(--cm-white));
    border: 2px solid rgb(var(--cm-gray-200));
    z-index: 1;
}

    .co-activity-icon i {
        font-size: 0.75rem;
    }

    .co-activity-icon.co-bg-primary {
        background: rgba(var(--cm-primary), 0.1);
        border-color: rgb(var(--cm-primary));
        color: rgb(var(--cm-primary));
    }

.co-activity-content {
    flex: 1;
}

.co-activity-description {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-700));
    margin: 0 0 var(--cm-space-xs) 0;
    line-height: 1.5;
}

    .co-activity-description strong {
        font-weight: 600;
        color: rgb(var(--cm-gray-900));
    }

.co-activity-time {
    display: inline-flex;
    align-items: center;
    gap: var(--cm-space-xs);
    font-size: 0.75rem;
    color: rgb(var(--cm-gray-500));
}

    .co-activity-time i {
        font-size: 0.75rem;
    }

.co-empty-state {
    padding: var(--cm-space-2xl);
    text-align: center;
}

.co-empty-icon {
    font-size: 2rem;
    color: rgb(var(--cm-gray-400));
    margin-bottom: var(--cm-space-md);
}

.co-empty-text {
    font-size: 0.875rem;
    color: rgb(var(--cm-gray-600));
    margin: 0;
}

.co-quick-actions {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--cm-space-md);
}

.co-quick-action-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--cm-space-sm);
    padding: var(--cm-space-lg);
    background: rgb(var(--cm-white));
    border: 1px solid rgb(var(--cm-gray-200));
    border-radius: var(--cm-radius-md);
    font-size: 0.8125rem;
    font-weight: 500;
    color: rgb(var(--cm-gray-700));
    cursor: pointer;
    transition: var(--cm-transition);
}

    .co-quick-action-btn:hover {
        background: rgb(var(--cm-gray-50));
        border-color: rgb(var(--cm-primary));
        color: rgb(var(--cm-primary));
        transform: translateY(-2px);
        box-shadow: var(--cm-shadow-md);
    }

    .co-quick-action-btn i {
        font-size: 1.25rem;
    }

.co-info-list {
    display: flex;
    flex-direction: column;
    gap: var(--cm-space-md);
}

.co-info-item {
    display: flex;
    justify-content: space-between;
    font-size: 0.8125rem;
    padding-bottom: var(--cm-space-sm);
    border-bottom: 1px solid rgb(var(--cm-gray-100));
}

    .co-info-item:last-child {
        border-bottom: none;
    }

.co-info-label {
    font-weight: 600;
    color: rgb(var(--cm-gray-600));
}

.co-info-value {
    color: rgb(var(--cm-gray-900));
}

.co-mt-4 {
    margin-top: var(--cm-space-lg);
}

.co-mb-4 {
    margin-bottom: var(--cm-space-lg);
}

.co-mb-6 {
    margin-bottom: var(--cm-space-2xl);
}

/* ====== TEXT UTILITIES ====== */
.cm-text-center {
    text-align: center;
}

.cm-text-primary {
    color: rgb(var(--cm-primary));
}

.cm-text-gray {
    color: rgb(var(--cm-gray-600));
}

/* ====== SPACING UTILITIES ====== */
.cm-mt-3 {
    margin-top: var(--cm-space-md);
}

.cm-mt-4 {
    margin-top: var(--cm-space-lg);
}

.cm-mb-4 {
    margin-bottom: var(--cm-space-lg);
}

.cm-mb-6 {
    margin-bottom: var(--cm-space-2xl);
}

/* ====== ANIMATIONS ====== */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ====== RESPONSIVE DESIGN ====== */
@media (max-width: 1199.98px) {
    .co-row {
        grid-template-columns: 1fr;
    }

    .co-grid-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 991.98px) {
    .cm-header-content {
        flex-direction: column;
    }

    .cm-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
    }

    .cm-grid-3 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .cm-page-title {
        font-size: 1.5rem;
    }

    .co-grid-4 {
        grid-template-columns: 1fr;
    }

    .co-quick-actions {
        grid-template-columns: 1fr;
    }

    .cm-stats-row {
        flex-direction: column;
        gap: var(--cm-space-md);
    }

    .cm-header-actions {
        flex-direction: column;
        width: 100%;
    }

        .cm-header-actions .cm-btn {
            width: 100%;
            justify-content: center;
        }
}

@media (max-width: 575.98px) {
    .cm-page-container {
        padding: 4rem 0.75rem 1rem;
    }

    .cm-action-buttons {
        flex-direction: column;
        width: 100%;
    }

        .cm-action-buttons .cm-btn {
            width: 100%;
        }
}

/* ====== DARK THEME ADJUSTMENTS ====== */
[data-theme="atriver-dark"] .cm-card,
[data-theme="atriver-dark"] .co-card,
[data-theme="atriver-dark"] .cm-tabs {
    background: rgb(var(--cm-white));
    border-color: rgb(var(--cm-gray-200));
}

[data-theme="atriver-dark"] .co-card-header {
    background: rgb(var(--cm-gray-50));
    border-color: rgb(var(--cm-gray-200));
}

[data-theme="atriver-dark"] .co-activity-item::before {
    background: rgb(var(--cm-gray-200));
}

[data-theme="atriver-dark"] .co-info-item {
    border-color: rgb(var(--cm-gray-100));
}

/* ============================================
   RESPONSIVE DESIGN
   ============================================ */

@media (max-width: 1199.98px) {
    .co-row {
        grid-template-columns: 1fr;
    }

    .crf-grid-5,
    .ccr-grid-4,
    .ctr-grid-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 991.98px) {
    .cm-header-content {
        flex-direction: column;
    }

    .cm-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
    }

    .rs-code-banner {
        flex-direction: column;
    }

    .crf-banner-content {
        flex-direction: column;
        text-align: center;
    }

    .ccr-grid-3,
    .cgrp-grid-3 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .cm-grid-3,
    .co-grid-4,
    .rs-grid-4 {
        grid-template-columns: 1fr;
    }

    .cmem-grid {
        grid-template-columns: 1fr;
    }

    .co-quick-actions {
        grid-template-columns: 1fr;
    }

    .rs-share-options,
    .crf-share-buttons {
        flex-direction: column;
    }

        .rs-share-options .rs-share-btn,
        .crf-share-buttons .crf-share-btn {
            width: 100%;
            justify-content: center;
        }

    .cse-row,
    .ccm-row {
        grid-template-columns: 1fr;
    }

    .ctr-filters-row {
        flex-direction: column;
    }

        .ctr-filters-row .ctr-btn {
            width: 100%;
        }
}

@media (max-width: 575.98px) {
    .cm-page-container {
        padding: 4rem 0.75rem 1rem;
    }

    .rs-code-text,
    .crf-code-text,
    .imm-code-text {
        font-size: 1rem;
    }

    .ccr-credit-value {
        font-size: 1.5rem;
    }

    .jcm-modal-content,
    .ccm-modal-content,
    .imm-modal-content {
        max-width: calc(100% - 1rem);
        max-height: calc(100vh - 2rem);
    }

    .jcm-modal-footer,
    .ccm-modal-footer,
    .imm-modal-footer {
        flex-direction: column;
    }

        .jcm-modal-footer .jcm-btn,
        .ccm-modal-footer .ccm-btn,
        .imm-modal-footer .imm-btn {
            width: 100%;
        }
}

/* ============================================
   PRINT STYLES
   ============================================ */

@media print {
    .cm-page-container {
        background: white;
        padding: 0;
    }

    .cm-tabs,
    .cm-header-actions,
    .cm-btn,
    .rs-share-options,
    .crf-share-methods,
    .ccr-btn,
    .ctr-filters-row,
    .cse-tabs,
    .cmem-actions,
    .cgrp-actions,
    .cinv-actions {
        display: none !important;
    }

    .cm-card,
    .rs-card,
    .crf-card,
    .ccr-card,
    .ctr-card,
    .cse-card {
        box-shadow: none;
        border: 1px solid #ddd;
    }
}

/* ============================================
   ANIMATIONS
   ============================================ */

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pulse {
    0%, 100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.05);
    }
}
