/* Color Palette - Factora Invoice System */
:root {
    /* Primary Color Palette */
    --federal-blue: #03045eff;
    --marian-blue: #023e8aff;
    --honolulu-blue: #0077b6ff;
    --blue-green: #0096c7ff;
    --pacific-cyan: #00b4d8ff;
    --vivid-sky-blue: #48cae4ff;
    --non-photo-blue: #90e0efff;
    --non-photo-blue-2: #ade8f4ff;
    --light-cyan: #caf0f8ff;

    /* Semantic Color Mapping */
    --primary: var(--honolulu-blue);
    --primary-dark: var(--marian-blue);
    --primary-darker: var(--federal-blue);
    --primary-light: var(--blue-green);
    --primary-lighter: var(--pacific-cyan);
    --secondary: var(--vivid-sky-blue);
    --secondary-light: var(--non-photo-blue);
    --secondary-lighter: var(--non-photo-blue-2);
    --accent: var(--pacific-cyan);
    --accent-light: var(--vivid-sky-blue);
    --background-light: var(--light-cyan);
    --background-lighter: var(--non-photo-blue-2);

    /* Bootstrap Overrides */
    --bs-primary: var(--primary);
    --bs-primary-rgb: 0, 119, 182;
    --bs-secondary: var(--secondary);
    --bs-success: #28a745;
    --bs-danger: #dc3545;
    --bs-warning: #ffc107;
    --bs-info: var(--accent);
    --bs-dark: var(--primary-darker);
    --bs-light: var(--background-light);
}

/* Global Color Applications */
body {
    --text-primary: var(--primary-darker);
    --text-secondary: var(--marian-blue);
    --border-color: var(--non-photo-blue);
    --link-color: var(--primary);
    --link-hover: var(--primary-dark);
}

/* Primary Button Styles */
.btn-primary {
    background-color: var(--primary);
    border-color: var(--primary);
    color: white;
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--primary-dark);
    border-color: var(--primary-dark);
    color: white;
}

.btn-primary:active {
    background-color: var(--primary-darker);
    border-color: var(--primary-darker);
}

/* Secondary Button Styles */
.btn-secondary {
    background-color: var(--secondary);
    border-color: var(--secondary);
    color: white;
}

.btn-secondary:hover,
.btn-secondary:focus {
    background-color: var(--primary-light);
    border-color: var(--primary-light);
    color: white;
}

/* Info Button Styles */
.btn-info {
    background-color: var(--accent);
    border-color: var(--accent);
    color: white;
}

.btn-info:hover,
.btn-info:focus {
    background-color: var(--accent-light);
    border-color: var(--accent-light);
    color: white;
}

/* Link Styles */
a {
    color: var(--primary);
}

a:hover {
    color: var(--primary-dark);
}

/* Navbar Styles */
.navbar-dark {
    background-color: var(--primary-darker) !important;
}

.navbar-dark .navbar-nav .nav-link {
    color: rgba(255, 255, 255, 0.9);
}

.navbar-dark .navbar-nav .nav-link:hover {
    color: var(--accent-light);
}

/* Card Header Styles */
.card-header {
    background-color: var(--primary);
    color: white;
}

.card-header.bg-primary {
    background-color: var(--primary) !important;
}

.card-header.bg-secondary {
    background-color: var(--secondary) !important;
}

/* Badge Styles */
.badge.bg-primary {
    background-color: var(--primary) !important;
}

.badge.bg-secondary {
    background-color: var(--secondary) !important;
}

.badge.bg-info {
    background-color: var(--accent) !important;
}

/* Alert Styles */
.alert-primary {
    background-color: var(--background-lighter);
    border-color: var(--accent);
    color: var(--primary-darker);
}

.alert-info {
    background-color: var(--background-lighter);
    border-color: var(--accent);
    color: var(--primary-darker);
}

/* Table Header Styles */
.table thead th {
    background-color: var(--primary);
    color: white;
    border-color: var(--primary-dark);
}

/* Form Control Focus */
.form-control:focus,
.form-select:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 0.2rem rgba(0, 180, 216, 0.25);
}

/* Progress Bar */
.progress-bar {
    background-color: var(--primary);
}

/* Pagination */
.page-link {
    color: var(--primary);
}

.page-link:hover {
    color: var(--primary-dark);
    background-color: var(--background-light);
    border-color: var(--accent);
}

.page-item.active .page-link {
    background-color: var(--primary);
    border-color: var(--primary);
}

/* Gradient Backgrounds */
.bg-gradient-primary {
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
}

.bg-gradient-secondary {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-light) 100%);
}

.bg-gradient-light {
    background: linear-gradient(135deg, var(--background-lighter) 0%, var(--background-light) 100%);
}

/* Text Colors */
.text-primary {
    color: var(--primary) !important;
}

.text-secondary {
    color: var(--secondary) !important;
}

/* Border Colors */
.border-primary {
    border-color: var(--primary) !important;
}

.border-secondary {
    border-color: var(--secondary) !important;
}

