/* ========================================
   Components CSS - 通用组件样式
   中间内容行布局 & 通用卡片 & 编辑器 & 弹窗
   所有魔法数字已替换为 variables.css 变量
   ======================================== */

/* ---- 中间内容行布局（小组件 + APP 图标并排） ---- */
.widget-app-row {
  display: flex;
  gap: var(--spacing-md);
  align-items: center;
  flex-shrink: 0;
}

/* ---- 通用卡片基础样式 ---- */
.card {
  background: var(--color-card-bg);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  padding: var(--spacing-card);
}

.card--muted {
  background: var(--color-card-muted);
  box-shadow: var(--shadow-inset);
}

.card--frost {
  background: var(--color-frost);
  backdrop-filter: var(--blur-medium);
  -webkit-backdrop-filter: var(--blur-medium);
  border: 1px solid var(--color-frost-border);
}

/* ========================================
   Editor CSS - 编辑交互组件样式
   ======================================== */

/* ---- 可编辑元素交互样式 ---- */
[contenteditable="true"] {
  outline: none;
  cursor: text;
  transition: background-color var(--transition-fast), border-radius var(--transition-fast);
  padding: 0 var(--spacing-xs);
  margin: 0 calc(var(--spacing-xs) * -1);
}

[contenteditable="true"]:hover {
  background-color: var(--color-accent-active);
  border-radius: var(--spacing-xs);
}

[contenteditable="true"]:focus {
  background-color: rgba(0, 0, 0, 0.06);
  border-radius: var(--spacing-xs);
}

/* 图片可点击提示 */
.editable-img {
  cursor: pointer;
  transition: filter var(--transition-fast);
}

.editable-img:hover {
  filter: brightness(0.9);
}

/* ---- 遮罩层 ---- */
.overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--color-overlay);
  z-index: var(--z-overlay);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-base);
  backdrop-filter: var(--blur-light);
  -webkit-backdrop-filter: var(--blur-light);
  border-radius: var(--radius-phone);
}

.overlay.active {
  opacity: 1;
  pointer-events: auto;
}

/* ---- iOS 风格 Action Sheet ---- */
.action-sheet {
  position: absolute;
  bottom: var(--spacing-action-bottom);
  left: var(--spacing-page);
  right: var(--spacing-page);
  z-index: var(--z-action-sheet);
  transform: translateY(150%);
  transition: transform var(--transition-spring);
}

.action-sheet.active {
  transform: translateY(0);
}

.action-sheet__group {
  background: var(--color-frost-heavy);
  backdrop-filter: var(--blur-heavy);
  -webkit-backdrop-filter: var(--blur-heavy);
  border-radius: var(--radius-action-sheet);
  overflow: hidden;
  margin-bottom: var(--spacing-sm);
}

.action-sheet__btn {
  width: 100%;
  padding: var(--spacing-xl) var(--spacing-lg);
  font-size: var(--font-size-xl);
  color: var(--color-accent);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--color-border);
  cursor: pointer;
  font-weight: var(--font-weight-light);
}

.action-sheet__btn:last-child {
  border-bottom: none;
}

.action-sheet__btn:active {
  background: var(--color-accent-active);
}

.action-sheet__btn--cancel {
  font-weight: var(--font-weight-medium);
}

/* ---- iOS 风格 Prompt 弹窗 ---- */
.ios-prompt {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(1.1);
  width: 270px;
  background: var(--color-frost-heavy);
  backdrop-filter: var(--blur-heavy);
  -webkit-backdrop-filter: var(--blur-heavy);
  border-radius: var(--radius-modal);
  z-index: var(--z-modal);
  opacity: 0;
  pointer-events: none;
  transition: all var(--transition-fast);
  box-shadow: var(--shadow-modal);
}

.ios-prompt.active {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, -50%) scale(1);
}

.ios-prompt__content {
  padding: var(--spacing-xl) var(--spacing-lg) var(--spacing-lg);
  text-align: center;
}

.ios-prompt__title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
  margin-bottom: var(--spacing-xs);
  color: var(--color-text-primary);
}

.ios-prompt__desc {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-lg);
  line-height: 1.3;
}

.ios-prompt__input {
  width: 100%;
  background: var(--color-input-bg);
  border: 1px solid var(--color-border-input);
  border-radius: var(--radius-input);
  padding: 6px var(--spacing-sm);
  font-size: var(--font-size-sm);
  box-shadow: var(--shadow-input-inset);
}

.ios-prompt__actions {
  display: flex;
  border-top: 1px solid var(--color-border-input);
}

.ios-prompt__btn {
  flex: 1;
  padding: var(--spacing-md);
  font-size: var(--font-size-lg);
  color: var(--color-accent);
  background: transparent;
  border: none;
  border-right: 1px solid var(--color-border-input);
  cursor: pointer;
}

.ios-prompt__btn:last-child {
  border-right: none;
}

.ios-prompt__btn:active {
  background: var(--color-accent-active);
}

.ios-prompt__btn--confirm {
  font-weight: var(--font-weight-medium);
}
