@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
    --bg-main: #0f172a;
    --accent-blue: #2563eb;
    --accent-green: #10b981;
}

body {
    font-family: 'Plus Jakarta Sans', sans-serif;
    background-color: #f8fafc;
    color: #0f172a;
    margin: 0;
    padding: 0;
}

.custom-scrollbar::-webkit-scrollbar { width: 6px; }
.custom-scrollbar::-webkit-scrollbar-track { background: #0f172a; }
.custom-scrollbar::-webkit-scrollbar-thumb { background: #334155; border-radius: 4px; }

.premium-card {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.premium-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
}

/* 🎯 FIXED VISUAL OVERLAP ENGINE (Classes Matched to index.php/header.html) 🎯 */

/* Parent Menu Element Selector */
.nav-item-root { 
    position: relative; 
}

/* Hidden State: Shuruat me saare lists ko chupayega */
.nav-item-root .dropdown-menu-container {
    display: none !important;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    background: #ffffff;
    border: 1px solid #e2e8f0;
    box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 10px 10px -5px rgb(0 0 0 / 0.04);
    border-radius: 16px;
    padding: 16px;
    min-width: 240px;
    z-index: 9999;
}

/* Hover State: Mouse le jane par bina layout bigade grid format me khulega */
.nav-item-root:hover .dropdown-menu-container {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 6px;
}

/* Backward compatibility for old layout naming conventions */
.nav-item { position: relative; }
.nav-item .dropdown-menu-list { display: none !important; }
.nav-item:hover .dropdown-menu-list {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 6px;
    position: absolute;
    top: 100%;
    left: 0;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1);
    border-radius: 12px;
    padding: 12px;
    min-width: 200px;
    z-index: 50;
}