/* 宫格图配置弹层样式:收藏页(favorites.html「生成宫格图」)与聊天页(chat.html「下载宫格图」)共用。
   依赖两页 :root 共有的设计变量(颜色 / 圆角 / 阴影 / 缓动等);
   --dur 仅收藏页定义,这里统一用 var(--dur, .15s) 兜底,聊天页无该变量时退到 .15s。
   导出图本身的网格卡片样式见 static/css/grid-image.css。 */

/* 弹层遮罩(收藏页对比/宫格弹层共用 .overlay) */
.overlay {
  position: fixed; inset: 0; background: rgba(15, 15, 25, .5); z-index: 100;
  display: none; align-items: center; justify-content: center; padding: 24px;
}
.overlay.show { display: flex; }

/* 宫格弹层主体 */
.grid-panel {
  background: var(--color-surface); border-radius: var(--radius-md);
  /* 边框:深色下遮罩与页面同样深、阴影几乎不可见,无边框时弹窗轮廓会融进背景 */
  border: 1px solid var(--color-border);
  width: min(1200px, 96vw); max-height: 92vh; display: flex; flex-direction: column; overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.grid-head {
  padding: 14px 20px; border-bottom: 1px solid var(--color-border);
  display: flex; align-items: center; gap: 10px;
}
.grid-head h2 { margin: 0; font-size: 1.05rem; font-weight: 650; }
.grid-head .sub { color: var(--color-text-tertiary); font-size: .85rem; }
/* 关闭按钮:自包含样式,不依赖收藏页 topbar 的 .icon-btn,聊天页也能直接用 */
.grid-head .close {
  margin-left: auto;
  width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--color-border-strong); background: var(--color-surface);
  color: var(--color-text); border-radius: var(--radius-md);
  font-size: 1.1rem; line-height: 1; cursor: pointer;
  transition: background var(--dur, .15s) var(--ease);
}
.grid-head .close:hover { background: var(--color-surface-hover); }

.grid-body { display: flex; min-height: 0; flex: 1; overflow: hidden; }
.grid-cfg {
  width: 280px; border-right: 1px solid var(--color-border);
  padding: 16px 18px; overflow-y: auto;
  display: flex; flex-direction: column; gap: 18px;
}
.grid-cfg .row { display: flex; flex-direction: column; gap: 8px; }
.grid-cfg .row > label { font-size: .82rem; color: var(--color-text-secondary); font-weight: 500; }
.grid-cfg input[type=text] {
  padding: 8px 12px; border: 1px solid var(--color-border); border-radius: var(--radius-sm);
  background: var(--color-surface); color: var(--color-text); font-size: .9rem; outline: none;
  font-family: var(--font-sans);
  transition: border-color var(--dur, .15s) var(--ease);
}
.grid-cfg input[type=text]:focus { border-color: var(--color-primary); }
.seg { display: flex; gap: 6px; flex-wrap: wrap; }
.seg button {
  min-width: 36px; padding: 6px 10px; border: 1px solid var(--color-border-strong);
  background: var(--color-surface); color: var(--color-text); border-radius: var(--radius-sm);
  font-size: .85rem; cursor: pointer;
  transition: border-color var(--dur, .15s) var(--ease), background var(--dur, .15s) var(--ease), color var(--dur, .15s) var(--ease);
}
.seg button:hover { border-color: var(--color-primary); color: var(--color-primary); }
.seg button.active {
  background: var(--color-primary); border-color: var(--color-primary); color: var(--color-primary-text);
}
.toggles { display: flex; flex-direction: column; gap: 8px; }
.toggles label {
  display: flex; align-items: center; gap: 8px; font-size: .88rem; cursor: pointer; user-select: none;
  color: var(--color-text);
}
.toggles input[type=checkbox] { accent-color: var(--color-primary); width: 16px; height: 16px; }
.grid-cfg .hint { font-size: .76rem; color: var(--color-text-tertiary); line-height: 1.5; }
.grid-cfg .actions { display: flex; gap: 8px; margin-top: auto; padding-top: 12px; border-top: 1px solid var(--color-border); }
.grid-cfg .actions .btn-dl {
  flex: 1; padding: 9px 14px; border: none; border-radius: var(--radius-sm);
  background: var(--color-primary); color: var(--color-primary-text);
  font-size: .9rem; font-weight: 500; cursor: pointer;
  transition: background var(--dur, .15s) var(--ease), opacity var(--dur, .15s) var(--ease);
}
.grid-cfg .actions .btn-dl:hover { background: var(--color-primary-hover); }
.grid-cfg .actions .btn-dl[disabled] { opacity: .5; cursor: not-allowed; }
/* 复制按钮:轮廓样式与下载按钮区分,功能等价 */
.grid-cfg .actions .btn-copy {
  background: var(--color-surface); color: var(--color-primary);
  border: 1px solid var(--color-primary);
}
.grid-cfg .actions .btn-copy:hover { background: var(--color-primary-soft); }

.grid-preview-wrap {
  flex: 1; min-width: 0; overflow: auto;
  /* 预览画布:衬托白色导出图的留白区,跟随主题(深色下变深,白图更突出)。
     导出图本身固定浅底,不受此处影响——截图只取内部导出节点,不含本容器背景。 */
  background: var(--color-bg); padding: 24px;
  display: flex; justify-content: center; align-items: flex-start;
}
.grid-preview-wrap.loading { align-items: center; color: var(--color-text-tertiary); }

@media (max-width: 860px) {
  .grid-body { flex-direction: column; }
  .grid-cfg { width: 100%; border-right: none; border-bottom: 1px solid var(--color-border); max-height: 40vh; }
  .grid-preview-wrap { padding: 14px; }
}
