/* ============================================================
   WeCheck モバイルメニュー専用スタイル
   ブレークポイント基準: 768px
   変更する場合: 下記 @media の max-width: 767px / min-width: 768px を一括変更すること
   PC幅 (768px 以上) には一切影響しない構成
   ============================================================ */

/* ---- PC幅では全モバイル専用要素を完全非表示 ---- */
@media only screen and (min-width: 769px) {
    .wc-mobile-hamburger     { display: none !important; }
    .wc-mobile-backdrop      { display: none !important; }
    .wc-mobile-profile-panel { display: none !important; }
    .wc-search-toggle-btn    { display: none !important; }
    .nav-left-sidebar.sidebar-dark{
        /*開いたまま画面サイズを変えた場合、強制的に高さ調節を適用する*/
        top:40px !important;
    }
}

/* ================================================================
   モバイル幅専用 (max-width: 767px)
   既存 layout.css の 768px ルールを !important で最小限上書き。
   上書き対象:
     - .nav-left-sidebar (position:relative → fixed オフスクリーン)
     - .dashboard-wrapper (margin-left: 264px → 0)
     - .dashboard-header .navbar-toggler (Bootstrap toggler 非表示)
     - #navbarSupportedContent (collapse → 常時表示)
   ================================================================ */
@media only screen and (max-width: 768px) {
    /* ---- 3本線ハンバーガーボタン ---- */
    .wc-mobile-hamburger {
        margin-top: 0;
        display: inline-flex;
        justify-content: center;
        align-items: center;
        margin-left: 5px;
        width: 38px;
        height: 38px;
        background: transparent;
        border: none;
        cursor: pointer;
        padding: 4px;
        flex-shrink: 0;
        outline: none !important; /* フォーカス時の輪郭線 */
        box-shadow: none !important; /* ボックスシャドウ */
        -webkit-appearance: none; /* WebKit系のデフォルトボタン外観 */
        appearance: none; /* 標準のデフォルトボタン外観 */
    }


        .wc-mobile-hamburger:hover,
        .wc-mobile-hamburger:focus,
        .wc-mobile-hamburger:active {
            outline: none !important;
            box-shadow: none !important;
            background: transparent !important;
            border: none !important;
        }

    /* ---- 既存 Bootstrap navbar-toggler を非表示
           スコープを .dashboard-header 内の直接子 nav に限定して影響範囲を閉じる ---- */
    .dashboard-header > nav > .navbar-toggler {
        display: none !important;
    }

    .dashboard-header .navbar {
        flex-wrap: nowrap !important;
    }

    /* ---- ヘッダー: #navbarSupportedContent を常時表示
           通知/チャットアイコンをヘッダーに常駐させるための上書き
           flex:1 で残りスペースを占有し ml-auto でアイコンを右寄せ ---- */
    #navbarSupportedContent {
        display: flex !important;
        flex: 1 !important;
        padding: 0 !important;
        flex-basis: 0% !important;
    }

    /* ---- ヘッダー: 通知/チャットアイコンを横並びに強制
           Bootstrap の .navbar-nav はモバイルで flex-direction:column になるため上書き ---- */
    #navbarSupportedContent .navbar-nav {
        flex-direction: row !important;
        align-items: center !important;
    }

    /* ---- ヘッダー: プロフィールと機関名を非表示
           モバイルではオーバーレイ内プロフィールパネルに表示するため ---- */
    .dashboard-header .medication-name {
        display: none !important;
    }

    .dashboard-header .nav-user {
        display: none !important;
    }

    /* ---- 既存サイドバー: layout.css の 768px ルールを上書きしてオフスクリーン固定に変更
           上書き元: .nav-left-sidebar { position:relative; width:100%; top:0; right:0; }
           top / height は JS (openWeCheckMobileMenu) が実行時に動的に上書きする ---- */
    .nav-left-sidebar {
        position: fixed !important;
        left: -280px !important;
        top: 60px !important;
        height: calc(100% - 60px) !important;
        width: 264px !important;
        z-index: 1045 !important;
        transition: left 0.3s ease;
        overflow-y: auto;
    }

    /* ---- サイドバー内の Bootstrap toggler を非表示 ---- */
    .nav-left-sidebar .navbar-toggler {
        display: none !important;
    }

    /* ---- サイドバー内の "Dashboard" テキストリンク (d-xl-none d-lg-none) を非表示 ---- */
    .nav-left-sidebar .d-xl-none.d-lg-none {
        display: none !important;
    }

    /* ---- dashboard-wrapper: layout.css でも 0 になるが念のため明示 ---- */
    .dashboard-wrapper {
        margin-left: 0 !important;
        top: 0 !important;
    }

    /* ---- オーバーレイ背景 ---- */
    .wc-mobile-backdrop {
        display: none;
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.45);
        z-index: 1040;
    }

    /* ---- モバイル プロフィールパネル
           top:0 から始まりサイドバー上部に重なるオーバーレイヘッダーとして機能
           高さは height:auto で中身に合わせて伸縮 (空 label は実質高さ 0)
           背景は白、テキストは濃紺 (見本に合わせた配色) ---- */
    .wc-mobile-profile-panel {
        position: fixed;
        left: -280px;
        top: 0;
        width: 264px;
        height: auto;
        z-index: 1046;
        background-color: #fff;
        display: flex;
        align-items: flex-start;
        padding: 10px 12px;
        transition: left 0.3s ease;
        box-sizing: border-box;
        border-bottom: 1px solid #e6e6f2;
    }

    .wc-mobile-profile-content {
        display: flex;
        flex-direction: column;
        justify-content: center;
        flex: 1;
        min-width: 0;
    }

    /* 機関名: 空のとき label は実質高さ 0 になる (中身なし・width 未指定のため) */
    .wc-mobile-clinic-name {
        display: block;
        color: #1B3553;
        font-size: 11px;
        font-weight: 600;
        margin-bottom: 4px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .wc-mobile-profile-row {
        position: relative;
        display: flex;
        align-items: center;
    }

    .wc-mobile-profile-link {
        display: flex;
        align-items: center;
        color: #1B3553;
        text-decoration: none;
        cursor: pointer;
        min-width: 0;
    }

        .wc-mobile-profile-link .user-info-name {
            margin-left: 8px;
            min-width: 0;
        }

        .wc-mobile-profile-link .user-info-name-primary {
            display: block;
            color: #1B3553;
            font-size: 13px;
            font-weight: bold;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            max-width: 150px;
            margin-bottom: 0;
            cursor: pointer;
        }

        .wc-mobile-profile-link .user-info-name-sub {
            display: block;
            color: #71789e;
            font-size: 11px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            max-width: 150px;
        }

    .wc-mobile-profile-dropdown {
        min-width: 200px;
    }

    /* ================================================================
       メニューオープン時 (JS が body.wc-mobile-menu-open を付与した状態)
       ================================================================ */

    body.wc-mobile-menu-open {
        overflow: hidden;
    }

    body.wc-mobile-menu-open .wc-mobile-backdrop {
        display: block;
    }

    body.wc-mobile-menu-open .wc-mobile-profile-panel {
        left: 0;
    }

    body.wc-mobile-menu-open .nav-left-sidebar {
        left: 0 !important;
    }

    /* サイドバー内の #navbarNav (Bootstrap collapse) をメニュー展開時に強制表示 */
    body.wc-mobile-menu-open .nav-left-sidebar #navbarNav {
        display: block !important;
        }

    /* ================================================================
       一覧系ページ 検索カード モバイルレイアウト統一
       Doctor を基準に、見本寄せの方向で共通部を調整
       対象ページ: Doctor, Patient, PatientGroup, PatientRequest,
                   MedicalTeam, Operator, ServiceRequest, Partner,
                   MedicalInstitution, Notice
       ================================================================ */

    /* 検索行: 横並び → 縦積み */
    .content-row {
        flex-direction: column !important;
        align-items: stretch !important;
        width: 100% !important;
        padding:0 10px;
    }

    /* 各フィルター区画: 全幅・縦積み（ラベル上・入力欄下）・下余白 */
    .content-row-filter {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }

    /* ラベル: 縮退防止・余白調整 */
    .label-content-row {
        flex-shrink: 0 !important;
        margin: 5px 0 !important;
    }

    /* カテゴリ・ソートドロップダウン: column モードで全幅 */
    .dropdown-category,
    .dropdown-category-sort {
        width: 100% !important;
        flex: 0 0 auto !important;
        min-width: 0 !important;
    }

    /* 件数ドロップダウン: コンパクト幅維持 */
    .dropdown-category-count {
        width: auto !important;
        min-width: 0 !important;
    }

    /* select2 コンテナ: 親コンテナに合わせて全幅
       layout.css の .sortList .select2-container 300px !important (0,2,0) を
       複合セレクタ (0,3,0) で上書き */
    .dropdown-category-sort.sortList .select2-container,
    .dropdown-category .select2-container {
        width: 100% !important;
    }

    /* 検索区画内 select2: layout.css の 200px !important (0,3,0) を (0,4,0) で上書き */
    .collapsible .collapsible-content-search .dropdown-category .select2-container {
        width: 100% !important;
    }

    /* キーワード入力欄: column モードで全幅 */
    .input-search {
        width: 100% !important;
        flex: 0 0 auto !important;
    }

    /* テキスト input: 親 .input-search を全幅で埋める
       layout.css の input[type="text"] 90% !important (0,2,1) を (0,3,0) で上書き */
    .collapsible .collapsible-content-search .input-search .search-box {
        width: 100% !important;
        box-sizing: border-box !important;
    }

    /* select 要素: 全幅 */
    .search-list {
        width: 100% !important;
        box-sizing: border-box !important;
    }

    /* 検索ボタン: min-width 解放 */
    .button-search {
        min-width: 0 !important;
        width: auto !important;
    }

    /* Filter トグルボタン: min-width 解放 */
    .collapsible-dropdown-button-d {
        min-width: 0 !important;
    }

    /* リセットボタンコンテナ: 右寄せ → 通常フロー・下余白 */
    .button-reset {
        min-width: 0 !important;
        margin: 0 0 10px 0 !important;
    }

    /* リセットリンク: 幅自動維持 */
    .filter-reset-btn {
        width: auto !important;
    }

    /* ステータス等ボタン群: 固定幅解除・折返し対応 */
    .list-button-content-row {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 4px !important;
        align-items: center !important;
        width: 100% !important;
        min-width: 0 !important;
    }

    /* 縦線セパレーター: 非表示 */
    .line-content-row {
        display: none !important;
    }

    /* テーブルコンテナ: 横スクロール許可 */
    #table-container-wc {
        overflow-x: auto;
        width: 100%;
    }

    /* 検索カード内 padding */
    .collapsible-content-search {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }

    /* 展開フィルターエリア padding: layout.css の 18px (0,1,0) を (0,2,0) で縮小 */
    .card-collapsible .collapsibleContent {
        padding-left: 20px !important;
        padding-right: 10px !important;
    }

    /* Sort 全幅・Count+Reset 同行レイアウト
       doctor.css の .content-row (0,1,0 !important) に勝つため複合セレクタ (0,2,0) で指定 */
    .content-row.base-filter-option {
        flex-direction: row !important;
        flex-wrap: wrap !important;
        align-items: center !important;
    }

    /* Sort: 1行占有 */
    .base-filter-option > .content-row-filter:first-child {
        flex: 0 0 100% !important;
    }

    /* Count: コンパクト幅（共通の width: 100% を (0,3,0) で無効化） */
    .base-filter-option > .content-row-filter:not(:first-child) {
        flex: 0 0 auto !important;
        width: auto !important;
        margin-bottom: 0 !important;
    }

    /* Reset: Count の右側へ展開・右寄せ */
    .base-filter-option > .button-reset {
        flex: 1 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        margin-right: 10px !important;
    }

    /* ================================================================
       見本寄せ 微調整
       ================================================================ */

    /* m-l-10 の margin-left: 30px をフィルター行内では無効化
       （PC 横並びレイアウト用スペーサーのためモバイルでは不要） */
    .content-row-filter .label-content-row {
        margin-left: 0 !important;
    }

    /* Filter ボタンの PC 用余白を解除
       layout.css の (0,3,0) を (0,4,0) で上書き */
    .collapsible .collapsible-content-search .content-row-filter .collapsible-dropdown-button-d {
        margin-top: 0 !important;
        margin-right: 0 !important;
        text-align: left !important;
    }

    /* Search/Filter ボタン行のみ横並び・中央寄せ
       column に変えた content-row-filter を最後の行（ボタン行）だけ row に戻す */
    .collapsible-content-search .content-row > .content-row-filter:last-child {
        display: grid !important;
        grid-template-columns: 1fr auto 1fr;
        align-items: center !important;
        width: 100% !important;
        margin-top: 10px;
    }


        /* Search を中央 */
        .collapsible-content-search .content-row > .content-row-filter:last-child .button-search {
            grid-column: 2;
            justify-self: center;
            width: auto !important;
            min-width: 0 !important;
            margin: 0 !important;
        }

        /* Filter を右端 */
        .collapsible-content-search .content-row > .content-row-filter:last-child .collapsible-dropdown-button-d {
            grid-column: 3;
            justify-self: end;
            min-width: 0 !important;
            margin: 0 !important;
            text-align: right !important;
        }

    /* フィルター行の下 padding 解除: margin-bottom 8px + padding-bottom 5px = 13px → 8px に */
    .filter-option .content-row-filter {
        padding: 0 10px;
    }

    /* ================================================================
       Doctor 検索カード モバイル個別調整
       共通ルール適用後も doctor.css の固定幅指定が残る箇所を
       複合セレクタで特異度を上げて上書きする
       ================================================================ */

    /* Team ドロップダウン: column モードで全幅
       doctor.css の width: 170px !important (0,1,0) を (0,2,0) で上書き */
    .dropdown-category.team-list-content-row {
        width: 100% !important;
        flex: 0 0 auto !important;
        min-width: 0 !important;
    }

    /* Team select2: 固定幅解除 (doctor.css 0,2,0 → こちら 0,3,0) */
    .dropdown-category.team-list-content-row .select2,
    .dropdown-category.team-list-content-row .select2-container {
        width: 100% !important;
    }

    /* User Role ドロップダウン: column モードで全幅
       doctor.css の width: 310px !important (0,1,0) を (0,2,0) で上書き */
    .dropdown-category.role-list-content-row {
        width: 100% !important;
        flex: 0 0 auto !important;
        min-width: 0 !important;
    }

    /* User Role select2: 固定幅解除 (doctor.css 0,2,0 → こちら 0,3,0) */
    .dropdown-category.role-list-content-row .select2-container {
        width: 100% !important;
    }

    /* Count 行だけ ラベル左 + セレクト右 の横並び */
    .base-filter-option > .content-row-filter:nth-child(2) {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        width: auto !important;
    }

        .base-filter-option > .content-row-filter:nth-child(2) .label-content-row {
            flex-shrink: 0 !important;
            margin: 0 10px 0 0 !important;
        }

        .base-filter-option > .content-row-filter:nth-child(2) .dropdown-category-count {
            width: auto !important;
            min-width: 65px !important;
        }

    /* ================================================================
       検索フォーム開閉トグル (Search 見出し行右端)
       ================================================================ */

    /* 見出し行: flex 配置 + 高さ固定解除（常時適用） */
    .collapsible .collapsible-content-div {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        height: auto !important;        /* layout.css の height: 30px 固定を解除 */
        min-height: 36px !important;    /* クリック領域確保 */
        padding: 4px 0 !important;      /* 上下余白 */
    }

    /* 見出しラベル: height: inherit・margin を解除（常時適用） */
    .collapsible .collapsible-content-div label:first-child {
        height: auto !important;
        margin: 0 !important;
        line-height: 1.4 !important;
    }

    /* トグルボタン本体 */
    .wc-search-toggle-btn {
        background: none;
        border: none;
        padding: 0 4px;
        cursor: pointer;
        color: #0c5ab6;
        line-height: 1;
        flex-shrink: 0;
        outline: none !important;
        box-shadow: none !important;
        width:30px;
        margin-right:20px;
    }

        .wc-search-toggle-btn:hover,
        .wc-search-toggle-btn:focus,
        .wc-search-toggle-btn:active {
            outline: none !important;
            box-shadow: none !important;
            background: none !important;
            border: none !important;
            color: #0c5ab6 !important;
        }

    /* 閉じた状態: .collapsible の下余白（上下対称スペース） */
    .card-collapsible.wc-search-collapsed .collapsible {
        padding-bottom: 10px !important;
    }

    /* 閉じた状態: 検索フォーム・hr・フィルターエリアを非表示 */
    .card-collapsible.wc-search-collapsed .collapsible-content-search,
    .card-collapsible.wc-search-collapsed .collapsible-hr,
    .card-collapsible.wc-search-collapsed .collapsibleContent {
        display: none !important;
    }

    /* 閉じた状態: アイコン反転 (∧ → ∨) */
    .card-collapsible.wc-search-collapsed .wc-search-toggle-icon {
        transform: rotate(180deg);
    }
    .graph-header {
        margin-top: 0px !important;
    }

    /* 1) PC absolute配置をモバイルで解除（重なり防止） */
    #dashboard-ecommerce .dashboard-export-buttons,
    #dashboard-ecommerce .dashboard-patient-info {
/*        position: static !important;
        right: auto !important;*/
    }
    /* 2) 3ボタンを欠けずに表示 */
    #dashboard-ecommerce .dashboard-export-buttons {
        width: 100% !important;
        display: flex !important;
        gap: 8px !important;
        flex-wrap: nowrap !important;
        margin-top: 4px !important;
    }

        #dashboard-ecommerce .dashboard-export-buttons .nav-link {
            flex: 1 1 0 !important;
            min-width: 0 !important;
            justify-content: center !important;
        }

            #dashboard-ecommerce .dashboard-export-buttons .nav-link span {
                white-space: nowrap !important;
                overflow: hidden !important;
                text-overflow: ellipsis !important;
            }
    /* 3) 患者情報のはみ出し防止 */
    #dashboard-ecommerce .dashboard-patient-info {
        order: 2 !important;
        display: flex !important;
        position: static !important; /* 重要：PC用の絶対配置を完全に無効化 */
        margin-left: auto !important;
        margin-top: 65px !important; /* 見出しと高さを揃える */
    }
        #dashboard-ecommerce .dashboard-patient-info .nav-link {
            background-color: #F4F4F4 !important;
            border-radius: 10px !important;
            padding: 5px 12px !important;
            display: flex !important;
            align-items: center !important;
        }
        #dashboard-ecommerce .dashboard-patient-info .user-info-name-primary,
        #dashboard-ecommerce .dashboard-patient-info .user-info-name-sub {
            white-space: nowrap !important;
            overflow: hidden !important;
            text-overflow: ellipsis !important;
        }
    #dashboard-ecommerce .graph-header {
        display: flex !important;
        flex-wrap: wrap !important;
        align-items: center !important;
        gap: 8px !important;
    }
        /* 1行目: 見出し */
        #dashboard-ecommerce .graph-header > nav {
            order: 1 !important;
            /*            flex: 0 0 100% !important;
            width: 100% !important;*/
            flex: 0 1 auto !important;
            width: auto !important;
            margin-top: 65px;
        }

            #dashboard-ecommerce .graph-header > nav .breadcrumb {
                margin: 0 !important;
                padding: 0 !important;
            }

        /* 2行目: ボタン1,2,3 */
        #dashboard-ecommerce .graph-header .dashboard-export-buttons {
            order: 2;
            flex: 0 0 100% !important;
            width: 100% !important;
            display: grid !important;
            grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
            gap: 8px !important;
            position: static !important;
            right: auto !important;
            margin-top: 4px !important; 
        }

            #dashboard-ecommerce .graph-header .dashboard-export-buttons .nav-link {
                min-width: 0 !important;
                justify-content: center !important;
                padding: 8px 8px !important;
            }

                #dashboard-ecommerce .graph-header .dashboard-export-buttons .nav-link span {
                    white-space: nowrap !important;
                    overflow: hidden !important;
                    text-overflow: ellipsis !important;
                    min-width:auto;
                }

    /*表タイトル*/
    /* ▼ 追加：スマホ時はタイトルを非表示 ▼ */
    .wc-table-title {
        display: none !important;
    }

    /*詳細*/
    /*.detail-body{
        margin-top: 100px;
    }*/

    /*医療機関申請*/
    .navbar-fixed.navbar-create-request{
        margin-top:60px;
    }


}

@media only screen and (max-width: 391px){
    /* ---- 3本線ハンバーガーボタン ---- */
    .wc-mobile-hamburger {
        margin-left: 0;
        padding: 4px;
    }

    .navbar-right-top .nav-item .nav-link {
        padding: 6px 4px 0 !important;
        margin-left: 0 !important;
    }

    .navbar.navbar-expand-md.bg-white.fixed-top .navbar-brand {
        margin-right: 0;
    }

    .dashboard-patient-chart{
        padding:20px !important;
    }

    /* 3) 患者情報のはみ出し防止 */
    #dashboard-ecommerce .dashboard-patient-info {
        position: static !important; /* 重要：PC用の絶対配置を完全に無効化 */
        max-width:120px; /*患者の表示を小さくする*/
        margin-top: 65px !important; /* 見出しと高さを揃える */
    }

    /*表示が完全に重なるため、中央に寄せる*/
    .base-filter-option > .button-reset {
        display: flex !important;
        align-items: center !important;
        justify-self: center;
        margin: auto !important;
        padding-top: 5px;
    }

    .content-row.base-filter-option {
        flex-direction: column !important;
        flex-wrap: wrap !important;
        align-items: baseline !important;
    }

    .card{
        min-width: auto !important;
        min-height:auto !important;
    }

    #dashboardSetting{
        max-width:300px;
    }
}
