/*
 * tools/_shared/color-examples.css
 * 颜色示例预览样式 — color_tool / design_md 共用
 */

/* ========== 颜色示例：通用 ========== */
/* .ct-examples 已替换为全局 .grid.grid-2（定义完全一致，含响应式） */

.ct-ex-section {
  background: var(--bg-surface);
  border: 1px solid var(--border-base);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}
.ct-ex-section h4 {
  margin: 0 0 var(--space-3);
  font-size: var(--text-sm); font-weight: 600;
  color: var(--fg-strong);
}

/* --- Chat 示例（容器已替换为全局 .u-col.u-gap-2） --- */

/* --- Toast 示例 --- */
.ct-ex-toast {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3); border-radius: var(--radius-sm);
  border-left: 4px solid; margin-bottom: var(--space-2);
  background: var(--bg-surface-2);
}
.ct-ex-toast i { font-size: 1.25rem; flex-shrink: 0; }
.ct-ex-toast-body { flex: 1; }
.ct-ex-toast-title { font-size: var(--text-sm); font-weight: 600; margin-bottom: 2px; }
.ct-ex-toast-msg { font-size: var(--text-xs); color: var(--fg-muted); }

/* --- Chat 示例（.ct-ex-chat 已替换为全局 .u-col.u-gap-2） --- */
.ct-ex-bubble {
  max-width: 80%; padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md); font-size: var(--text-sm); line-height: 1.5;
}
.ct-ex-bubble.is-left {
  align-self: flex-start;
  background: var(--bg-surface-2); color: var(--fg-base);
  border-bottom-left-radius: var(--radius-sm);
}
.ct-ex-bubble.is-right {
  align-self: flex-end;
  background: var(--ct-primary, var(--color-brand)); color: var(--fg-invert);
  border-bottom-right-radius: var(--radius-sm);
}

/* --- 按钮示例 --- */
.ct-ex-btn {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm); font-size: var(--text-sm);
  font-weight: 500; cursor: pointer; border: none;
  transition: opacity var(--dur-fast), transform var(--dur-fast);
}
.ct-ex-btn:hover { opacity: .9; }
.ct-ex-btn:active { transform: scale(.97); }
.ct-ex-btn.is-fill {
  background: var(--ct-primary, var(--color-brand)); color: var(--fg-invert);
}
.ct-ex-btn.is-outline {
  background: transparent; color: var(--ct-primary, var(--color-brand));
  border: 1.5px solid var(--ct-primary, var(--color-brand));
}
.ct-ex-btn.is-ghost {
  background: color-mix(in srgb, var(--ct-primary, var(--color-brand)) 10%, transparent);
  color: var(--ct-primary, var(--color-brand)); border: none;
}
.ct-ex-btn.is-disabled {
  opacity: .45; cursor: not-allowed; pointer-events: none;
  background: var(--ct-primary, var(--color-brand)); color: var(--fg-invert);
}

/* --- 进度条示例 --- */
.ct-ex-progress { margin-bottom: var(--space-3); }
.ct-ex-progress-bar {
  height: 10px; border-radius: var(--radius-pill);
  background: var(--bg-surface-2); overflow: hidden;
  margin-top: var(--space-1);
}
.ct-ex-progress-fill {
  height: 100%; border-radius: var(--radius-pill);
  transition: width var(--dur-slow);
}
.ct-ex-progress-label {
  display: flex; justify-content: space-between;
  font-size: var(--text-xs); color: var(--fg-muted);
}

/* --- Tag 示例（.ct-ex-tags 已替换为全局 .grid-chips） --- */
.ct-ex-tag-demo {
  display: flex; flex-direction: column; gap: var(--space-4);
}
.ct-ex-tag-group {
  display: flex; flex-direction: column; gap: var(--space-2);
}
.ct-ex-tag-label {
  font-size: var(--text-xs); color: var(--ct-muted, var(--fg-muted));
}
.ct-ex-tag {
  display: inline-flex; align-items: center; gap: var(--space-1);
  min-height: 24px; padding: 3px var(--space-3);
  border: 1px solid transparent; border-radius: var(--ct-radius-pill, var(--radius-pill));
  font-size: var(--text-xs); font-weight: 600; line-height: 1;
  color: var(--ct-on-primary, var(--fg-invert));
  white-space: nowrap;
}
.ct-ex-tag svg {
  width: 12px; height: 12px; stroke-width: 2.25;
}
.ct-ex-tag-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor; flex-shrink: 0;
}
.ct-ex-tag-count {
  min-width: 17px; height: 17px; padding: 0 4px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, currentColor 14%, transparent);
  font-size: 10px; line-height: 1;
}
.ct-ex-tag-remove {
  width: 14px; height: 14px; margin-right: -3px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%; background: color-mix(in srgb, currentColor 12%, transparent);
  font-size: 12px; line-height: 1;
}

/* --- Input 示例 --- */
.ct-ex-input {
  width: 100%; padding: var(--space-2) var(--space-3);
  border: 2px solid var(--border-base); border-radius: var(--radius-sm);
  font-size: var(--text-sm); background: var(--bg-surface);
  color: var(--fg-base); transition: border-color var(--dur-fast);
  outline: none;
}
.ct-ex-input:focus,
.ct-ex-input.is-focused {
  border-color: var(--ct-primary, var(--color-brand));
}

/* --- Card 示例 --- */
.ct-ex-card {
  border: 1px solid var(--border-base); border-radius: var(--radius-md);
  overflow: hidden;
}
.ct-ex-card-header {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-base);
  display: flex; justify-content: space-between; align-items: center;
}
.ct-ex-card-header h5 { margin: 0; font-size: var(--text-sm); color: var(--fg-strong); }
.ct-ex-card-badge {
  padding: 2px var(--space-2); border-radius: var(--radius-pill);
  font-size: 11px; font-weight: 600; color: var(--fg-invert);
  background: var(--ct-primary, var(--color-brand));
}
.ct-ex-card-body {
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm); color: var(--fg-muted); line-height: 1.6;
}
.ct-ex-card-footer {
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--border-base);
}

/* --- 特性卡片 --- */
.ct-ex-feature {
  position: relative; overflow: hidden;
  background: linear-gradient(
    135deg,
    var(--ct-primary-soft, var(--ct-50, var(--color-brand-soft))) 0%,
    var(--ct-surface-card, var(--bg-surface)) 100%
  );
  padding: var(--space-6) var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.ct-ex-feature-circle {
  width: 5rem; height: 5rem;
  background: var(--ct-primary, var(--color-brand));
  border-radius: 50%; position: absolute;
  right: -1rem; top: -1.25rem;
  display: flex; align-items: flex-end; justify-content: flex-start;
  padding: 0 0 1.25rem 1.5rem;
}
.ct-ex-feature-circle span { color: var(--fg-invert); font-size: 1.25rem; font-weight: 500; }
.ct-ex-feature-icon {
  width: 2.5rem; height: 2.5rem;
  color: var(--ct-primary, var(--color-brand)); font-size: 2.5rem;
}
.ct-ex-feature-title {
  font-weight: 700; font-size: var(--text-lg); color: var(--fg-strong);
  margin: 0; padding-top: var(--space-2);
}
.ct-ex-feature-desc {
  font-size: var(--text-sm); line-height: 1.8; color: var(--fg-muted); margin: 0;
}

/* --- 定价 / 颜色系统卡片 --- */
.ct-ex-pricing {
  display: flex; flex-direction: column; gap: var(--space-3);
  background: linear-gradient(
    180deg,
    var(--ct-primary-soft, var(--ct-50, var(--color-brand-soft))) 0%,
    var(--ct-surface-card, var(--bg-surface)) 30%
  );
  padding: 0 !important;
}
.ct-ex-pricing-inner {
  display: flex; flex-direction: column; gap: var(--space-3);
  padding: var(--space-5);
}
.ct-ex-pricing-title {
  font-weight: 700; font-size: var(--text-lg); color: var(--fg-strong); margin: 0;
}
.ct-ex-pricing-desc {
  font-size: var(--text-sm); color: var(--fg-muted); margin: 0;
}
.ct-ex-switch-tabs {
  display: flex; position: relative;
  padding: 2px; background: var(--bg-surface-2);
  border-radius: var(--radius-md);
}
.ct-ex-switch-tab {
  width: 50%; height: 32px; position: relative; z-index: 2;
  background: transparent; border: 0; outline: none;
  cursor: pointer; font-weight: 500; font-size: var(--text-sm);
  color: var(--fg-muted); border-radius: var(--radius-sm);
  transition: color var(--dur-base);
}
.ct-ex-switch-tab:hover { color: var(--fg-base); }
.ct-ex-switch-tab.is-active { color: var(--fg-strong); }
.ct-ex-switch-indicator {
  position: absolute; top: 2px; left: 2px; width: calc(50% - 2px); height: 32px;
  background: var(--bg-surface); border: 1px solid var(--border-base);
  box-shadow: var(--shadow-xs);
  border-radius: var(--radius-sm);
  transition: left var(--dur-base) var(--ease-standard);
  z-index: 1;
}
.ct-ex-feature-list { display: flex; flex-direction: column; gap: var(--space-2); }
.ct-ex-feature-list-title {
  font-size: var(--text-sm); font-weight: 600; color: var(--fg-strong);
}
.ct-ex-feature-list ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: var(--space-2);
}
.ct-ex-feature-list li {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-sm); color: var(--fg-muted);
}
.ct-ex-feature-list li i {
  color: var(--ct-primary, var(--color-brand)); font-size: 1.1rem; flex-shrink: 0;
}
.ct-ex-pricing-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--border-base);
}
.ct-ex-price {
  font-size: 2rem; font-weight: 800; color: var(--fg-strong);
}
.ct-ex-price sup { font-size: var(--text-sm); top: -.8em; }
.ct-ex-price sub { font-size: var(--text-xs); color: var(--fg-muted); font-weight: 400; }
.ct-ex-pricing-action {
  min-width: 100px; height: 36px;
  background: var(--ct-primary, var(--color-brand)); color: var(--fg-invert);
  border: 0; border-radius: var(--radius-sm);
  font-size: var(--text-sm); font-weight: 600;
  cursor: pointer; transition: opacity var(--dur-fast);
}
.ct-ex-pricing-action:hover { opacity: .9; }

/* --- 圆环图 --- */
.ct-ex-doughnut {
  position: relative; width: 100%; height: 240px;
  display: flex; align-items: center; justify-content: center;
}
.ct-ex-doughnut svg { width: 220px; height: 220px; }
.ct-ex-doughnut-center {
  position: absolute; font-size: var(--text-sm); font-weight: 600;
  color: var(--fg-muted); pointer-events: none;
}
.ct-ex-doughnut-legend {
  display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-3);
}
.ct-ex-doughnut-legend span {
  display: flex; align-items: center; gap: var(--space-1);
  font-size: var(--text-xs); color: var(--fg-muted);
}
.ct-ex-doughnut-legend i {
  width: var(--space-2); height: var(--space-2); border-radius: calc(var(--radius-sm) / 2); display: inline-block;
}

/* --- Radio 选项卡 --- */
.ct-ex-radios { display: flex; flex-direction: column; gap: var(--space-2); }
.ct-ex-radio {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3); border-radius: var(--radius-sm);
  cursor: pointer; transition: background .15s; position: relative;
}
.ct-ex-radio:hover { background: var(--bg-surface-2); }
.ct-ex-radio-icon {
  width: 1.25rem; height: 1.25rem;
  color: var(--ct-primary, var(--color-brand)); font-size: 1.25rem;
  flex-shrink: 0;
}
.ct-ex-radio-label { font-size: var(--text-sm); font-weight: 500; color: var(--fg-base); flex: 1; }
.ct-ex-radio input[type="radio"] {
  accent-color: var(--ct-primary, var(--color-brand));
  width: 1rem; height: 1rem; margin: 0;
}

/* --- Primary / Outline 按钮分组 --- */
.ct-ex-btn-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-2); }
@media (max-width: 640px) { .ct-ex-btn-grid { grid-template-columns: repeat(2, 1fr); } }
.ct-ex-btn.is-hover { opacity: .85; }
.ct-ex-btn.is-active { transform: translateY(1px); }
.ct-ex-btn.is-outline-hover { border-color: var(--ct-600, var(--color-brand)); color: var(--ct-600, var(--color-brand)); }
.ct-ex-btn.is-outline-active { border-color: var(--ct-700, var(--color-brand)); color: var(--ct-700, var(--color-brand)); }

/* --- Token 主题变量覆盖 --- */
/* 渐变卡片（feature / pricing）保留主色渐变，不被纯色覆盖 */
.ct-ex-themed .ct-ex-section:not(.ct-ex-feature):not(.ct-ex-pricing):not(.ct-ex-dark-band) {
  background: var(--ct-surface-card, var(--bg-surface));
  border-color: var(--ct-hairline, var(--border-base));
}
.ct-ex-themed .ct-ex-section h4 { color: var(--ct-ink, var(--fg-strong)); }
.ct-ex-themed .ct-ex-feature-title,
.ct-ex-themed .ct-ex-pricing-title { color: var(--ct-ink, var(--fg-strong)); }
.ct-ex-themed .ct-ex-feature-desc,
.ct-ex-themed .ct-ex-pricing-desc { color: var(--ct-body, var(--fg-muted)); }
.ct-ex-themed .ct-ex-pricing-action { color: var(--ct-on-primary, var(--fg-invert)); }
.ct-ex-themed .ct-ex-feature-circle span { color: var(--ct-on-primary, var(--fg-invert)); }
.ct-ex-section-hint {
  margin: calc(-1 * var(--space-2)) 0 var(--space-3);
  font-size: var(--text-xs); color: var(--fg-muted); line-height: 1.5;
}
.ct-ex-btn.is-fill {
  background: var(--ct-primary, var(--color-brand));
  color: var(--ct-on-primary, var(--fg-invert));
}
.ct-ex-btn.is-fill.is-hover { background: var(--ct-primary-active, var(--ct-primary)); }
.ct-ex-btn.is-fill.is-active { background: var(--ct-primary-active, var(--ct-primary)); transform: translateY(1px); }
.ct-ex-bubble.is-right {
  background: var(--ct-primary, var(--color-brand));
  color: var(--ct-on-primary, var(--fg-invert));
}
.ct-ex-progress-fill {
  background: var(--ct-primary, var(--color-brand));
}
.ct-ex-progress-fill.is-success { background: var(--ct-success, var(--color-success)); }
.ct-ex-tag.is-primary { background: var(--ct-primary, var(--color-brand)); }
.ct-ex-tag.is-success { background: var(--ct-success, var(--color-success)); }
.ct-ex-tag.is-warning { background: var(--ct-warning, var(--color-warning)); }
.ct-ex-tag.is-danger  { background: var(--ct-danger, var(--color-danger)); }
.ct-ex-tag.is-info    { background: var(--ct-info, var(--color-info)); }
.ct-ex-tag.is-neutral {
  color: var(--ct-body, var(--fg-base));
  background: var(--ct-surface-raised, var(--bg-surface-2));
  border-color: var(--ct-hairline, var(--border-base));
}
.ct-ex-tag.is-soft {
  color: var(--tag-color, var(--ct-primary, var(--color-brand)));
  background: color-mix(in srgb, var(--tag-color, var(--ct-primary, var(--color-brand))) 12%, var(--ct-surface-card, var(--bg-surface)));
}
.ct-ex-tag.is-outline {
  color: var(--tag-color, var(--ct-primary, var(--color-brand)));
  background: transparent;
  border-color: color-mix(in srgb, var(--tag-color, var(--ct-primary, var(--color-brand))) 42%, transparent);
}
.ct-ex-tag.is-success { --tag-color: var(--ct-success, var(--color-success)); }
.ct-ex-tag.is-warning { --tag-color: var(--ct-warning, var(--color-warning)); }
.ct-ex-tag.is-danger  { --tag-color: var(--ct-danger, var(--color-danger)); }
.ct-ex-tag.is-info    { --tag-color: var(--ct-info, var(--color-info)); }

/* --- YAML 组件 Token 行 --- */
.ct-ex-token-row { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; }
.ct-ex-token-btn { cursor: default; border: none; }
.ct-ex-token-badge { display: inline-block; }
.ct-ex-wcag { font-size: 10px; font-weight: 600; margin-left: var(--space-2); opacity: .85; }

/* --- 表面层级 --- */
.ct-ex-surface-stack {
  display: flex; flex-direction: column; gap: var(--space-2);
  padding: var(--space-3); border-radius: var(--ct-radius-md, var(--radius-md));
  background: var(--ct-canvas, var(--bg-surface-2));
}
.ct-ex-surface-layer {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-3) var(--space-4); border-radius: var(--ct-radius-md, var(--radius-md));
  font-size: var(--text-sm);
}
.ct-ex-surface-layer span { font-weight: 600; color: var(--ct-ink, var(--fg-strong)); }
.ct-ex-surface-layer code {
  font-size: var(--text-xs); font-family: var(--font-mono); color: var(--ct-muted, var(--fg-muted));
  cursor: pointer;
}
.ct-ex-surface-layer.is-canvas  { background: var(--ct-canvas, var(--bg-surface-2)); }
.ct-ex-surface-layer.is-raised  { background: var(--ct-surface-raised, var(--bg-surface-2)); }
.ct-ex-surface-layer.is-card    { background: var(--ct-surface-card, var(--bg-surface)); box-shadow: 0 1px 0 var(--ct-hairline, var(--border-subtle)); }

/* --- 文本层级 --- */
.ct-ex-type-stack { display: flex; flex-direction: column; gap: var(--space-3); }
.ct-ex-type-display { color: var(--ct-ink, var(--fg-strong)); }
.ct-ex-type-title   { color: var(--ct-ink, var(--fg-strong)); }
.ct-ex-type-body    { color: var(--ct-body, var(--fg-base)); }
.ct-ex-type-caption { color: var(--ct-muted, var(--fg-muted)); text-transform: uppercase; letter-spacing: .04em; }

/* --- 反色条带 --- */
.ct-ex-dark-band { padding: 0 !important; overflow: hidden; border: none !important; }
.ct-ex-dark-inner {
  display: flex; flex-direction: column; gap: var(--space-2);
  padding: var(--space-5);
  background: var(--ct-dark-bg, #1a1a2e);
  color: var(--ct-on-dark, #f8f8fc);
  border-radius: var(--ct-radius-md, var(--radius-md));
}
.ct-ex-dark-inner strong { font-size: var(--text-lg); }
.ct-ex-dark-inner span { font-size: var(--text-sm); opacity: .75; }
.ct-ex-dark-cta {
  align-self: flex-start; margin-top: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background: var(--ct-primary, var(--color-brand));
  color: var(--ct-on-primary, var(--fg-invert));
  border: none; border-radius: var(--ct-radius-sm, var(--radius-sm));
  font-size: var(--text-sm); font-weight: 600; cursor: default;
}

/* --- 表格斑马纹 --- */
.ct-ex-table {
  width: 100%; border-collapse: collapse; font-size: var(--text-sm);
}
.ct-ex-table th {
  text-align: left; padding: var(--space-2) var(--space-3);
  color: var(--ct-muted, var(--fg-muted)); font-weight: 600;
  border-bottom: 1px solid var(--ct-hairline, var(--border-base));
}
.ct-ex-table td {
  padding: var(--space-2) var(--space-3);
  color: var(--ct-body, var(--fg-base));
  border-bottom: 1px solid var(--ct-hairline, var(--border-base));
}
.ct-ex-table tbody tr:nth-child(even) { background: var(--ct-surface-stripe, var(--bg-surface-2)); }

/* --- 输入框扩展 --- */
.ct-ex-field-label {
  font-size: var(--text-xs); color: var(--ct-muted, var(--fg-muted));
  margin-bottom: var(--space-1);
}
.ct-ex-input.is-error { border-color: var(--ct-danger, var(--color-danger)); }
.ct-ex-field-error {
  font-size: var(--text-xs); color: var(--ct-danger, var(--color-danger));
  margin-top: var(--space-1);
}
.ct-ex-themed .ct-ex-input {
  border-color: var(--ct-hairline, var(--border-base));
  background: var(--ct-surface-card, var(--bg-surface));
  color: var(--ct-ink, var(--fg-base));
}
.ct-ex-themed .ct-ex-card {
  border-color: var(--ct-hairline, var(--border-base));
  background: var(--ct-surface-card, var(--bg-surface));
}
.ct-ex-themed .ct-ex-card-body { color: var(--ct-body, var(--fg-muted)); }
