﻿/* ダッシュボード用レスポンシブレイアウト */

/* タブレット・モバイル（1024px未満） */
@media (max-width: 1024px) {
    :root {
        --sidebar-width: 0px;
        /* デフォルトでサイドバーを非表示 */
    }

    .sidebar {
        position: fixed;
        left: -260px;
        top: 0;
        bottom: 0;
        width: 260px;
        z-index: 100;
        border-right: 1px solid var(--border-color);
        box-shadow: 10px 0 20px rgba(0, 0, 0, 0.5);
        transition: left 0.3s ease;
    }

    .sidebar.open {
        left: 0;

        :root {
            --sidebar-width: 260px;
        }

        /* CSSだけでは変数更新不可。スタイリング用ロジックのみ */
    }

    /* ヘッダーにハンバーガーメニューを表示（必要なら後でHTML追加。今はレイアウト重視） */
    /* 今回はモバイル用にシンプルなトップバーナビ、またはサイドバー切替を想定 */

    /* カードグリッドのレスポンシブ調整 */
    .compact-grid {
        grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    }

    @media (max-width: 768px) {
        .compact-grid {
            grid-template-columns: 1fr;
        }

        .canvas-scroll {
            padding: 1.5rem 1rem;
        }
    }

    /* Adjust Header for Mobile */
    .main-header {
        padding: 0 1rem;
        gap: 0.5rem;
    }

    .header-ad {
        display: none;
    }

    /* Mobile Sidebar Toggle */
    .sidebar-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        background: transparent;
        border: none;
        color: var(--text-primary);
        font-size: 1.5rem;
        cursor: pointer;
        padding: 0;
        margin-right: 0.5rem;
    }

    /* Mobile Header Language Switcher - REMOVED to use main.css styles */
    /* .header-lang-switch block removed */

    .search-bar {
        flex: 1;
        max-width: none;
        /* Allow full width search on mobile */
    }
}

/* Desktop: Hide Mobile Controls */
@media (min-width: 1025px) {

    .sidebar-toggle {
        display: none;
    }
}
