/**
 * AITravel 主題色彩系統 - 莫蘭迪橘色
 * 
 * 莫蘭迪色系特點：低飽和度、柔和、優雅
 * 主色：莫蘭迪橘色（暖色調）
 */

:root {
  /* ==================== 主色系 - 莫蘭迪橘色 ==================== */
  --primary-50: #FFF5F0;
  --primary-100: #FFE8DC;
  --primary-200: #FFD4C1;
  --primary-300: #FFBFA0;
  --primary-400: #E8A87C;  /* 主要橘色 */
  --primary-500: #D4956B;
  --primary-600: #C0825A;
  --primary-700: #A66F4D;
  --primary-800: #8C5C40;
  --primary-900: #6B4530;

  /* ==================== 輔助色系 ==================== */
  /* 莫蘭迪灰色 */
  --gray-50: #F8F7F6;
  --gray-100: #F0EEEC;
  --gray-200: #E3E0DD;
  --gray-300: #D1CCC7;
  --gray-400: #B8B2AC;
  --gray-500: #9A9490;
  --gray-600: #7D7874;
  --gray-700: #625F5B;
  --gray-800: #4A4845;
  --gray-900: #2D2C2A;

  /* 莫蘭迪綠色（成功） */
  --success-50: #F2F7F4;
  --success-100: #E3EFE7;
  --success-200: #C7DFCF;
  --success-300: #A8CCBA;
  --success-400: #8AB9A5;
  --success-500: #6FA08C;
  --success-600: #5A8773;
  --success-700: #476D5C;
  --success-800: #365445;
  --success-900: #263B30;

  /* 莫蘭迪紅色（錯誤/警告） */
  --danger-50: #FDF5F4;
  --danger-100: #FAE8E6;
  --danger-200: #F5D1CD;
  --danger-300: #EDB5AE;
  --danger-400: #E39A90;
  --danger-500: #D47F72;
  --danger-600: #C06558;
  --danger-700: #A05247;
  --danger-800: #7F4038;
  --danger-900: #5E2F29;

  /* 莫蘭迪藍色（資訊） */
  --info-50: #F4F7F9;
  --info-100: #E7EEF3;
  --info-200: #CFE0E9;
  --info-300: #B3CFDD;
  --info-400: #96BDD1;
  --info-500: #7AA7C0;
  --info-600: #6391AD;
  --info-700: #507790;
  --info-800: #3E5D72;
  --info-900: #2D4454;

  /* 莫蘭迪黃色（警告） */
  --warning-50: #FBF8F2;
  --warning-100: #F7F0E3;
  --warning-200: #EFE1C7;
  --warning-300: #E5CFA8;
  --warning-400: #DBBD89;
  --warning-500: #CCA76B;
  --warning-600: #B89156;
  --warning-700: #9A7746;
  --warning-800: #7B5E37;
  --warning-900: #5C4529;

  /* ==================== 語義化顏色 ==================== */
  --color-primary: var(--primary-400);
  --color-primary-hover: var(--primary-500);
  --color-primary-active: var(--primary-600);
  --color-primary-light: var(--primary-100);
  --color-primary-dark: var(--primary-700);

  --color-success: var(--success-500);
  --color-success-light: var(--success-100);
  --color-danger: var(--danger-500);
  --color-danger-light: var(--danger-100);
  --color-warning: var(--warning-500);
  --color-warning-light: var(--warning-100);
  --color-info: var(--info-500);
  --color-info-light: var(--info-100);

  /* ==================== 文字顏色 ==================== */
  --text-primary: var(--gray-900);
  --text-secondary: var(--gray-600);
  --text-tertiary: var(--gray-500);
  --text-disabled: var(--gray-400);
  --text-inverse: #FFFFFF;

  /* ==================== 背景顏色 ==================== */
  --bg-primary: #FFFFFF;
  --bg-secondary: var(--gray-50);
  --bg-tertiary: var(--gray-100);
  --bg-overlay: rgba(45, 44, 42, 0.5);

  /* ==================== 邊框顏色 ==================== */
  --border-light: var(--gray-200);
  --border-medium: var(--gray-300);
  --border-dark: var(--gray-400);

  /* ==================== 陰影 ==================== */
  --shadow-sm: 0 1px 2px 0 rgba(45, 44, 42, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(45, 44, 42, 0.1);
  --shadow-lg: 0 10px 15px -3px rgba(45, 44, 42, 0.1);
  --shadow-xl: 0 20px 25px -5px rgba(45, 44, 42, 0.1);

  /* ==================== 圓角 ==================== */
  --radius-sm: 0.25rem;
  --radius-md: 0.375rem;
  --radius-lg: 0.5rem;
  --radius-xl: 0.75rem;
  --radius-full: 9999px;

  /* ==================== 間距 ==================== */
  --spacing-xs: 0.25rem;
  --spacing-sm: 0.5rem;
  --spacing-md: 1rem;
  --spacing-lg: 1.5rem;
  --spacing-xl: 2rem;
  --spacing-2xl: 3rem;
}

/* ==================== 通用類別 ==================== */

/* 文字顏色 */
.text-primary { color: var(--text-primary); }
.text-secondary { color: var(--text-secondary); }
.text-tertiary { color: var(--text-tertiary); }
.text-disabled { color: var(--text-disabled); }
.text-inverse { color: var(--text-inverse); }
.text-theme { color: var(--color-primary); }
.text-success { color: var(--color-success); }
.text-danger { color: var(--color-danger); }
.text-warning { color: var(--color-warning); }
.text-info { color: var(--color-info); }

/* 背景顏色 */
.bg-primary { background-color: var(--bg-primary); }
.bg-secondary { background-color: var(--bg-secondary); }
.bg-tertiary { background-color: var(--bg-tertiary); }
.bg-theme { background-color: var(--color-primary); }
.bg-theme-light { background-color: var(--color-primary-light); }
.bg-success { background-color: var(--color-success); }
.bg-success-light { background-color: var(--color-success-light); }
.bg-danger { background-color: var(--color-danger); }
.bg-danger-light { background-color: var(--color-danger-light); }
.bg-warning { background-color: var(--color-warning); }
.bg-warning-light { background-color: var(--color-warning-light); }
.bg-info { background-color: var(--color-info); }
.bg-info-light { background-color: var(--color-info-light); }

/* 邊框顏色 */
.border-light { border-color: var(--border-light); }
.border-medium { border-color: var(--border-medium); }
.border-dark { border-color: var(--border-dark); }
.border-theme { border-color: var(--color-primary); }

/* 按鈕樣式 */
.btn-theme {
  background-color: var(--color-primary);
  color: var(--text-inverse);
  border: none;
  padding: 0.5rem 1.5rem;
  border-radius: var(--radius-md);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
}

.btn-theme::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}

.btn-theme:active::before {
  width: 300px;
  height: 300px;
}

.btn-theme:hover {
  background-color: var(--color-primary-hover);
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 10px 15px -3px rgba(232, 168, 124, 0.3), 0 4px 6px -2px rgba(232, 168, 124, 0.2);
}

.btn-theme:active {
  background-color: var(--color-primary-active);
  transform: translateY(0) scale(0.98);
}

.btn-theme:disabled {
  background-color: var(--gray-300);
  color: var(--text-disabled);
  cursor: not-allowed;
  transform: none;
}

.btn-theme-outline {
  background-color: transparent;
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
  padding: 0.5rem 1.5rem;
  border-radius: var(--radius-md);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.btn-theme-outline:hover {
  background-color: var(--color-primary-light);
}

.btn-success {
  background-color: var(--color-success);
  color: var(--text-inverse);
}

.btn-success:hover {
  background-color: var(--success-600);
}

.btn-danger {
  background-color: var(--color-danger);
  color: var(--text-inverse);
}

.btn-danger:hover {
  background-color: var(--danger-600);
}

/* 卡片樣式 */
.card-theme {
  background-color: var(--bg-primary);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--spacing-lg);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid rgba(232, 168, 124, 0.08);
}

.card-theme:hover {
  box-shadow: 0 20px 25px -5px rgba(232, 168, 124, 0.1), 0 10px 10px -5px rgba(232, 168, 124, 0.04);
  transform: translateY(-4px);
  border-color: rgba(232, 168, 124, 0.15);
}

/* 標籤樣式 */
.tag-theme {
  background-color: var(--color-primary-light);
  color: var(--color-primary-dark);
  padding: 0.25rem 0.75rem;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

/* 輸入框樣式 */
.input-theme {
  width: 100%;
  padding: 0.625rem 1rem;
  border: 2px solid var(--border-light);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  color: var(--text-primary);
  background-color: var(--bg-primary);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.input-theme:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(232, 168, 124, 0.1), 0 4px 6px -1px rgba(232, 168, 124, 0.1);
  transform: translateY(-1px);
}

.input-theme:disabled {
  background-color: var(--bg-tertiary);
  color: var(--text-disabled);
  cursor: not-allowed;
}

/* 連結樣式 */
.link-theme {
  color: var(--color-primary);
  text-decoration: none;
  transition: color 0.2s ease;
}

.link-theme:hover {
  color: var(--color-primary-hover);
  text-decoration: underline;
}

/* 圖標顏色 */
.icon-calendar {
  color: #E8A87C; /* 莫蘭迪橘 - 日期 */
}

.icon-clock {
  color: #8B9D83; /* 莫蘭迪綠 - 時間 */
}

.icon-location {
  color: #D4A5A5; /* 莫蘭迪粉 - 地點 */
}

.icon-money {
  color: #B8A07E; /* 莫蘭迪金 - 金錢 */
}

.icon-hotel {
  color: #9B8B7E; /* 莫蘭迪棕 - 住宿 */
}

.icon-restaurant {
  color: #C9A690; /* 莫蘭迪橙 - 餐廳 */
}

.icon-attraction {
  color: #7B9EA8; /* 莫蘭迪藍 - 景點 */
}

.icon-shopping {
  color: #C4A5B0; /* 莫蘭迪紫 - 購物 */
}

.icon-store {
  color: #A89B8E; /* 莫蘭迪棕灰 - 店家 */
}

.icon-tag {
  color: #A8B5A8; /* 莫蘭迪灰綠 - 標籤 */
}

.icon-note {
  color: #B8A8A0; /* 莫蘭迪灰 - 備註 */
}

/* 分隔線 */
.divider-theme {
  height: 1px;
  background-color: var(--border-light);
  margin: var(--spacing-lg) 0;
}

/* 徽章 */
.badge-theme {
  background-color: var(--color-primary);
  color: var(--text-inverse);
  padding: 0.125rem 0.5rem;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 600;
  display: inline-block;
}

/* 載入動畫 */
.loading-theme {
  color: var(--color-primary);
  animation: spin 1s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* 毛玻璃效果 - 模態框背景 */
.modal-backdrop-blur {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* 標籤選擇器樣式 */
.tag-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.tag-option {
  padding: 0.375rem 0.875rem;
  border-radius: var(--radius-full);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  border: 2px solid var(--border-light);
  background-color: var(--bg-primary);
  color: var(--text-secondary);
  user-select: none;
}

.tag-option:hover {
  border-color: var(--color-primary);
  background-color: var(--color-primary-light);
  transform: translateY(-1px);
}

.tag-option.selected {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
  color: var(--text-inverse);
  box-shadow: 0 2px 4px rgba(232, 168, 124, 0.2);
}

/* 狀態徽章樣式 */
.status-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.75rem;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.status-candidate {
  background-color: #E5E5E5;
  color: #666666;
}

.status-to_reserve,
.status-to_buy {
  background-color: #FFE5D9;
  color: #E8A87C;
}

.status-reserved,
.status-purchased {
  background-color: #D9EDD9;
  color: #7BA87B;
}

/* 狀態選擇器中的選中樣式 */
#statusSelector .tag-option[data-status="candidate"].selected {
  border-color: #999999;
  background-color: #999999;
  color: white;
}

#statusSelector .tag-option[data-status="to_reserve"].selected,
#statusSelector .tag-option[data-status="to_buy"].selected {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
  color: white;
}

#statusSelector .tag-option[data-status="reserved"].selected,
#statusSelector .tag-option[data-status="purchased"].selected {
  border-color: #7BA87B;
  background-color: #7BA87B;
  color: white;
}

.tag-option.selected:hover {
  background-color: var(--color-primary-hover);
}

/* 自訂標籤輸入 */
.custom-tag-input-wrapper {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.custom-tag-input {
  flex: 1;
  min-width: 0;
}

/* ==================== 資料夾標籤 ==================== */
.folder-tab {
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  background-color: var(--bg-secondary);
  color: var(--text-secondary);
  border: 1px solid var(--border-light);
  transition: all 0.2s ease;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.folder-tab:hover {
  background-color: var(--bg-tertiary);
  color: var(--text-primary);
  border-color: var(--color-primary);
}

.folder-tab.active {
  background-color: var(--color-primary);
  color: white;
  border-color: var(--color-primary);
}

.folder-tab.active:hover {
  background-color: var(--color-primary-hover);
}

/* ==================== 滾動條隱藏 ==================== */
.scrollbar-hide {
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}

.scrollbar-hide::-webkit-scrollbar {
  display: none;  /* Chrome, Safari and Opera */
}

/* ==================== 資料夾標籤容器 ==================== */
.folder-tabs-wrapper {
  position: relative;
}

#folderTabsContainer {
  padding-right: 60px; /* 為展開按鈕留出空間 */
}

#expandFoldersBtn {
  min-width: 44px;
  min-height: 44px;
}

/* ==================== 底部導航欄 (Footer) ==================== */
footer {
  z-index: 20 !important; /* 降低 z-index，避免擋住 SweetAlert2 (z-index: 1060) */
}

footer > div {
  max-width: 500px;
  margin: 0 auto;
}

.nav-btn {
  position: relative;
  cursor: pointer;
  transition: all 0.3s ease;
  min-width: 70px;
}

.nav-btn:hover i {
  transform: scale(1.1);
}

.nav-btn.active i {
  color: var(--color-primary) !important;
}

.nav-btn.active span {
  color: var(--color-primary) !important;
  font-weight: 600;
}

/* ==================== 分類標籤 ==================== */
.category-tab {
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  border: 2px solid var(--color-light);
  background-color: white;
  color: var(--text-secondary);
  font-weight: 500;
  transition: all 0.3s ease;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}

.category-tab:hover {
  border-color: var(--color-primary);
  background-color: var(--primary-50);
}

.category-tab.active {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
  color: white;
}

/* ==================== Modal 樣式 ==================== */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  z-index: 1000;
  padding: 10px;
  padding-top: 10px;
  overflow-y: auto;
  /* 在 iframe 內，不使用 vh，因為 iframe 本身已經有高度限制 */
  /* 使用 align-items: flex-start 而不是 center，避免在 iframe 內產生過大的頂部間距 */
}

.modal-overlay.hidden {
  display: none;
}

.modal-container {
  background: white;
  border-radius: 16px;
  width: 100%;
  max-width: 500px;
  /* 在 iframe 內，需要考慮 Header 高度 (52px) + 安全間距 (20px) */
  /* 使用 calc(100vh - 80px) 確保 Modal 不會超出可視範圍 */
  max-height: calc(100vh - 80px);
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  /* 確保圓角在所有邊都生效 */
  overflow: hidden;
  border-radius: 16px;
  /* 只在水平方向居中，垂直方向由 flexbox 的 align-items: center 控制 */
  margin: 0 auto;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--gray-200);
  flex-shrink: 0;
}

.modal-title {
  font-size: 20px;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.modal-close {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: none;
  background: var(--gray-100);
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.modal-close:hover {
  background: var(--gray-200);
  color: var(--text-primary);
}

.modal-body {
  padding: 24px;
  overflow-y: auto;
  overflow-x: hidden;
  flex: 1;
}

.modal-footer {
  display: flex;
  gap: 12px;
  padding: 16px 24px;
  border-top: 1px solid var(--gray-200);
  flex-shrink: 0;
}

/* ==================== 營業時間編輯器樣式 ==================== */
.business-hours-editor {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.business-hours-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px;
  background-color: var(--gray-50);
  border-radius: 6px;
  border-bottom: 1px solid var(--gray-200);
}

.business-hours-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.business-hours-day {
  font-weight: 500;
  color: var(--text-primary);
  font-size: 14px;
}

.business-hours-time-slots {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.business-hours-time {
  display: flex;
  align-items: center;
  gap: 6px;
}

.business-hours-input {
  flex: 1;
  padding: 6px 8px;
  border: 1px solid var(--gray-300);
  border-radius: 4px;
  font-size: 13px;
  color: var(--text-primary);
  background-color: white;
  transition: border-color 0.2s;
}

.business-hours-input:focus {
  outline: none;
  border-color: var(--theme-color);
  box-shadow: 0 0 0 2px rgba(232, 168, 124, 0.1);
}

.business-hours-input:disabled {
  background-color: var(--gray-100);
  color: var(--text-secondary);
  cursor: not-allowed;
}

.business-hours-separator {
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 500;
}

.business-hours-closed-label {
  display: flex;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  user-select: none;
  font-size: 13px;
  color: var(--text-secondary);
}

.business-hours-closed-checkbox {
  cursor: pointer;
}

.business-hours-add-slot {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  font-size: 12px;
  color: var(--theme-color);
  background: transparent;
  border: 1px dashed var(--theme-color);
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
}

.business-hours-add-slot:hover {
  background: rgba(232, 168, 124, 0.1);
}

.business-hours-remove-slot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--text-secondary);
  background: transparent;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
}

.business-hours-remove-slot:hover {
  background: var(--gray-200);
  color: #e74c3c;
}

/* ==================== 表單樣式 ==================== */
.form-label {
  display: block;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 6px;
}

.form-input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--gray-300);
  border-radius: 8px;
  font-size: 14px;
  color: var(--text-primary);
  transition: all 0.2s;
  box-sizing: border-box;
}

.form-input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(232, 168, 124, 0.1);
}

.form-input::placeholder {
  color: var(--text-tertiary);
}

.form-group {
  margin-bottom: 16px;
}

.item-form {
  display: flex;
  flex-direction: column;
}

/* ==================== 按鈕樣式 ==================== */
.btn-primary {
  flex: 1;
  padding: 12px 24px;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--primary-500) 100%);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}

.btn-primary:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(232, 168, 124, 0.3);
}

.btn-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn-secondary {
  flex: 1;
  padding: 12px 24px;
  background: white;
  color: var(--text-secondary);
  border: 1px solid var(--gray-300);
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}

.btn-secondary:hover {
  background: var(--gray-50);
  border-color: var(--gray-400);
}

/* ==================== 地圖容器 ==================== */
.map-container {
  width: 100%;
  height: 240px;
  border-radius: 12px;
  border: 1px solid var(--gray-300);
  overflow: hidden;
}

/* ==================== 搜尋結果列表 ==================== */
.search-results-container {
  max-height: 200px;
  overflow-y: auto;
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  background: var(--gray-50);
}

.search-result-item {
  padding: 12px 16px;
  border-bottom: 1px solid var(--gray-200);
  cursor: pointer;
  transition: all 0.2s;
}

.search-result-item:last-child {
  border-bottom: none;
}

.search-result-item:hover {
  background: white;
}

.search-result-item.selected {
  background: var(--primary-50);
  border-left: 3px solid var(--color-primary);
}

.search-result-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.search-result-subtitle {
  font-size: 12px;
  color: var(--text-secondary);
}

/* ==================== 營業時間顯示 ==================== */
.business-hours-display {
  padding: 12px;
  background: var(--gray-50);
  border-radius: 8px;
  /* 移除 max-height 和 overflow-y，讓營業時間完整顯示在父層 */
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
}

.business-hours-item {
  margin-bottom: 4px;
}

.business-hours-item:last-child {
  margin-bottom: 0;
}

/* ==================== 響應式設計 ==================== */
@media (max-width: 640px) {
  .modal-container {
    max-width: 100%;
    /* 在移動端，也需要考慮 Header 高度 (52px) + 安全間距 */
    /* 使用 calc(100vh - 80px) 確保 Modal 不會超出可視範圍 */
    max-height: calc(100vh - 80px);
    /* 保持所有邊都有圓角，不要只有上方圓角 */
    border-radius: 16px;
  }

  .modal-header {
    padding: 16px 20px;
  }

  .modal-body {
    padding: 20px;
  }

  .modal-footer {
    padding: 12px 20px;
  }

  .map-container {
    height: 200px;
  }

  .search-results-container {
    max-height: 160px;
  }
}

/* ==================== Utility 類別 ==================== */
.mb-3 {
  margin-bottom: 16px;
}

.text-center {
  text-align: center;
}

.text-gray-500 {
  color: var(--text-secondary);
}

.py-4 {
  padding-top: 16px;
  padding-bottom: 16px;
}

.text-2xl {
  font-size: 24px;
}

.mb-2 {
  margin-bottom: 8px;
}

.text-sm {
  font-size: 14px;
}

/* ==================== 拖曳排序樣式 ==================== */
.sortable-ghost {
  opacity: 0.4;
  background: var(--primary-50);
}

.sortable-chosen {
  cursor: move;
}

.sortable-drag {
  opacity: 1;
  transform: rotate(2deg);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.folder-card {
  transition: all 0.3s ease;
}

.folder-card:active {
  cursor: move;
}

/* ==================== 項目選單樣式 ==================== */
.item-menu {
  position: fixed;
  background: white;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  padding: 4px 0;
  min-width: 160px;
  z-index: 1000;
  animation: menuFadeIn 0.15s ease-out;
}

@keyframes menuFadeIn {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.item-menu-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 14px;
  color: var(--text-primary);
}

.item-menu-item i {
  width: 16px;
  text-align: center;
  color: var(--text-secondary);
}

.item-menu-item:hover {
  background: var(--gray-50);
}

.item-menu-item-danger {
  color: var(--danger-500);
}

.item-menu-item-danger i {
  color: var(--danger-500);
}

.item-menu-item-danger:hover {
  background: var(--danger-50);
}

/* ==================== 日期選項樣式 ==================== */
.day-option {
  transition: all 0.2s;
}

.day-option:not(.cursor-not-allowed):hover {
  transform: translateY(-2px);
  box-shadow: 0 2px 8px rgba(232, 168, 124, 0.2);
}

.day-option.cursor-not-allowed {
  opacity: 0.6;
}

/* ==================== SweetAlert2 全局樣式覆蓋 ==================== */
/* 確保所有 SweetAlert2 對話框使用系統主題色 */
.swal2-popup {
  border-radius: 16px !important;
  font-family: inherit !important;
}

.swal2-title {
  color: var(--text-primary) !important;
  font-size: 1.5rem !important;
  font-weight: 600 !important;
}

.swal2-html-container {
  color: var(--text-secondary) !important;
  font-size: 1rem !important;
}

/* 確認按鈕 - 使用莫蘭迪橘色 */
.swal2-confirm {
  background-color: #E8A87C !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 12px 24px !important;
  font-weight: 600 !important;
  box-shadow: 0 2px 8px rgba(232, 168, 124, 0.3) !important;
  transition: all 0.2s ease !important;
}

.swal2-confirm:hover {
  background-color: #D4956B !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(232, 168, 124, 0.4) !important;
}

.swal2-confirm:focus {
  box-shadow: 0 0 0 3px rgba(232, 168, 124, 0.3) !important;
}

/* 取消按鈕 */
.swal2-cancel {
  background-color: transparent !important;
  border: 1px solid var(--gray-300) !important;
  border-radius: 8px !important;
  padding: 12px 24px !important;
  font-weight: 600 !important;
  color: var(--text-secondary) !important;
  transition: all 0.2s ease !important;
}

.swal2-cancel:hover {
  background-color: var(--gray-50) !important;
  border-color: var(--gray-400) !important;
}

/* 刪除確認按鈕 - 使用危險色 */
.swal2-popup.swal-delete-confirm .swal2-confirm {
  background-color: var(--danger-500) !important;
}

.swal2-popup.swal-delete-confirm .swal2-confirm:hover {
  background-color: var(--danger-600) !important;
}

/* 輸入框樣式 */
.swal2-input,
.swal2-textarea {
  border: 1px solid var(--gray-300) !important;
  border-radius: 8px !important;
  padding: 10px 12px !important;
  font-size: 14px !important;
  color: var(--text-primary) !important;
  transition: all 0.2s ease !important;
}

.swal2-input:focus,
.swal2-textarea:focus {
  border-color: #E8A87C !important;
  box-shadow: 0 0 0 3px rgba(232, 168, 124, 0.1) !important;
  outline: none !important;
}

/* 圖標顏色 */
.swal2-icon.swal2-success [class^='swal2-success-line'] {
  background-color: var(--success-500) !important;
}

.swal2-icon.swal2-success .swal2-success-ring {
  border-color: rgba(111, 160, 140, 0.3) !important;
}

.swal2-icon.swal2-error [class^='swal2-x-mark-line'] {
  background-color: var(--danger-500) !important;
}

.swal2-icon.swal2-warning {
  border-color: var(--warning-500) !important;
  color: var(--warning-500) !important;
}

.swal2-icon.swal2-info {
  border-color: var(--info-500) !important;
  color: var(--info-500) !important;
}

.swal2-icon.swal2-question {
  border-color: #E8A87C !important;
  color: #E8A87C !important;
}
