/* ===================================================
   mobile.css - OPTIMIZED SWIPE & FIXED FOOTER
   =================================================== */

@media (max-width: 915px) {
    
    /* 1. Kunci struktur dengan Dynamic Viewport Height */
    html, body {
        height: 100% !important;
        width: 100% !important;
        margin: 0; padding: 0;
        overflow: hidden; 
        touch-action: pan-x pan-y;
    }

    .app-container {
        display: flex !important;
        flex-direction: column !important;
        /* Menggunakan dvh agar pas dengan navigasi browser mobile */
        height: 100vh !important;
        height: 100dvh !important; 
        width: 100% !important;
        overflow: hidden;
    }

    /* 2. Header Area */
    .top-header {
        flex-shrink: 0 !important;
        padding: 5px 10px !important;
        gap: 4px !important;
        background: rgba(255, 255, 255, 0.1);
    }

    .header-row h1 {
        font-size: 0.95rem !important;
        margin: 0 !important;
    }

    .user-area-container {
        margin: 2px 0 5px 0 !important;
    }

    .user-label {
        font-size: 10px !important;
        padding: 3px 8px !important;
    }

    .logout-btn {
        padding: 3px 10px !important;
        font-size: 10px !important;
    }

    /* 3. Navigasi Minggu */
    .week-nav {
        display: flex !important;
        justify-content: space-between !important;
        gap: 4px !important;
        padding: 2px 0 !important;
    }

    .week-nav button {
        flex: 1 !important;
        padding: 6px 2px !important;
        font-size: 9px !important;
        white-space: nowrap !important;
        border-radius: 8px !important;
    }

    #currentWeek {
        font-size: 10px !important;
        min-width: auto !important;
    }

    /* 4. Navigasi Hari Mobile (Sticky) */
    .mobile-day-nav {
        display: flex !important;
        flex-shrink: 0 !important;
        justify-content: space-between;
        align-items: center;
        padding: 5px 10px !important;
        background: white;
        border-bottom: 1px solid #ddd;
    }

    .nav-day-btn {
        padding: 5px 10px !important;
        font-size: 10px !important;
    }

    /* 5. Area Tengah (Grid Jadwal) - Optimasi Swipe */
    .schedule-grid {
        display: flex !important; 
        flex-direction: row !important; 
        flex-wrap: nowrap !important;
        flex: 1 !important; 
        width: 100% !important;
        min-height: 0 !important;
        overflow-x: auto !important; 
        
        /* SNAP SETTINGS: Mandatory agar berhenti tepat di kolom */
        scroll-snap-type: x mandatory !important;
        scroll-behavior: smooth;
        
        /* Mencegah scroll terlalu liar di iOS/Chrome */
        -webkit-overflow-scrolling: touch;
        gap: 0 !important;
    }

    .schedule-grid::-webkit-scrollbar { display: none; }

    .day-column {
        flex: 0 0 100% !important;
        min-width: 100% !important;
        max-width: 100% !important;
        height: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        
        /* MENGATUR SENSITIVITAS: Memaksa berhenti di tiap kolom */
        scroll-snap-align: start !important;
        scroll-snap-stop: always !important; 
        
        box-sizing: border-box !important;
        padding: 10px !important;
        background: #f4f7f6 !important;
    }

    .day-header {
        flex-shrink: 0 !important;
        background: #2c3e50;
        color: white;
        padding: 6px;
        border-radius: 6px;
        margin-bottom: 8px;
        font-size: 0.85rem;
    }

    /* 6. List Tugas (Scroll Internal) */
    .task-list {
        flex: 1 !important;
        overflow-y: auto !important;
        padding: 0 5px 10px 5px !important;
        margin: 0;
        list-style: none;
    }

    .task-item {
        background: white !important;
        border: 1px solid #ddd !important;
        margin-bottom: 5px !important;
        padding: 10px !important;
        border-radius: 8px !important;
        font-size: 12px !important;
    }

    /* 7. FIXED FOOTER (TAMBAH TUGAS) */
    .add-task-section {
        flex-shrink: 0 !important; 
        display: grid !important;
        grid-template-columns: 1fr 1.5fr auto !important;
        gap: 5px;
        /* Padding bottom ekstra agar tidak tertutup navigasi browser */
        padding: 10px 10px 20px 10px !important; 
        background: white !important;
        border-top: 2px solid #3498db;
        z-index: 999 !important;
    }

    .add-task-section select, 
    .add-task-section input, 
    .add-task-section button {
        font-size: 11px !important;
        height: 38px !important; 
        border-radius: 6px !important;
    }

    .add-task-section button {
        background: #27ae60 !important;
        color: white !important;
        font-weight: bold !important;
        padding: 0 8px !important;
    }
}

/* Sembunyikan Debug Log secara permanen */
#mobileDebugLog {
    display: none !important;
}