:root {
    --topi-leaf-dark: #4f7300;
    --topi-leaf: #6e9707;
    --topi-leaf-soft: #a7d63f;
    --topi-earth: #8c3b0f;
    --topi-cream: #f8efd8;
    --topi-cream-soft: #fdf7e8;
    --topi-cream-deep: #efe1bc;
    --topi-ink: #3f4c18;
    --topi-muted-olive: #7b6a45;
}

.topi-card {
    border: 1px solid rgba(79, 115, 0, 0.12);
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 8px 22px rgba(79, 115, 0, 0.08);
}

body {
    --primary: var(--topi-leaf);
    --light: var(--topi-cream);
    --dark: #263300;
    background: linear-gradient(180deg, var(--topi-cream-soft) 0%, #f7f2e3 100%);
}

a:not(.btn),
.nav-link,
.link-primary,
.text-primary {
    color: var(--topi-leaf) !important;
}

a:not(.btn):hover,
.nav-link:hover,
.link-primary:hover,
.link-primary:focus {
    color: var(--topi-leaf-dark) !important;
}

.bg-primary {
    background-color: var(--topi-leaf) !important;
}

.border-primary {
    border-color: var(--topi-leaf) !important;
}

.dropdown-item.active,
.dropdown-item:active,
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link,
.page-item.active .page-link,
.list-group-item.active,
.progress-bar {
    background-color: var(--topi-leaf) !important;
    border-color: var(--topi-leaf) !important;
}

.page-link,
.page-link:hover,
.page-link:focus {
    color: var(--topi-leaf-dark) !important;
}

.btn:focus,
.btn-check:focus + .btn,
.btn-outline-primary:focus,
.btn-primary:focus,
.page-link:focus,
.form-check-input:focus,
.form-control:focus,
.form-select:focus {
    box-shadow: 0 0 0 0.25rem rgba(110, 151, 7, 0.18) !important;
}

.form-check-input:checked,
.form-check-input[type="checkbox"]:indeterminate {
    background-color: var(--topi-leaf) !important;
    border-color: var(--topi-leaf) !important;
}

.sidebar {
    background: linear-gradient(180deg, var(--topi-cream-soft) 0%, var(--topi-cream-deep) 100%);
    border-right: 1px solid rgba(79, 115, 0, 0.14);
}

.sidebar .navbar {
    background: transparent !important;
}

.sidebar .navbar .navbar-brand {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.sidebar .navbar .navbar-nav .nav-link {
    color: var(--topi-ink);
    border-left-color: transparent;
    transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.sidebar .navbar .navbar-nav .nav-link:hover,
.sidebar .navbar .navbar-nav .nav-link.active {
    color: var(--topi-leaf-dark);
    background: rgba(255, 255, 255, 0.72);
    border-color: var(--topi-leaf);
}

.sidebar .navbar .navbar-nav .nav-link i {
    color: var(--topi-earth);
    background: rgba(255, 255, 255, 0.62);
    border: 1px solid rgba(79, 115, 0, 0.14);
}

.sidebar .navbar .navbar-nav .nav-link:hover i,
.sidebar .navbar .navbar-nav .nav-link.active i {
    color: var(--topi-leaf-dark);
    background: rgba(167, 214, 63, 0.22);
}

.sidebar .navbar .dropdown-item {
    color: #485a0e !important;
    font-weight: 500;
}

.sidebar .navbar .dropdown-item:hover,
.sidebar .navbar .dropdown-item:focus {
    color: #2f3f00 !important;
    background: rgba(167, 214, 63, 0.2);
}

.sidebar .navbar .dropdown-item.active,
.sidebar .navbar .dropdown-item:active {
    color: #fff !important;
    background: linear-gradient(135deg, var(--topi-leaf) 0%, var(--topi-leaf-dark) 100%) !important;
}

.sidebar .navbar .navbar-nav .text-muted,
.sidebar .navbar .navbar-nav .small.text-muted {
    color: var(--topi-muted-olive) !important;
}

.content .navbar {
    background: linear-gradient(180deg, var(--topi-cream-soft) 0%, #f7ead0 100%) !important;
    border-bottom: 1px solid rgba(79, 115, 0, 0.14);
}

.content .navbar .sidebar-toggler,
.content .navbar .navbar-nav .nav-link i {
    color: var(--topi-leaf-dark);
    background: rgba(255, 255, 255, 0.62);
    border: 1px solid rgba(79, 115, 0, 0.14);
}

.content .navbar .sidebar-toggler:hover,
.content .navbar .navbar-nav .nav-link:hover i {
    background: rgba(255, 255, 255, 0.8);
}

.topi-section-title,
.topi-page-title {
    color: var(--topi-leaf-dark);
}

.topi-role-badge {
    font-size: 0.72rem;
    letter-spacing: 0.02em;
    background: linear-gradient(135deg, var(--topi-leaf) 0%, var(--topi-leaf-dark) 100%) !important;
    color: #fff;
}

.topi-logout-btn {
    border-color: #b4412f !important;
    color: #9f3023 !important;
    background: #fff;
    font-weight: 600;
}

.topi-logout-btn:hover,
.topi-logout-btn:focus {
    color: #fff !important;
    background: #b4412f !important;
    border-color: #b4412f !important;
}

.topi-logout-btn i {
    color: inherit !important;
}

.btn.btn-primary {
    color: #fff !important;
    background-color: var(--topi-leaf);
    border-color: var(--topi-leaf);
}

.btn.btn-primary:hover,
.btn.btn-primary:focus {
    color: #fff !important;
    background-color: var(--topi-leaf-dark);
    border-color: var(--topi-leaf-dark);
}

.btn.btn-secondary {
    color: #fff !important;
    background-color: #5f6f42;
    border-color: #5f6f42;
}

.btn.btn-secondary:hover,
.btn.btn-secondary:focus,
.btn.btn-secondary:active {
    color: #fff !important;
    background-color: #43512e;
    border-color: #43512e;
}

.btn.btn-danger {
    color: #fff !important;
    background-color: #b4412f;
    border-color: #b4412f;
}

.btn.btn-danger:hover,
.btn.btn-danger:focus,
.btn.btn-danger:active {
    color: #fff !important;
    background-color: #7c2318;
    border-color: #7c2318;
}

.btn.btn-info {
    color: #243000;
    background-color: #d7eeb1;
    border-color: #b8d88a;
}

.btn.btn-info:hover,
.btn.btn-info:focus,
.btn.btn-info:active {
    color: #1c2600;
    background-color: #c9e49c;
    border-color: #a6c679;
}

.btn.btn-outline-primary {
    color: var(--topi-leaf-dark);
    border-color: var(--topi-leaf);
}

.btn.btn-outline-primary:hover,
.btn.btn-outline-primary:focus {
    color: #fff;
    background-color: var(--topi-leaf);
    border-color: var(--topi-leaf);
}

.btn.btn-outline-secondary {
    color: #4e5e33;
    border-color: #5f6f42;
}

.btn.btn-outline-secondary:hover,
.btn.btn-outline-secondary:focus {
    color: #fff;
    background-color: #5f6f42;
    border-color: #5f6f42;
}

.btn.btn-outline-danger {
    color: #9f3023;
    border-color: #b4412f;
}

.btn.btn-outline-danger:hover,
.btn.btn-outline-danger:focus {
    color: #fff;
    background-color: #b4412f;
    border-color: #b4412f;
}

.btn.btn-outline-info {
    color: #3f5908;
    border-color: #9fbe65;
}

.btn.btn-outline-info:hover,
.btn.btn-outline-info:focus {
    color: #243000;
    background-color: #d7eeb1;
    border-color: #9fbe65;
}

.form-control:focus,
.form-select:focus {
    border-color: rgba(110, 151, 7, 0.55);
    box-shadow: 0 0 0 0.25rem rgba(110, 151, 7, 0.16);
}

.topi-section-title {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 0.9rem;
}

.topi-page-title {
    font-weight: 700;
}

.topi-brand-logo {
    max-height: 90px;
    width: auto;
    object-fit: contain;
    display: block;
    margin: 0 auto;
}

@media (max-width: 575.98px) {
    .topi-page-title {
        font-size: 1.1rem;
    }
}
