/* --- SIFIRLAMA --- */
body { margin: 0; padding: 0; background-color: #f8f9fc; font-family: 'Poppins', sans-serif; }
ul.lazzoni-menu, ul.lazzoni-menu li { list-style: none !important; padding: 0 !important; margin: 0 !important; }

/* --- SIDEBAR --- */
.portal-layout-wrapper { display: flex; width: 100%; min-height: 100vh; }
.lazzoni-sidebar-wrapper { width: var(--sidebar-width, 280px); background: #ffffff; height: 100vh; position: fixed; top: 0; left: 0; border-right: 1px solid #eee; display: flex; flex-direction: column; z-index: 1000; }
.sidebar-header { padding: 25px 20px; border-bottom: 1px solid #f0f0f0; }
.header-top-info { font-size: 13px; color: #444; font-weight: 500; }
.user-name { margin: 5px 0 0 0; font-size: 18px; font-weight: 700; color: #222; }
.lazzoni-menu { padding: 10px 0; overflow-y: auto; flex-grow: 1; }
.menu-link { display: flex; align_items: center; padding: 12px 20px; text-decoration: none; color: #555; transition: all 0.2s; border-left: 3px solid transparent; position: relative; }
.menu-item.active .menu-link, .menu-link:hover { background: #f8f9fa; color: #000; border-left-color: #000; }

/* KUTUSUZ İKON (Masaüstü) */
.icon-box { width: 30px; height: 30px; display: flex; align_items: center; justify-content: center; margin-right: 10px; font-size: 20px; position: relative; background: transparent !important; }
.menu-text { flex-grow: 1; font-weight: 500; font-size: 14px; }
.menu-arrow { font-size: 12px; color: #ccc; transition: transform 0.3s; }
.sidebar-footer { padding: 20px; border-top: 1px solid #f0f0f0; }
.logout-btn { display: block; text-align: center; color: #ef5350; background: #fff5f5; padding: 10px; border-radius: 8px; text-decoration: none; font-weight: 500; transition: 0.2s; }

/* ALT MENÜ */
.lazzoni-submenu { display: none; background: #fafafa; padding: 5px 0 !important; border-top: 1px solid #eee; }
.submenu-link { display: block; padding: 8px 20px 8px 60px; font-size: 13px; color: #666; text-decoration: none; transition: 0.2s; }
.submenu-link:hover { color: #000; background: #eee; }
.menu-item.open > .menu-link .menu-arrow { transform: rotate(180deg); }

/* KİLİT & POPUP */
.menu-item.locked-item .menu-link { opacity: 0.6; cursor: not-allowed; filter: grayscale(0.8); }
.lock-overlay { position: absolute; top: -5px; right: -5px; background: #333; color: #fff; width: 14px; height: 14px; border-radius: 50%; font-size: 8px; display: flex; align_items: center; justify-content: center; border: 1px solid #fff; }
.lazzoni-popup-overlay { position: fixed !important; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.6); backdrop-filter: blur(4px); z-index: 999999 !important; display: none; align_items: center; justify-content: center; }
#access-denied-card.lazzoni-popup-card { background: #ffffff !important; padding: 20px 25px !important; border-radius: 12px; width: 350px !important; max-width: 90% !important; text-align: center; box-shadow: 0 15px 50px rgba(0,0,0,0.3); height: auto !important; min-height: 0 !important; display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; gap: 8px !important; }
#access-denied-card * { margin: 0 !important; padding: 0 !important; box-sizing: border-box !important; }
.popup-icon-wrapper { width: 40px !important; height: 40px !important; background: #fff5f5 !important; color: #ef5350 !important; border-radius: 50%; display: flex !important; align_items: center !important; justify-content: center !important; font-size: 18px !important; margin-bottom: 5px !important; }
#access-denied-card h3 { color: #222 !important; font-size: 16px !important; font-weight: 700 !important; line-height: 1.2 !important; }
#access-denied-card p { color: #666 !important; font-size: 13px !important; line-height: 1.4 !important; }
#close-access-popup { background: #333 !important; color: #fff !important; border: none !important; padding: 8px 25px !important; border-radius: 6px !important; font-size: 12px !important; font-weight: 600 !important; cursor: pointer !important; margin-top: 10px !important; width: auto !important; height: auto !important; }

/* CONTENT */
.portal-content-area { margin-left: var(--sidebar-width, 280px); width: calc(100% - var(--sidebar-width, 280px)); padding: 30px; box-sizing: border-box; }
.content-header { display: flex; align_items: center; margin-bottom: 30px; }
.content-header h2 { font-size: 24px; font-weight: 600; color: #333; margin: 0; }
#mobile-menu-toggle { display: none; background: none; border: none; font-size: 24px; color: #333; margin-right: 15px; cursor: pointer; }
.welcome-box { background: white; padding: 40px; border-radius: 15px; box-shadow: 0 5px 15px rgba(0,0,0,0.03); text-align: center; }

/* --- MOBİL GÖRÜNÜM (GRID MENÜ - BÜYÜK İKONLU) --- */
@media screen and (max-width: 768px) {
    .portal-layout-wrapper { flex-direction: column; }
    .lazzoni-sidebar-wrapper { position: relative; width: 100% !important; height: auto; border-right: none; background: transparent; padding-bottom: 20px; }
    .portal-content-area { margin-left: 0; width: 100%; padding: 20px; display: none; }
    body.content-active .lazzoni-sidebar-wrapper { display: none; }
    body.content-active .portal-content-area { display: block; }
    #mobile-back-btn { display: inline-block; margin-right: 10px; font-size: 20px; }
    
    .sidebar-header { background: transparent; border: none; padding: 20px 20px 10px 20px; text-align: left; }
    .user-name { font-size: 20px; margin-top: 5px; }
    
    .lazzoni-menu { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; padding: 0 15px; overflow: visible; margin-top: 15px; }
    
    .menu-link {
        flex-direction: column; justify-content: center;
        background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px);
        border: 1px solid rgba(255, 255, 255, 0.8); box-shadow: 0 8px 20px rgba(0,0,0,0.06);
        border-radius: 20px; padding: 10px; height: 120px; text-align: center;
    }
    .icon-box { width: 55px; height: 55px; font-size: 28px; margin-right: 0; margin-bottom: 12px; background: transparent !important; }
    .icon-box i { font-size: 32px; filter: drop-shadow(0 4px 6px rgba(0,0,0,0.1)); }
    .menu-text { font-size: 13px; font-weight: 600; color: #444; line-height: 1.2; }
    .sidebar-footer { display: block !important; padding: 20px 15px; border: none; margin-top: 10px; }
    .logout-btn { background: #fff; border: 1px solid #fee2e2; color: #ef5350; box-shadow: 0 4px 10px rgba(239, 83, 80, 0.1); padding: 15px; font-size: 14px; border-radius: 12px; }

    /* MOBİLDE ALT MENÜ STİLİ */
    /* Kutunun hemen altına açılacak şekilde */
    .has-submenu { grid-row: span 2; /* Açılırsa yeri büyüsün (Grid'de zor ama CSS ile deneyelim) */ }
    .lazzoni-submenu { grid-column: 1 / -1; background: transparent; padding: 10px; border: none; }
    .lazzoni-submenu li { background: #fff; border-radius: 8px; margin-bottom: 5px; padding: 10px; box-shadow: 0 2px 5px rgba(0,0,0,0.05); }
    .lazzoni-submenu li a { color: #333; text-decoration: none; font-size: 14px; display: block; }
}