@charset "UTF-8";
/**
 * YH-UI Sass Variables
 * 原具体的 CSS 变量输出规则 (:root, html.dark 等) 已移至 root.scss，以防止各组件样式编译时产生重复的全局变量 CSS 冗余。
 */
.yh-ai-artifacts {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  background: var(--yh-bg-color-overlay);
  border-left: 1px solid var(--yh-border-color-lighter);
  box-shadow: -10px 0 30px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
  z-index: 1001;
  overflow: hidden;
  container-type: inline-size;
  container-name: ai-artifacts;
}
.yh-ai-artifacts.is-fullscreen {
  width: 100% !important;
  left: 0 !important;
  right: 0 !important;
}

.yh-ai-artifacts {
  /* Theme adjustments */
  background: var(--yh-ai-artifacts-bg-color, var(--yh-bg-color-overlay));
  /* Inline mode */
}
.yh-ai-artifacts--inline {
  position: relative;
  width: 100% !important;
  max-width: 100%;
  height: 400px;
  border: 1px solid var(--yh-border-color-lighter);
  border-radius: var(--yh-radius-md);
  margin: 12px 0;
  box-shadow: none;
}

html.dark .yh-ai-artifacts {
  background: var(--yh-ai-artifacts-bg-color, rgba(26, 26, 27, 0.9));
  backdrop-filter: blur(20px);
  border-left: 1px solid rgba(255, 255, 255, 0.08);
}
.yh-ai-artifacts__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--yh-border-color-lighter);
  background: var(--yh-bg-color-overlay);
}

.yh-ai-artifacts__title-area {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--yh-text-color-primary);
}
.yh-ai-artifacts__title-area .yh-icon {
  color: var(--yh-color-primary);
}

.yh-ai-artifacts__actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.yh-ai-artifacts__tabs {
  display: flex;
  background: var(--yh-fill-color-light);
  padding: 2px;
  border-radius: 8px;
}

.yh-ai-artifacts__tab {
  padding: 4px 12px;
  border: none;
  background: transparent;
  font-size: 13px;
  color: var(--yh-text-color-secondary);
  cursor: pointer;
  border-radius: 6px;
  transition: all 0.2s;
}
.yh-ai-artifacts__tab.is-active {
  background: var(--yh-bg-color-overlay);
  color: var(--yh-color-primary);
  box-shadow: var(--yh-shadow-sm);
}

.yh-ai-artifacts__version-bar {
  display: flex;
  align-items: center;
  padding: 8px 16px;
  background: var(--yh-fill-color-lighter);
  border-bottom: 1px solid var(--yh-border-color-extra-light);
  gap: 12px;
}

.yh-ai-artifacts__version-label {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--yh-text-color-placeholder);
  white-space: nowrap;
}

.yh-ai-artifacts__version-list {
  display: flex;
  gap: 6px;
  overflow-x: auto;
}
.yh-ai-artifacts__version-list::-webkit-scrollbar {
  display: none;
}

.yh-ai-artifacts__version-item {
  padding: 2px 8px;
  font-size: 12px;
  background: var(--yh-bg-color-overlay);
  border: 1px solid var(--yh-border-color-lighter);
  border-radius: 4px;
  cursor: pointer;
  white-space: nowrap;
}
.yh-ai-artifacts__version-item.is-active {
  background: var(--yh-color-primary-light-9);
  border-color: var(--yh-color-primary);
  color: var(--yh-color-primary);
}

.yh-ai-artifacts__content {
  flex: 1;
  overflow-x: hidden;
  overflow-y: auto;
  background: #fdfdfd;
  position: relative;
  display: flex;
  flex-direction: column;
}
html.dark .yh-ai-artifacts__content {
  background: #0d0d0d;
}

.yh-ai-artifacts__sandbox {
  width: 100%;
  height: 100%;
  border: none;
}

.yh-ai-artifacts__code-viewer {
  margin: 0;
  padding: 24px;
  height: 100%;
  overflow: auto;
  font-family: var(--yh-font-family-mono);
  font-size: 13px;
  line-height: 1.6;
  background: #282c34;
  color: #abb2bf;
}

.yh-ai-artifacts__placeholder {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--yh-text-color-secondary);
  gap: 16px;
}
.yh-ai-artifacts__placeholder .yh-icon {
  font-size: 48px;
  opacity: 0.2;
}

.yh-ai-artifacts__footer {
  padding: 8px 16px;
  font-size: 12px;
  color: var(--yh-text-color-placeholder);
  background: var(--yh-fill-color-light);
  display: flex;
  justify-content: space-between;
}

@container ai-artifacts (max-width: 720px) {
  .yh-ai-artifacts__header {
    flex-wrap: wrap;
    gap: 12px;
    align-items: flex-start;
  }
  .yh-ai-artifacts__actions {
    width: 100%;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .yh-ai-artifacts__tabs {
    flex: 1 1 auto;
    min-width: 0;
  }
}
@container ai-artifacts (max-width: 520px) {
  .yh-ai-artifacts__tab {
    flex: 1 1 0;
    text-align: center;
  }
  .yh-ai-artifacts__version-bar {
    flex-direction: column;
    align-items: flex-start;
  }
  .yh-ai-artifacts__footer {
    flex-direction: column;
    gap: 4px;
    align-items: flex-start;
  }
}

.yh-slide-right-enter-active,
.yh-slide-right-leave-active {
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.yh-slide-right-enter-from,
.yh-slide-right-leave-to {
  transform: translateX(100%);
}