/* ========================================
   EywaLink Core 自定義樣式
   注意：避免使用全域選擇器覆蓋 MudBlazor 預設樣式
   ======================================== */

/* 如需自定義按鈕樣式，請使用特定 class 而非全域 .mud-button */
/* 例如：.my-custom-button { background-color: green; } */

.mud-card {
    border: 1px solid #ccc; /* 自定義卡片邊框 */
}

/* ========================================
   製程範本選擇器對話框樣式
   Process Template Selector Dialog
   使用更具體的 CSS 選擇器來覆蓋 MudBlazor 預設寬度
   ======================================== */

/* 針對所有 MudDialog - 增加最大寬度 */
.mud-dialog-container {
    max-width: none !important;
}

.mud-dialog.mud-dialog-width-xl {
    max-width: 1400px !important;
    width: 95vw !important;
}

/* 確保對話框標題有足夠空間 */
.process-template-dialog-title {
    width: 100% !important;
    white-space: normal !important;
    word-wrap: break-word !important;
}

/* 確保對話框內容區域有足夠空間 */
.process-template-dialog-content {
    max-height: 80vh !important;
    overflow-y: auto !important;
}

/* 行動端調整 */
@media (max-width: 959.98px) {
    .mud-dialog.mud-dialog-width-xl {
        width: 98vw !important;
        max-width: 100% !important;
        margin: 0.5rem !important;
    }
}

/* ========================================
   雙欄對話框樣式 (Two-Column Dialog)
   適用於 TagProperties 和 ComProperties 編輯
   支援跨平台響應式設計
   ======================================== */

/* 雙欄對話框基本樣式 */
.two-column-dialog.mud-dialog {
    width: 95vw !important;
    max-width: 1200px !important;
}

/* 行動端調整 (螢幕寬度 < 600px) */
@media (max-width: 599.98px) {
    .two-column-dialog.mud-dialog {
        width: 95vw !important;
        max-width: 100% !important;
        margin: 0.5rem !important;
    }
    
    .two-column-dialog .mud-dialog-content {
        max-height: 75vh !important;
        overflow-y: auto !important;
    }
}

/* 平板端調整 (600px - 959px) */
@media (min-width: 600px) and (max-width: 959.98px) {
    .two-column-dialog.mud-dialog {
        width: 90vw !important;
        max-width: 950px !important;
    }
}

/* 桌面端調整 (≥ 960px) */
@media (min-width: 960px) {
    .two-column-dialog.mud-dialog {
        width: 90vw !important;
        max-width: 1200px !important;
    }
}

/* 確保對話框內容可滾動 */
.two-column-dialog .mud-dialog-content {
    max-height: 80vh !important;
    overflow-y: auto !important;
}

/* ========================================
   Properties 欄位間距樣式
   適用於 TagProperties 和 ComProperties
   ======================================== */

/* Properties 區域內的 MudGrid 間距 */
.two-column-dialog .mud-grid {
    row-gap: 0.5rem;
}

/* Properties 區域內的 MudItem 間距 */
.two-column-dialog .mud-grid > .mud-grid-item {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
}

/* 數值欄位和下拉選單的間距 */
.two-column-dialog .mud-input-control {
    margin-bottom: 0.5rem;
}

/* Checkbox 的間距 */
.two-column-dialog .mud-checkbox {
    margin-bottom: 0.5rem;
}

/* Switch 的間距 */
.two-column-dialog .mud-switch {
    margin-bottom: 0.5rem;
}

/* 群組 Paper 的間距 */
.two-column-dialog .mud-paper {
    margin-bottom: 0.75rem;
}

/* 群組標題的間距 */
.two-column-dialog .mud-paper > .mud-typography {
    margin-bottom: 0.75rem;
}

/* 群組內部的 MudGrid 間距 */
.two-column-dialog .mud-paper .mud-grid {
    row-gap: 0.75rem;
}

/* ========================================
   Radio Button 響應式樣式
   ======================================== */

/* Radio Group 響應式容器 */
.radio-group-responsive {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    margin-bottom: 0.75rem;
}

/* Radio 項目樣式 */
.radio-group-responsive .radio-item {
    flex: 0 0 auto;
    min-width: fit-content;
}

/* 行動端：垂直排列 */
@media (max-width: 599.98px) {
    .radio-group-responsive {
        flex-direction: column;
        gap: 0.25rem;
    }
    
    .radio-group-responsive .radio-item {
        width: 100%;
    }
}

/* 小螢幕：允許換行 */
@media (min-width: 600px) and (max-width: 959.98px) {
    .radio-group-responsive {
        flex-wrap: wrap;
    }
}

/* ========================================
   FindTagsDialog 全螢幕樣式
   覆蓋所有全域限制，確保對話框佔滿整個螢幕
   配合 DialogOptions.FullScreen = true 使用
   ======================================== */

/* FindTagsDialog 全螢幕對話框 - 多種選擇器確保樣式套用 */
.find-tags-fullscreen-dialog.mud-dialog,
.mud-dialog.find-tags-fullscreen-dialog,
.mud-dialog-container .find-tags-fullscreen-dialog,
.mud-dialog-fullscreen.find-tags-fullscreen-dialog,
.mud-dialog.mud-dialog-fullscreen {
    width: 100vw !important;
    height: 100vh !important;
    max-width: 100vw !important;
    max-height: 100vh !important;
    min-width: 100vw !important;
    min-height: 100vh !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 0 !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
}

/* 確保對話框容器也是全螢幕 */
.mud-dialog-container:has(.find-tags-fullscreen-dialog),
.mud-overlay-dialog {
    max-width: 100vw !important;
    width: 100vw !important;
}

/* FindTagsDialog 內容區域 - 使用 calc 計算高度 */
.find-tags-fullscreen-dialog .mud-dialog-content,
.mud-dialog-fullscreen .mud-dialog-content {
    width: 100% !important;
    max-width: 100% !important;
    height: calc(100vh - 64px) !important;
    max-height: calc(100vh - 64px) !important;
    padding: 16px !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* FindTagsDialog 按鈕區域 */
.find-tags-fullscreen-dialog .mud-dialog-actions,
.mud-dialog-fullscreen .mud-dialog-actions {
    padding: 8px 16px !important;
    height: 64px !important;
    flex-shrink: 0 !important;
    box-sizing: border-box !important;
}

/* FindTagsDialog 三欄佈局容器 */
.find-tags-three-column-layout {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    height: 100% !important;
    gap: 16px !important;
    box-sizing: border-box !important;
}

/* FindTagsDialog 左側面板 */
.find-tags-three-column-layout .find-tags-left-panel {
    flex: 1 1 45% !important;
    min-width: 350px !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* FindTagsDialog 中間按鈕區 */
.find-tags-three-column-layout .find-tags-center-panel {
    flex: 0 0 60px !important;
    width: 60px !important;
    min-width: 60px !important;
    max-width: 60px !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 12px !important;
    box-sizing: border-box !important;
}

/* FindTagsDialog 右側面板 */
.find-tags-three-column-layout .find-tags-right-panel {
    flex: 1 1 45% !important;
    min-width: 350px !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* FindTagsDialog 輸入區域 */
.find-tags-three-column-layout .find-tags-input-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-items: flex-end !important;
    flex-shrink: 0 !important;
}

/* FindTagsDialog 地址值容器 */
.find-tags-three-column-layout .find-tags-address-container {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    padding: 8px !important;
    box-sizing: border-box !important;
}

/* FindTagsDialog 地址值網格 */
.find-tags-three-column-layout .find-tags-address-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-content: flex-start !important;
}

/* FindTagsDialog 地址值項目 */
.find-tags-three-column-layout .find-tags-address-item {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    padding: 4px 8px !important;
    border: 1px solid rgba(0, 0, 0, 0.12) !important;
    border-radius: 4px !important;
    min-width: 140px !important;
    box-sizing: border-box !important;
}

/* FindTagsDialog 表格容器 */
.find-tags-three-column-layout .find-tags-table-container {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: auto !important;
    box-sizing: border-box !important;
}

/* 響應式 - 極小螢幕 */
@media (max-width: 768px) {
    .find-tags-three-column-layout {
        flex-direction: column !important;
    }
    
    .find-tags-three-column-layout .find-tags-left-panel,
    .find-tags-three-column-layout .find-tags-right-panel {
        min-width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
        max-height: 40vh !important;
    }
    
    .find-tags-three-column-layout .find-tags-center-panel {
        flex-direction: row !important;
        width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
        padding: 8px 0 !important;
    }
}

/* ========================================
   ProcessSamplingRuleDialog 樣式
   ======================================== */
.sampling-rule-dialog.mud-dialog {
    width: 1200px !important;
    max-width: 95vw !important;
}


/* ========================================
   路徑圖視覺優化 (Route Diagram Visual Enhancement)
   Product Route Diagram Edit 專用樣式
   ======================================== */

/* Diagram 容器 - 添加柔和背景 */
.diagram-container {
    background: linear-gradient(135deg, #f5f7fa 0%, #fafbfc 100%);
    border-radius: 8px;
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.05);
}

/* Diagram SVG 連接線動畫效果 */
.diagram-container svg path {
    transition: stroke 0.3s ease, stroke-width 0.3s ease;
}

.diagram-container svg path:hover {
    stroke: #1976D2 !important;
    stroke-width: 3px !important;
}

/* Grid 網格線優化 */
.diagram-container .grid-line {
    stroke: rgba(0, 0, 0, 0.05);
    stroke-width: 1px;
}

/* 連接線箭頭顏色 */
.diagram-container .link-arrow {
    fill: #2196F3;
}

/* 節點選中狀態 */
.diagram-container .selected-node {
    filter: drop-shadow(0 4px 12px rgba(33, 150, 243, 0.4));
}

/* Navigator 小地圖樣式優化 */
.diagram-container .navigator-widget {
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    border: 2px solid #e0e0e0 !important;
    background: white !important;
}

/* 路徑圖工具列樣式 */
.route-diagram-toolbar {
    background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
    border-radius: 8px;
}

/* 路徑圖統計資訊樣式 */
.route-diagram-stats {
    padding: 8px 16px;
    background: rgba(33, 150, 243, 0.08);
    border-radius: 6px;
    font-weight: 500;
}

/* 節點拖曳控制點 */
.diagram-container .drag-new-link-control {
    opacity: 0.6;
    transition: opacity 0.2s ease;
}

.diagram-container .drag-new-link-control:hover {
    opacity: 1;
}

/* 響應式調整 */
@media (max-width: 768px) {
    .diagram-container {
        border-radius: 4px;
    }

    .route-diagram-toolbar {
        flex-wrap: wrap;
    }
}

/* ========================================
   UiDefinePage 編輯模式光標樣式
   Edit Mode / View Mode Cursor Styles
   ======================================== */

/* 編輯模式：預設顯示十字游標（move），拖動時顯示抓取手勢（grabbing） */
.diagram-container.edit-mode {
    cursor: move !important;
}

.diagram-container.edit-mode:active {
    cursor: grabbing !important;
}

/* 編輯模式下的節點：懸停時顯示十字游標 */
.diagram-container.edit-mode .diagram-node {
    cursor: move !important;
}

/* 編輯模式下的節點：拖動時顯示抓取手勢 */
.diagram-container.edit-mode .diagram-node:active {
    cursor: grabbing !important;
}

/* 編輯模式下的節點內部元素（包括 node-block, list-group-item 等）也顯示移動游標 */
.diagram-container.edit-mode .node-block,
.diagram-container.edit-mode .list-group-item,
.diagram-container.edit-mode .container-fluid {
    cursor: move !important;
}

/* 編輯模式下：強制 MudBlazor 輸入控件顯示移動游標，而非文字編輯游標 */
.diagram-container.edit-mode .mud-input,
.diagram-container.edit-mode .mud-input-root,
.diagram-container.edit-mode .mud-input-slot,
.diagram-container.edit-mode input,
.diagram-container.edit-mode textarea {
    cursor: move !important;
    pointer-events: none !important; /* 防止在編輯模式下觸發輸入 */
}

/* 編輯模式下：防止 MudBlazor 標籤顯示文字游標 */
.diagram-container.edit-mode .mud-input-label,
.diagram-container.edit-mode .mud-input-label-text {
    cursor: move !important;
}

/* 執行模式：使用預設光標，輸入控件恢復正常功能 */
.diagram-container.view-mode {
    cursor: default !important;
}

.diagram-container.view-mode .diagram-node {
    cursor: default !important;
}

.diagram-container.view-mode .node-block,
.diagram-container.view-mode .list-group-item,
.diagram-container.view-mode .container-fluid {
    cursor: default !important;
}

/* 執行模式：輸入控件恢復正常的文字編輯游標 */
.diagram-container.view-mode .mud-input,
.diagram-container.view-mode .mud-input-root,
.diagram-container.view-mode .mud-input-slot,
.diagram-container.view-mode input,
.diagram-container.view-mode textarea {
    cursor: text !important;
    pointer-events: auto !important; /* 恢復輸入功能 */
}

/* 執行模式：唯讀欄位使用預設游標 */
.diagram-container.view-mode .mud-input[readonly],
.diagram-container.view-mode input[readonly],
.diagram-container.view-mode textarea[readonly] {
    cursor: default !important;
}

