/* DAE Revamp — shared visual primitives layered on top of colors_and_type.css */

/* === atoms === */
.dae-wrap { max-width: 1240px; margin: 0 auto; padding: 0 40px; }

/* Headline accent — a thin sky-blue underline under the last word, used sparingly */
.dae-h1 { font: 600 64px/1.04 var(--font-display); letter-spacing: -0.035em; color: var(--color-ink); }
.dae-h2 { font: 600 44px/1.10 var(--font-display); letter-spacing: -0.030em; color: var(--color-ink); }
.dae-h3 { font: 600 28px/1.20 var(--font-display); letter-spacing: -0.020em; color: var(--color-ink); }
.dae-h4 { font: 600 20px/1.30 var(--font-display); letter-spacing: -0.012em; color: var(--color-ink); }
.dae-eyebrow {
  font: 500 12px/1 var(--font-mono); letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--dae-blue);
  display: inline-flex; align-items: center; gap: 8px;
}
.dae-eyebrow::before {
  content: ""; width: 18px; height: 1px; background: var(--dae-blue);
}
.dae-lede { font: 400 18px/1.6 var(--font-body); color: var(--color-body); }
.dae-mono { font: 500 12px/1 var(--font-mono); letter-spacing: 0.06em; text-transform: uppercase; }

/* === buttons === */
.dae-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 44px; padding: 0 22px; border: 0; border-radius: 6px;
  font: 500 14px/1 var(--font-body); cursor: pointer; text-decoration: none;
  white-space: nowrap; transition: background 150ms ease, border-color 150ms ease, color 150ms ease;
}
.dae-btn-primary  { background: var(--dae-blue); color: #fff; }
.dae-btn-primary:hover { background: var(--dae-blue-600); }
.dae-btn-secondary{ background: transparent; color: var(--color-ink); border: 1px solid var(--color-hairline); }
.dae-btn-secondary:hover { border-color: var(--color-ink); }
.dae-btn-ghost { background: transparent; color: var(--dae-blue); padding: 0 10px; }
.dae-btn-on-dark { background: #fff; color: var(--color-ink); }
.dae-btn-on-dark-outline { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,0.22); }
.dae-btn-on-dark-outline:hover { border-color: #fff; }
.dae-btn-sm { height: 36px; padding: 0 14px; font-size: 13px; }
.dae-btn-lg { height: 52px; padding: 0 28px; font-size: 15px; }

/* === language switch (EN/TH/ZH) === */
.dae-lang {
  display: inline-flex; align-items: center; gap: 2px;
  padding: 3px; background: var(--color-surface-soft);
  border-radius: 999px; font: 500 12px/1 var(--font-mono);
}
.dae-lang button {
  border: 0; background: transparent; color: var(--color-muted);
  padding: 6px 10px; border-radius: 999px; cursor: pointer;
  letter-spacing: 0.04em; font: inherit;
}
.dae-lang button.is-active { background: #fff; color: var(--color-ink); box-shadow: 0 1px 2px rgba(14,29,49,.06); }

/* === DAE wordmark === */
.dae-wordmark {
  font: 700 22px/1 var(--font-display); letter-spacing: -0.06em;
  color: var(--dae-blue); display: inline-flex; align-items: center; gap: 10px;
}
.dae-wordmark .pill {
  font: 500 10px/1 var(--font-mono); letter-spacing: 0.08em;
  color: var(--color-muted); text-transform: uppercase;
  border-left: 1px solid var(--color-hairline); padding-left: 10px;
}
.dae-wordmark-dark { color: #fff; }
.dae-wordmark-dark .pill { color: var(--color-on-dark-soft); border-left-color: rgba(255,255,255,0.18); }

/* === card primitives === */
.dae-card {
  background: #fff; border: 1px solid var(--color-hairline);
  border-radius: 12px; padding: 28px;
}
.dae-card-flat { background: #fff; border: 1px solid var(--color-hairline); border-radius: 10px; }
.dae-hair { border-top: 1px solid var(--color-hairline); }

/* === badge / chip === */
.dae-chip {
  display: inline-flex; align-items: center; gap: 8px;
  height: 26px; padding: 0 10px; border-radius: 999px;
  font: 500 12px/1 var(--font-mono); letter-spacing: 0.04em;
  background: var(--dae-blue-100); color: var(--dae-blue-700);
}
.dae-chip-success { background: #ecfdf5; color: #047857; }
.dae-chip-warn    { background: #fff8e6; color: #92400e; }
.dae-chip-mute    { background: var(--color-surface-soft); color: var(--color-muted); }
.dae-chip::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor;
  opacity: 0.7;
}

/* === status dot === */
.dae-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-success); box-shadow: 0 0 0 4px rgba(16,185,129,0.12); display: inline-block; }
.dae-dot-warn { background: var(--dae-amber); box-shadow: 0 0 0 4px rgba(255,183,3,0.15); }
.dae-dot-error { background: var(--color-error); box-shadow: 0 0 0 4px rgba(239,68,68,0.15); }

/* === Tables (clean, hairlined) === */
.dae-table { width: 100%; border-collapse: collapse; font: 400 13px/1.4 var(--font-body); color: var(--color-body); }
.dae-table th { text-align: left; font: 500 11px/1 var(--font-mono); letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--color-muted); padding: 12px 16px; background: var(--color-surface-soft); border-bottom: 1px solid var(--color-hairline); }
.dae-table td { padding: 14px 16px; border-bottom: 1px solid var(--color-hairline-soft); }
.dae-table tr:last-child td { border-bottom: 0; }
.dae-table .num { font-family: var(--font-mono); color: var(--color-ink); text-align: right; }

/* mini sparkline */
.dae-spark { display: block; width: 100%; height: 32px; }

/* design-canvas artboard backdrop */
.dae-artboard { background: #fff; color: var(--color-body); font-family: var(--font-body); }

/* fix: design canvas swallows certain font-related resets. Be explicit. */
.dae-artboard *, .dae-artboard *::before, .dae-artboard *::after { box-sizing: border-box; }
.dae-artboard a { text-decoration: none; }
.dae-artboard h1, .dae-artboard h2, .dae-artboard h3, .dae-artboard h4 { margin: 0; }
.dae-artboard p, .dae-artboard ul, .dae-artboard li { margin: 0; }
.dae-artboard ul { list-style: none; padding: 0; }
