:root {
    --primary-color: #1e40af;
    --secondary-color: #f59e0b;
    --dark-blue: #1e3a8a;
    --light-blue: #dbeafe;
}

body {
    font-family: 'Inter', sans-serif;
    line-height: 1.6;
}

.bg-primary-custom {
    background: linear-gradient(180deg, rgb(42, 51, 66) 0%, rgb(33, 37, 41) 100%);
}

.no-hyperlink {
    text-decoration: none !important;
    color: inherit !important;
}

.in-dropdown:hover {
    .collapse:not(.show) {
        display: block;
    }
}

/* ======== Navbar ======== */
.navbar-custom {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.btn-custom-navbar {
    background: var(--secondary-color);
    border: none;
    color: white;
    font-weight: 600;
    padding: 10px 20px;
    border-radius: 50px;
    transition: all 0.3s ease;
}

.btn-custom-navbar:hover {
    background: #d97706;
    color: white;
    transform: translateY(-2px);
}

/* ========= Custom offcanvas ========= */
/* Dev offcanvas custom design */
#devOffcanvas {
    width: 340px;
    background: linear-gradient(180deg, rgba(8,15,30,0.98), rgba(14,22,38,0.98));
    color: #e6eef8;
    border-left: 1px solid rgba(255,255,255,0.04);
    backdrop-filter: blur(6px);
}

/* Header */
#devOffcanvas .offcanvas-header {
    padding: 1rem 1rem;
    border-bottom: 1px solid rgba(255,255,255,0.03);
    background: transparent;
}

#devOffcanvas .offcanvas-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--light-blue);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Close button */
#devOffcanvas .btn-close {
    filter: invert(1) brightness(1.2);
    opacity: 0.9;
}

/* Body & scrollbar */
#devOffcanvas .offcanvas-body {
    padding: 0.75rem 0.75rem 1rem;
    max-height: calc(100vh - 72px);
    overflow-y: auto;
}

#devOffcanvas .offcanvas-body::-webkit-scrollbar {
    width: 8px;
}
#devOffcanvas .offcanvas-body::-webkit-scrollbar-track {
    background: transparent;
}
#devOffcanvas .offcanvas-body::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.06);
    border-radius: 6px;
}

/* List items & links */
#devOffcanvas .list-unstyled a {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    color: rgba(230,238,248,0.95);
    padding: 0.5rem 0.6rem;
    border-radius: 8px;
    transition: background 0.15s ease, transform 0.12s ease;
    text-decoration: none;
}

#devOffcanvas .list-unstyled a:hover {
    background: rgba(255,255,255,0.03);
    transform: translateX(4px);
    text-decoration: none;
}

/* Icons */
#devOffcanvas .bi {
    color: var(--secondary-color);
    font-size: 1.05rem;
}

/* Collapsible caret rotation when open */
#devOffcanvas a[aria-expanded="true"] .bi-caret-down-fill {
    transform: rotate(180deg);
    transition: transform 0.18s ease;
}

/* Nested collapse list */
#devOffcanvas .collapse {
    margin-top: 0.25rem;
}

#devOffcanvas .ps-3 a {
    padding-left: 1.05rem;
    font-size: 0.95rem;
    color: rgba(230,238,248,0.9);
}

/* Small separators & spacing */
#devOffcanvas .list-unstyled li + li {
    margin-top: 0.35rem;
}

/* Small section label (if used) */
#devOffcanvas .dev-section {
    font-size: 0.78rem;
    text-transform: uppercase;
    color: rgba(255,255,255,0.35);
    padding: 0.5rem 0.6rem;
}
