/* ====================================
   MUTUELLE HARENA - CUSTOM THEME
   ==================================== */

/* Color Palette */
:root {
    /* Main Colors */
    --primary: #006837;
    --primary-dark: #004d28;
    --primary-light: #008a45;

    /* Accent Colors */
    --accent-1: #c41e3a;
    --accent-2: #fdb913;
    --accent-3: #e67e22;
    --accent-4: #7d2842;

    /* Sidebar */
    --sidebar-bg: #2d3748;
    --sidebar-bg-dark: #1a202c;
    --sidebar-text: rgba(255, 255, 255, 0.85);
    --sidebar-hover: rgba(255, 255, 255, 0.1);
    --sidebar-active: rgba(255, 255, 255, 0.15);

    /* Neutral */
    --gray-dark: #4a5568;
    --gray: #718096;
    --gray-light: #e2e8f0;
    --gray-lighter: #f7fafc;

    /* Background */
    --bg-main: #f4f6f9;
    --bg-card: #ffffff;

    /* Text */
    --text-primary: #2d3748;
    --text-secondary: #4a5568;
    --text-muted: #718096;
}

/* Global Styles */
body {
    background-color: var(--bg-main);
    color: var(--text-primary);
    font-family: 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

/* ====================================
   SIDEBAR - Dark Gray Theme
   ==================================== */
.main-sidebar {
    background: linear-gradient(180deg, var(--sidebar-bg-dark) 0%, var(--sidebar-bg) 100%);
    box-shadow: 2px 0 6px rgba(0, 0, 0, 0.1);
}

/* Brand Logo */
.main-sidebar .brand-link {
    background-color: var(--sidebar-bg-dark);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    color: #ffffff;
    font-weight: 600;
    padding: 0.8125rem 1rem;
    transition: all 0.3s;
}

.main-sidebar .brand-link:hover {
    background-color: var(--sidebar-bg);
}

.main-sidebar .brand-text {
    color: #ffffff !important;
    font-size: 1.2rem;
    letter-spacing: 0.5px;
}

/* Sidebar Menu */
.sidebar-dark-primary .nav-sidebar > .nav-item > .nav-link {
    color: var(--sidebar-text);
    border-left: 3px solid transparent;
    transition: all 0.3s ease;
}

.sidebar-dark-primary .nav-sidebar > .nav-item > .nav-link:hover {
    background-color: var(--sidebar-hover);
    color: #ffffff;
    border-left-color: var(--accent-2);
}

.sidebar-dark-primary .nav-sidebar > .nav-item > .nav-link.active {
    background-color: var(--sidebar-active);
    color: #ffffff;
    border-left-color: var(--accent-2);
    font-weight: 600;
}

.sidebar-dark-primary .nav-sidebar > .nav-item > .nav-link > .nav-icon {
    color: var(--accent-2);
}

/* Sidebar Submenu */
.sidebar-dark-primary .nav-treeview > .nav-item > .nav-link {
    color: rgba(255, 255, 255, 0.75);
    padding-left: 2rem;
}

.sidebar-dark-primary .nav-treeview > .nav-item > .nav-link:hover {
    background-color: rgba(255, 255, 255, 0.08);
    color: #ffffff;
}

.sidebar-dark-primary .nav-treeview > .nav-item > .nav-link.active {
    background-color: rgba(255, 255, 255, 0.12);
    color: #ffffff;
}

/* ====================================
   NAVBAR
   ==================================== */
.main-header.navbar {
    background-color: #ffffff;
    border-bottom: 1px solid var(--gray-light);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
}

.main-header .nav-link {
    color: var(--text-secondary);
    transition: color 0.3s;
}

.main-header .nav-link:hover {
    color: var(--primary);
}

/* ====================================
   CONTENT
   ==================================== */
.content-wrapper {
    background-color: var(--bg-main);
}

.content-header h1 {
    color: var(--text-primary);
    font-weight: 600;
}

/* Cards */
.card {
    border: none;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.3s;
}

.card:hover {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.12);
}

.card-header {
    background-color: transparent;
    border-bottom: 2px solid var(--gray-light);
    font-weight: 600;
    color: var(--text-primary);
}

/* ====================================
   BUTTONS
   ==================================== */
.btn-primary {
    background-color: var(--primary);
    border-color: var(--primary);
    color: #ffffff;
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--primary-dark);
    border-color: var(--primary-dark);
    color: #ffffff;
}

.btn-success {
    background-color: var(--primary-light);
    border-color: var(--primary-light);
}

.btn-danger {
    background-color: var(--accent-1);
    border-color: var(--accent-1);
}

.btn-warning {
    background-color: var(--accent-2);
    border-color: var(--accent-2);
    color: var(--text-primary);
}

.btn-info {
    background-color: var(--accent-3);
    border-color: var(--accent-3);
}

/* ====================================
   TABLES
   ==================================== */
.table thead th {
    background-color: var(--primary);
    color: #ffffff;
    border: none;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.875rem;
    letter-spacing: 0.5px;
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(0, 104, 55, 0.03);
}

.table-hover tbody tr:hover {
    background-color: rgba(0, 104, 55, 0.08);
}

/* ====================================
   FORMS
   ==================================== */
.form-control:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 0.2rem rgba(0, 104, 55, 0.15);
}

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

/* ====================================
   BADGES & ALERTS
   ==================================== */
.badge-primary {
    background-color: var(--primary);
}

.badge-success {
    background-color: var(--primary-light);
}

.badge-danger {
    background-color: var(--accent-1);
}

.badge-warning {
    background-color: var(--accent-2);
    color: var(--text-primary);
}

.badge-info {
    background-color: var(--accent-3);
}

.alert-primary {
    background-color: rgba(0, 104, 55, 0.1);
    border-color: var(--primary);
    color: var(--primary-dark);
}

.alert-success {
    background-color: rgba(0, 138, 69, 0.1);
    border-color: var(--primary-light);
    color: var(--primary-dark);
}

.alert-danger {
    background-color: rgba(196, 30, 58, 0.1);
    border-color: var(--accent-1);
    color: var(--accent-1);
}

.alert-warning {
    background-color: rgba(253, 185, 19, 0.1);
    border-color: var(--accent-2);
    color: #856404;
}

/* ====================================
   FOOTER
   ==================================== */
.main-footer {
    background-color: #ffffff;
    border-top: 1px solid var(--gray-light);
    color: var(--text-muted);
}

/* ====================================
   UTILITIES
   ==================================== */
.text-primary {
    color: var(--primary) !important;
}

.bg-primary {
    background-color: var(--primary) !important;
}

.border-primary {
    border-color: var(--primary) !important;
}

/* ====================================
   COMPACT LISTS
   ==================================== */
.compact-table td,
.compact-table th {
    padding: 0.3rem !important;
    font-size: 0.875rem;
    vertical-align: middle;
}

.compact-table th {
    white-space: nowrap;
}

.compact-table .btn-sm {
    padding: 0.15rem 0.4rem;
    font-size: 0.75rem;
}

.compact-search {
    max-width: 400px;
}

/* ====================================
   TABLE RESPONSIVE HORIZONTAL
   ==================================== */
.table-responsive-horizontal {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.table-responsive-horizontal table td,
.table-responsive-horizontal table th {
    white-space: nowrap;
}

/* ====================================
   RESPONSIVE
   ==================================== */
@media (max-width: 768px) {
    .main-sidebar {
        box-shadow: none;
    }

    .content-header h1 {
        font-size: 1.5rem;
    }
}
