/* ============================================================
   DOMUNN — Design Language v2 (Editorial Luxury)
   Single source of truth across the site.
   Loaded once per page after the existing style-system.css
   so it can override legacy chrome where needed.
   ============================================================ */

/* ── Fonts ────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,300..800;1,6..72,300..800&family=Instrument+Serif:ital@0;1&family=DM+Sans:opsz,wght@9..40,300..700&family=JetBrains+Mono:wght@400;500&family=Noto+Serif+TC:wght@400;500;600;700&family=Noto+Sans+TC:wght@300;400;500;700&display=swap');

/* ── Tokens ──────────────────────────────────────────────── */
:root {
  /* Surfaces — uneven by design */
  --dm-ink: #0A0A0B;
  --dm-ink-2: #131315;
  --dm-ink-3: #1C1C1F;
  --dm-ink-4: #232326;
  --dm-paper: #F4F0E8;
  --dm-paper-2: #E8E2D4;
  --dm-bone: #EDEAE2;
  --dm-bone-dim: rgba(237,234,226,0.62);
  --dm-bone-soft: rgba(237,234,226,0.42);
  --dm-bone-ghost: rgba(237,234,226,0.14);
  --dm-smoke: #6F6F6A;
  --dm-line: rgba(237,234,226,0.10);
  --dm-line-strong: rgba(237,234,226,0.22);
  --dm-line-paper: rgba(10,10,11,0.10);
  --dm-line-paper-strong: rgba(10,10,11,0.22);

  /* Accents */
  --dm-volt: #06C755;
  --dm-volt-hi: #1FE672;
  --dm-volt-low: #04A547;
  --dm-volt-glow: rgba(6,199,85,0.35);
  --dm-volt-soft: rgba(6,199,85,0.12);
  --dm-ember: #FF5B2E;
  --dm-ember-glow: rgba(255,91,46,0.35);
  --dm-danger: #E05050;
  --dm-warn: #F5B947;
  --dm-info: #6BA8FF;

  /* Type */
  --dm-display: 'Newsreader','Noto Serif TC',Georgia,serif;
  --dm-display-tc: 'Noto Serif TC','Newsreader',serif;
  --dm-display-italic: 'Instrument Serif','Newsreader',serif;
  --dm-body: 'DM Sans','Noto Sans TC',-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --dm-mono: 'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --dm-fraunces-display: "opsz" 72;
  --dm-fraunces-headline: "opsz" 48;
  --dm-fraunces-title:    "opsz" 24;
  --dm-fraunces-prose:    "opsz" 12;

  /* Easing */
  --dm-ease: cubic-bezier(0.4,0,0.2,1);
  --dm-ease-out: cubic-bezier(0.16,1,0.3,1);
  --dm-ease-in:  cubic-bezier(0.4,0,1,1);

  /* Type scale */
  --dm-step--2: clamp(0.69rem,0.66rem + 0.16vw,0.78rem);
  --dm-step--1: clamp(0.83rem,0.78rem + 0.27vw,1.00rem);
  --dm-step-0:  clamp(1.00rem,0.93rem + 0.41vw,1.25rem);
  --dm-step-1:  clamp(1.20rem,1.09rem + 0.61vw,1.56rem);
  --dm-step-2:  clamp(1.44rem,1.27rem + 0.87vw,1.95rem);
  --dm-step-3:  clamp(1.73rem,1.47rem + 1.23vw,2.44rem);
  --dm-step-4:  clamp(2.07rem,1.69rem + 1.71vw,3.05rem);
  --dm-step-5:  clamp(2.49rem,1.93rem + 2.34vw,3.82rem);
  --dm-step-6:  clamp(2.99rem,2.18rem + 3.18vw,4.77rem);
  --dm-step-7:  clamp(3.58rem,2.43rem + 4.27vw,5.96rem);
  --dm-step-8:  clamp(4.30rem,2.66rem + 5.69vw,7.45rem);
  --dm-step-9:  clamp(5.16rem,2.81rem + 7.46vw,9.31rem);

  /* Layout */
  --dm-gutter: clamp(20px,4vw,64px);
  --dm-max: 1400px;
  --dm-max-narrow: 980px;
  --dm-prose: 62ch;

  /* Radii — almost none */
  --dm-r-0: 0;
  --dm-r-1: 2px;
  --dm-r-2: 4px;
  --dm-r-3: 8px;
  --dm-r-pill: 999px;

  /* Shadows — rare */
  --dm-shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
  --dm-shadow-md: 0 6px 24px rgba(0,0,0,0.3);
  --dm-shadow-lg: 0 18px 64px rgba(0,0,0,0.5);

  /* Z-stack */
  --dm-z-nav: 50;
  --dm-z-toast: 60;
  --dm-z-modal: 80;
}

/* ── Base ────────────────────────────────────────────────── */
.dm, html.dm, body.dm {
  background: var(--dm-ink);
  color: var(--dm-bone);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-family: var(--dm-body);
  font-size: var(--dm-step-0);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.01em;
}
body.dm { margin: 0; overflow-x: hidden; }
body.dm.dm-paper { background: var(--dm-paper); color: var(--dm-ink); }

body.dm ::selection { background: var(--dm-volt-glow); color: var(--dm-bone); }
body.dm.dm-paper ::selection { background: var(--dm-ink); color: var(--dm-paper); }

body.dm img, body.dm svg { display: block; max-width: 100%; }
body.dm a { color: inherit; text-decoration: none; }

body.dm :where(button, a, input, select, textarea, [tabindex], [role="button"]):focus-visible {
  outline: 2px solid var(--dm-volt);
  outline-offset: 3px;
  border-radius: 2px;
}
body.dm :where(button, a, input, select, textarea, [tabindex], [role="button"]):focus:not(:focus-visible) {
  outline: none;
}

body.dm ::-webkit-scrollbar { width: 10px; height: 10px; }
body.dm ::-webkit-scrollbar-track { background: transparent; }
body.dm ::-webkit-scrollbar-thumb { background: rgba(237,234,226,0.10); border-radius: 5px; }
body.dm ::-webkit-scrollbar-thumb:hover { background: rgba(237,234,226,0.22); }
body.dm.dm-paper ::-webkit-scrollbar-thumb { background: rgba(10,10,11,0.12); }
body.dm.dm-paper ::-webkit-scrollbar-thumb:hover { background: rgba(10,10,11,0.30); }

@media (prefers-reduced-motion: reduce) {
  body.dm *, body.dm *::before, body.dm *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ── Layout primitives ────────────────────────────────────── */
.dm-wrap {
  width: 100%;
  max-width: var(--dm-max);
  margin-inline: auto;
  padding-inline: var(--dm-gutter);
  position: relative;
}
.dm-wrap--narrow { max-width: var(--dm-max-narrow); }

.dm-section {
  padding-block: clamp(80px, 12vw, 200px);
  position: relative;
}
.dm-section--sm { padding-block: clamp(56px, 8vw, 120px); }
.dm-section--tight { padding-block: clamp(40px, 5vw, 64px); }
.dm-section--paper { background: var(--dm-paper); color: var(--dm-ink); }
.dm-section--paper ::selection { background: var(--dm-ink); color: var(--dm-paper); }
.dm-section--ink { background: var(--dm-ink); color: var(--dm-bone); }
.dm-section--ink-2 { background: var(--dm-ink-2); color: var(--dm-bone); }

.dm-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
}
.dm-grid--tight { gap: 16px; }
.dm-grid--loose { gap: 48px; }

.dm-rule {
  height: 1px;
  width: 100%;
  background: var(--dm-line);
  display: block;
  position: relative;
  overflow: hidden;
  border: 0;
}
.dm-section--paper .dm-rule { background: var(--dm-line-paper); }
.dm-rule--volt::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 0;
  background: var(--dm-volt);
  transition: width 1.4s var(--dm-ease-out);
}
.is-in .dm-rule--volt::after,
.dm-rule--volt.is-in::after { width: 38%; }

.dm-chapter {
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dm-bone-dim);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.dm-section--paper .dm-chapter { color: var(--dm-smoke); }
.dm-chapter::before {
  content: "";
  display: inline-block;
  width: 24px; height: 1px;
  background: var(--dm-volt);
}

.dm-eyebrow {
  font-family: var(--dm-mono);
  font-size: var(--dm-step--1);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--dm-bone-dim);
}
.dm-section--paper .dm-eyebrow { color: var(--dm-smoke); }

.dm-cap {
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--dm-bone-dim);
}
.dm-section--paper .dm-cap { color: var(--dm-smoke); }

.dm-section-title {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 32px;
  margin-bottom: 64px;
  align-items: baseline;
}
.dm-section-title .dm-section-num {
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.1em;
  color: var(--dm-bone-dim);
}
.dm-section--paper .dm-section-title .dm-section-num { color: var(--dm-smoke); }
@media (max-width: 720px) {
  .dm-section-title { grid-template-columns: 1fr; gap: 12px; margin-bottom: 40px; }
}

/* ── Typography roles ─────────────────────────────────────── */
.dm-display {
  font-family: var(--dm-display);
  font-weight: 400;
  font-size: var(--dm-step-8);
  line-height: 0.92;
  letter-spacing: -0.035em;
  font-variation-settings: var(--dm-fraunces-display);
  margin: 0;
}
.dm-display em {
  font-family: var(--dm-display-italic);
  font-style: italic;
  font-variation-settings: normal;
}
.dm-display .tc { font-family: var(--dm-display-tc); font-weight: 700; letter-spacing: -0.02em; }

.dm-headline {
  font-family: var(--dm-display);
  font-weight: 500;
  font-size: var(--dm-step-6);
  line-height: 1.0;
  letter-spacing: -0.025em;
  font-variation-settings: var(--dm-fraunces-headline);
  margin: 0;
}
.dm-headline .tc { font-family: var(--dm-display-tc); font-weight: 700; }
.dm-headline em { font-family: var(--dm-display-italic); font-style: italic; font-variation-settings: normal; }

.dm-title {
  font-family: var(--dm-display);
  font-weight: 500;
  font-size: var(--dm-step-3);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-variation-settings: var(--dm-fraunces-title);
  margin: 0;
}
.dm-title .tc { font-family: var(--dm-display-tc); font-weight: 700; }
.dm-title em { font-family: var(--dm-display-italic); font-style: italic; font-variation-settings: normal; }

.dm-subtitle {
  font-family: var(--dm-display);
  font-weight: 500;
  font-size: var(--dm-step-2);
  line-height: 1.15;
  letter-spacing: -0.018em;
  font-variation-settings: "opsz" 24;
  margin: 0;
}

.dm-lede {
  font-family: var(--dm-body);
  font-size: var(--dm-step-2);
  line-height: 1.35;
  letter-spacing: -0.015em;
  font-weight: 400;
  max-width: 38ch;
  color: var(--dm-bone);
  margin: 0;
}
.dm-section--paper .dm-lede { color: var(--dm-ink); }

.dm-prose {
  font-family: var(--dm-body);
  font-size: var(--dm-step-0);
  line-height: 1.65;
  max-width: var(--dm-prose);
  color: var(--dm-bone-dim);
  margin: 0;
}
.dm-section--paper .dm-prose { color: rgba(10,10,11,0.72); }
.dm-prose p + p { margin-top: 1.2em; }

.dm-pullquote {
  font-family: var(--dm-display-italic);
  font-style: italic;
  font-weight: 400;
  font-size: var(--dm-step-5);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-variation-settings: normal;
  margin: 0;
}
.dm-pullquote .tc { font-style: normal; font-family: var(--dm-display-tc); font-weight: 700; }

.dm-volt { color: var(--dm-volt); }
.dm-ember { color: var(--dm-ember); }
.dm-num {
  font-family: var(--dm-display);
  font-variation-settings: var(--dm-fraunces-display);
  font-weight: 400;
  letter-spacing: -0.04em;
  line-height: 0.9;
}

.dm-mark {
  background-image: linear-gradient(var(--dm-volt), var(--dm-volt));
  background-repeat: no-repeat;
  background-position: 0 92%;
  background-size: 0% 8px;
  transition: background-size 0.9s var(--dm-ease-out);
  padding-bottom: 4px;
}
.is-in .dm-mark, .dm-mark.is-in { background-size: 100% 8px; }

/* ── Nav (universal — also retemes legacy nav classes) ───── */
.dm-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: var(--dm-z-nav);
  padding: 16px 0;
  background: rgba(10,10,11,0.65);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-bottom: 1px solid transparent;
  transition: border-color 0.4s var(--dm-ease), background 0.3s var(--dm-ease);
}
.dm-nav.is-scrolled { border-bottom-color: var(--dm-line); }
body.dm.dm-paper .dm-nav { background: rgba(244,240,232,0.78); }
body.dm.dm-paper .dm-nav.is-scrolled { border-bottom-color: var(--dm-line-paper); }
.dm-nav .dm-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.dm-logo {
  font-family: var(--dm-display);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -0.04em;
  font-variation-settings: "opsz" 60;
  position: relative;
  display: inline-block;
}
/* reverted per user — .dm-logo::after volt-dot removed */

.dm-nav-links {
  display: flex;
  align-items: center;
  gap: clamp(16px, 3vw, 32px);
}
.dm-nav-link {
  font-family: var(--dm-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dm-bone-dim);
  position: relative;
  padding: 6px 0;
  transition: color 0.3s var(--dm-ease);
  background: transparent;
  border: 0;
  cursor: pointer;
}
body.dm.dm-paper .dm-nav-link { color: var(--dm-smoke); }
.dm-nav-link::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: var(--dm-volt);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s var(--dm-ease-out);
}
.dm-nav-link:hover, .dm-nav-link.is-active { color: var(--dm-bone); }
body.dm.dm-paper .dm-nav-link:hover, body.dm.dm-paper .dm-nav-link.is-active { color: var(--dm-ink); }
.dm-nav-link:hover::after, .dm-nav-link.is-active::after { transform: scaleX(1); }

.dm-nav-actions { display: flex; align-items: center; gap: 12px; }

.dm-nav-burger {
  display: none;
  width: 36px; height: 36px;
  align-items: center;
  justify-content: center;
  position: relative;
  background: transparent;
  border: 0;
  cursor: pointer;
}
.dm-nav-burger span {
  display: block;
  width: 22px;
  height: 1px;
  background: var(--dm-bone);
  position: relative;
}
body.dm.dm-paper .dm-nav-burger span { background: var(--dm-ink); }
.dm-nav-burger span::before, .dm-nav-burger span::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 1px;
  background: inherit;
}
.dm-nav-burger span::before { top: -7px; }
.dm-nav-burger span::after { top: 7px; }

@media (max-width: 880px) {
  .dm-nav-links { display: none; }
  .dm-nav-burger { display: inline-flex; }
  .dm-nav-links.is-open {
    display: flex;
    position: fixed;
    inset: 64px 0 0 0;
    background: var(--dm-ink);
    flex-direction: column;
    gap: 24px;
    padding: 64px var(--dm-gutter);
    align-items: flex-start;
  }
  body.dm.dm-paper .dm-nav-links.is-open { background: var(--dm-paper); }
  .dm-nav-links.is-open .dm-nav-link { font-size: 16px; }
}

/* ── Buttons ──────────────────────────────────────────────── */
.dm-btn {
  --bg: var(--dm-bone);
  --fg: var(--dm-ink);
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 14px 22px;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--dm-body);
  font-weight: 500;
  font-size: var(--dm-step--1);
  letter-spacing: -0.01em;
  border-radius: var(--dm-r-pill);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border: 0;
  cursor: pointer;
  transition: transform 0.4s var(--dm-ease-out), color 0.3s var(--dm-ease);
  white-space: nowrap;
  line-height: 1;
}
.dm-btn .dm-btn-arrow {
  display: inline-block;
  transition: transform 0.4s var(--dm-ease-out);
  font-family: var(--dm-body);
}
.dm-btn:hover { transform: translateY(-1px); }
.dm-btn:hover .dm-btn-arrow { transform: translateX(4px); }
.dm-btn[disabled], .dm-btn.is-disabled { opacity: 0.4; pointer-events: none; }

.dm-btn--primary {
  background: var(--dm-bone);
  color: var(--dm-ink);
}
.dm-btn--primary::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--dm-volt);
  transform: translateX(-101%);
  transition: transform 0.5s var(--dm-ease-out);
  z-index: -1;
}
.dm-btn--primary:hover { color: var(--dm-ink); }
.dm-btn--primary:hover::before { transform: translateX(0); }

.dm-btn--volt {
  background: var(--dm-volt);
  color: var(--dm-ink);
}
.dm-btn--volt::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--dm-bone);
  transform: translateX(101%);
  transition: transform 0.5s var(--dm-ease-out);
  z-index: -1;
}
.dm-btn--volt:hover::before { transform: translateX(0); }

.dm-btn--ghost {
  background: transparent;
  color: var(--dm-bone);
  border: 1px solid var(--dm-line-strong);
}
body.dm.dm-paper .dm-btn--ghost, .dm-section--paper .dm-btn--ghost {
  color: var(--dm-ink); border-color: var(--dm-line-paper-strong);
}
.dm-btn--ghost::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--dm-bone);
  transform: translateY(101%);
  transition: transform 0.45s var(--dm-ease-out);
  z-index: -1;
}
body.dm.dm-paper .dm-btn--ghost::before,
.dm-section--paper .dm-btn--ghost::before { background: var(--dm-ink); }
.dm-btn--ghost:hover { color: var(--dm-ink); border-color: var(--dm-bone); }
body.dm.dm-paper .dm-btn--ghost:hover,
.dm-section--paper .dm-btn--ghost:hover { color: var(--dm-paper); border-color: var(--dm-ink); }
.dm-btn--ghost:hover::before { transform: translateY(0); }

.dm-btn--text {
  background: transparent;
  padding: 4px 0;
  border-radius: 0;
  color: inherit;
  position: relative;
  font-weight: 500;
}
.dm-btn--text::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: currentColor;
  transform-origin: right;
  transition: transform 0.5s var(--dm-ease-out), background 0.3s var(--dm-ease);
}
.dm-btn--text:hover { transform: none; }
.dm-btn--text:hover::after { transform-origin: left; background: var(--dm-volt); }
.dm-btn--text:hover .dm-btn-arrow { color: var(--dm-volt); }

.dm-btn--sm { padding: 10px 16px; font-size: var(--dm-step--2); gap: 10px; }
.dm-btn--lg { padding: 20px 30px; font-size: var(--dm-step-0); gap: 16px; }
.dm-btn--icon { padding: 14px; }
.dm-btn--full { width: 100%; justify-content: center; }

/* ── Inputs ──────────────────────────────────────────────── */
.dm-input-block {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dm-input-label {
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dm-bone-dim);
}
.dm-section--paper .dm-input-label,
body.dm.dm-paper .dm-input-label { color: var(--dm-smoke); }

.dm-input-wrap { position: relative; }
.dm-input-wrap::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: var(--dm-volt);
  transform: scaleX(0);
  transition: transform 0.45s var(--dm-ease-out);
}
.dm-input-wrap:focus-within::after { transform: scaleX(1); }

.dm-input, .dm-textarea, .dm-select {
  width: 100%;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--dm-line-strong);
  padding: 14px 0;
  font-size: var(--dm-step-1);
  font-family: var(--dm-body);
  color: var(--dm-bone);
  outline: 0;
  transition: border-color 0.3s var(--dm-ease);
  border-radius: 0;
}
.dm-section--paper .dm-input,
body.dm.dm-paper .dm-input,
.dm-section--paper .dm-textarea,
body.dm.dm-paper .dm-textarea,
.dm-section--paper .dm-select,
body.dm.dm-paper .dm-select {
  color: var(--dm-ink);
  border-bottom-color: var(--dm-line-paper-strong);
}
.dm-input::placeholder, .dm-textarea::placeholder { color: var(--dm-smoke); }
.dm-textarea { resize: vertical; min-height: 120px; line-height: 1.5; }
.dm-select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, currentColor 50%), linear-gradient(135deg, currentColor 50%, transparent 50%); background-position: calc(100% - 16px) 22px, calc(100% - 10px) 22px; background-size: 6px 6px, 6px 6px; background-repeat: no-repeat; padding-right: 28px; }

.dm-checkbox, .dm-radio {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-family: var(--dm-body);
  font-size: var(--dm-step--1);
}
.dm-checkbox input, .dm-radio input { appearance: none; width: 18px; height: 18px; border: 1px solid var(--dm-line-strong); background: transparent; position: relative; cursor: pointer; flex-shrink: 0; }
.dm-radio input { border-radius: 50%; }
.dm-checkbox input:checked, .dm-radio input:checked { background: var(--dm-volt); border-color: var(--dm-volt); }
.dm-checkbox input:checked::after {
  content: "";
  position: absolute;
  left: 5px; top: 1px;
  width: 5px; height: 10px;
  border: solid var(--dm-ink);
  border-width: 0 1.5px 1.5px 0;
  transform: rotate(45deg);
}
.dm-radio input:checked::after {
  content: "";
  position: absolute;
  inset: 4px;
  background: var(--dm-ink);
  border-radius: 50%;
}

/* ── Cards ───────────────────────────────────────────────── */
.dm-card {
  display: flex;
  flex-direction: column;
  padding: 28px;
  background: var(--dm-ink-2);
  border: 1px solid var(--dm-line);
  border-radius: var(--dm-r-2);
  position: relative;
  overflow: hidden;
  transition: border-color 0.4s var(--dm-ease), transform 0.4s var(--dm-ease-out);
}
.dm-section--paper .dm-card,
body.dm.dm-paper .dm-card { background: #FFFFFF; border-color: var(--dm-line-paper); }
.dm-card:hover { border-color: var(--dm-volt); transform: translateY(-3px); }

.dm-card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
  color: var(--dm-bone-dim);
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.dm-section--paper .dm-card-meta,
body.dm.dm-paper .dm-card-meta { color: var(--dm-smoke); }

.dm-card-num {
  font-family: var(--dm-display);
  font-size: var(--dm-step-7);
  line-height: 0.9;
  letter-spacing: -0.04em;
  font-variation-settings: var(--dm-fraunces-display);
  margin: 24px 0 8px;
}
.dm-card-title {
  font-family: var(--dm-display);
  font-weight: 500;
  font-size: var(--dm-step-2);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 36;
  margin: 0 0 12px;
}
.dm-card-body {
  color: var(--dm-bone-dim);
  font-size: var(--dm-step--1);
  line-height: 1.55;
  max-width: 38ch;
  margin-bottom: 24px;
}
.dm-section--paper .dm-card-body,
body.dm.dm-paper .dm-card-body { color: rgba(10,10,11,0.65); }
.dm-card-foot { margin-top: auto; }

.dm-card--feature { background: var(--dm-paper); color: var(--dm-ink); border: 0; }
.dm-card--feature .dm-card-meta, .dm-card--feature .dm-card-body { color: var(--dm-smoke); }
.dm-card--ink { background: var(--dm-ink); color: var(--dm-bone); border-color: var(--dm-line); }
.dm-card--ink .dm-card-meta, .dm-card--ink .dm-card-body { color: var(--dm-bone-dim); }
.dm-card--accent {
  background: transparent;
  border: 1px solid var(--dm-volt);
  color: inherit;
}
.dm-card--accent::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--dm-volt);
  transform: translateY(100%);
  transition: transform 0.6s var(--dm-ease-out);
  z-index: 0;
}
.dm-card--accent:hover::before { transform: translateY(0); }
.dm-card--accent:hover, .dm-card--accent:hover * { color: var(--dm-ink); border-color: var(--dm-volt); }
.dm-card--accent > * { position: relative; z-index: 1; }

/* ── Badges & chips ──────────────────────────────────────── */
.dm-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px 6px 8px;
  border-radius: var(--dm-r-pill);
  background: var(--dm-ink-3);
  border: 1px solid var(--dm-line);
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dm-bone);
}
.dm-badge::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--dm-volt);
  box-shadow: 0 0 8px var(--dm-volt-glow);
}
.dm-badge--solid { background: var(--dm-volt); color: var(--dm-ink); border-color: var(--dm-volt); }
.dm-badge--solid::before { background: var(--dm-ink); box-shadow: none; }
.dm-badge--ember { background: var(--dm-ember); color: var(--dm-ink); border-color: var(--dm-ember); }
.dm-badge--ember::before { background: var(--dm-ink); box-shadow: none; }
.dm-badge--ghost { background: transparent; }
.dm-section--paper .dm-badge,
body.dm.dm-paper .dm-badge {
  background: rgba(10,10,11,0.04);
  border-color: var(--dm-line-paper);
  color: var(--dm-ink);
}

.dm-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: var(--dm-r-pill);
  border: 1px solid var(--dm-line);
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--dm-bone-dim);
  background: transparent;
  cursor: pointer;
  transition: color 0.3s var(--dm-ease), border-color 0.3s var(--dm-ease), background 0.3s var(--dm-ease);
}
.dm-section--paper .dm-chip,
body.dm.dm-paper .dm-chip { border-color: var(--dm-line-paper); color: var(--dm-smoke); }
.dm-chip:hover { color: var(--dm-bone); border-color: var(--dm-line-strong); }
.dm-section--paper .dm-chip:hover,
body.dm.dm-paper .dm-chip:hover { color: var(--dm-ink); border-color: var(--dm-line-paper-strong); }
.dm-chip.is-active { background: var(--dm-volt); border-color: var(--dm-volt); color: var(--dm-ink); }

/* ── KPI / Stat ──────────────────────────────────────────── */
.dm-stat {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 24px 0;
  border-top: 1px solid var(--dm-line);
}
.dm-section--paper .dm-stat,
body.dm.dm-paper .dm-stat { border-top-color: var(--dm-line-paper); }
.dm-stat-num {
  font-family: var(--dm-display);
  font-size: var(--dm-step-6);
  line-height: 0.9;
  letter-spacing: -0.04em;
  font-variation-settings: var(--dm-fraunces-display);
}
.dm-stat-label { font-family: var(--dm-mono); font-size: var(--dm-step--2); letter-spacing: 0.12em; text-transform: uppercase; color: var(--dm-bone-dim); }
.dm-section--paper .dm-stat-label,
body.dm.dm-paper .dm-stat-label { color: var(--dm-smoke); }

/* ── Table ──────────────────────────────────────────────── */
.dm-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--dm-body);
  font-size: var(--dm-step--1);
}
.dm-table th, .dm-table td { text-align: left; padding: 18px 16px; border-bottom: 1px solid var(--dm-line); }
.dm-section--paper .dm-table th, .dm-section--paper .dm-table td,
body.dm.dm-paper .dm-table th, body.dm.dm-paper .dm-table td { border-bottom-color: var(--dm-line-paper); }
.dm-table th { font-family: var(--dm-mono); font-size: var(--dm-step--2); letter-spacing: 0.1em; text-transform: uppercase; color: var(--dm-bone-dim); font-weight: 500; }
.dm-section--paper .dm-table th,
body.dm.dm-paper .dm-table th { color: var(--dm-smoke); }
.dm-table tr:last-child td { border-bottom: 0; }

/* ── Modal / dialog ─────────────────────────────────────── */
.dm-modal {
  position: fixed;
  inset: 0;
  z-index: var(--dm-z-modal);
  background: rgba(10,10,11,0.78);
  backdrop-filter: blur(12px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--dm-gutter);
  opacity: 0;
  transition: opacity 0.3s var(--dm-ease);
}
.dm-modal.is-open { display: flex; opacity: 1; }
.dm-modal-content {
  background: var(--dm-ink-2);
  color: var(--dm-bone);
  width: 100%;
  max-width: 520px;
  padding: 40px;
  border: 1px solid var(--dm-line);
  border-radius: var(--dm-r-2);
  position: relative;
  transform: translateY(20px);
  transition: transform 0.4s var(--dm-ease-out);
}
.dm-modal.is-open .dm-modal-content { transform: none; }
.dm-modal-close {
  position: absolute;
  top: 16px; right: 16px;
  width: 32px; height: 32px;
  background: transparent;
  border: 0;
  cursor: pointer;
  color: var(--dm-bone-dim);
  font-size: 24px;
  line-height: 1;
}
.dm-modal-close:hover { color: var(--dm-bone); }

/* ── Toast ──────────────────────────────────────────────── */
.dm-toast {
  position: fixed;
  bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--dm-ink-3);
  color: var(--dm-bone);
  padding: 14px 22px;
  border-radius: var(--dm-r-pill);
  font-family: var(--dm-body);
  font-size: var(--dm-step--1);
  border: 1px solid var(--dm-line);
  opacity: 0;
  transition: opacity 0.3s var(--dm-ease), transform 0.4s var(--dm-ease-out);
  z-index: var(--dm-z-toast);
  pointer-events: none;
}
.dm-toast.is-show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ── Motion: reveal / line-reveal ────────────────────────── */
.dm-reveal {
  --delay: 0ms;
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.9s var(--dm-ease-out) var(--delay),
    transform 1.0s var(--dm-ease-out) var(--delay);
  will-change: opacity, transform;
}
.dm-reveal.is-in { opacity: 1; transform: none; }

.dm-reveal-line { display: block; overflow: hidden; position: relative; }
.dm-reveal-line > span {
  display: block;
  transform: translateY(110%);
  transition: transform 1.2s var(--dm-ease-out) var(--delay, 0ms);
  will-change: transform;
}
.is-in .dm-reveal-line > span, .dm-reveal-line.is-in > span { transform: translateY(0); }

.dm-scan {
  position: relative;
  overflow: hidden;
}
.dm-scan::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, var(--dm-volt) 40%, var(--dm-volt) 60%, transparent);
  transform: translateX(-100%);
  pointer-events: none;
}
.dm-scan.is-in::after { animation: dm-scan-sweep 1.8s var(--dm-ease-out) forwards; }
@keyframes dm-scan-sweep { to { transform: translateX(100%); } }

/* ── Hero ────────────────────────────────────────────────── */
.dm-hero {
  min-height: 100vh;
  padding-block: clamp(140px, 18vh, 220px) clamp(60px, 10vh, 120px);
  position: relative;
  overflow: hidden;
  display: grid;
  align-items: center;
}
.dm-hero--tall { min-height: 110vh; }
.dm-hero-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
  align-items: end;
  position: relative;
  z-index: 1;
}
.dm-hero-meta {
  grid-column: 1 / span 4;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.dm-hero-headline { grid-column: 1 / -1; margin-top: 32px; }
.dm-hero-foot {
  grid-column: 1 / -1;
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--dm-line);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: end;
}
.dm-section--paper .dm-hero-foot,
body.dm.dm-paper .dm-hero-foot { border-top-color: var(--dm-line-paper); }
.dm-hero-foot-meta { display: flex; gap: 32px; flex-wrap: wrap; color: var(--dm-bone-dim); }
.dm-section--paper .dm-hero-foot-meta,
body.dm.dm-paper .dm-hero-foot-meta { color: var(--dm-smoke); }
.dm-hero-foot-meta span strong {
  color: var(--dm-bone);
  font-weight: 500;
  display: block;
  font-family: var(--dm-display);
  font-size: var(--dm-step-1);
  margin-top: 4px;
}
.dm-section--paper .dm-hero-foot-meta span strong,
body.dm.dm-paper .dm-hero-foot-meta span strong { color: var(--dm-ink); }

.dm-orb {
  position: absolute;
  width: 520px; height: 520px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(6,199,85,0.20) 0%, rgba(6,199,85,0.05) 40%, transparent 70%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
  top: -200px; right: -200px;
  transition: transform 0.4s var(--dm-ease-out);
}

@media (max-width: 760px) {
  .dm-hero-meta { grid-column: 1 / -1; }
  .dm-hero-foot { grid-template-columns: 1fr; }
}

/* ── Footer ──────────────────────────────────────────────── */
.dm-foot {
  padding: 80px 0 60px;
  border-top: 1px solid var(--dm-line);
  background: var(--dm-ink);
  color: var(--dm-bone);
}
body.dm.dm-paper .dm-foot { background: var(--dm-paper); color: var(--dm-ink); border-top-color: var(--dm-line-paper); }
.dm-foot-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  align-items: start;
}
@media (max-width: 880px) {
  .dm-foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 540px) {
  .dm-foot-grid { grid-template-columns: 1fr; }
}
.dm-foot-sign {
  font-family: var(--dm-display);
  font-size: var(--dm-step-7);
  line-height: 0.9;
  letter-spacing: -0.04em;
  font-variation-settings: var(--dm-fraunces-display);
  margin: 0 0 16px;
}
.dm-foot-tag { color: var(--dm-bone-dim); max-width: 32ch; font-size: var(--dm-step--1); line-height: 1.5; }
body.dm.dm-paper .dm-foot-tag { color: var(--dm-smoke); }
.dm-foot-col-title {
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 18px;
  color: var(--dm-bone-dim);
}
body.dm.dm-paper .dm-foot-col-title { color: var(--dm-smoke); }
.dm-foot-links { display: flex; flex-direction: column; gap: 12px; }
.dm-foot-links a {
  font-family: var(--dm-body);
  font-size: var(--dm-step--1);
  color: var(--dm-bone);
  transition: color 0.3s var(--dm-ease);
  position: relative;
  display: inline-block;
}
body.dm.dm-paper .dm-foot-links a { color: var(--dm-ink); }
.dm-foot-links a:hover { color: var(--dm-volt); }
.dm-foot-bottom {
  margin-top: 64px;
  padding-top: 32px;
  border-top: 1px solid var(--dm-line);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dm-bone-dim);
}
body.dm.dm-paper .dm-foot-bottom { border-top-color: var(--dm-line-paper); color: var(--dm-smoke); }

/* ── Feature row (alternating editorial block) ──────────── */
.dm-feature {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
  align-items: center;
  padding-block: clamp(60px, 8vw, 120px);
  border-top: 1px solid var(--dm-line);
}
.dm-section--paper .dm-feature,
body.dm.dm-paper .dm-feature { border-top-color: var(--dm-line-paper); }
.dm-feature:first-child { border-top: 0; }
.dm-feature-copy { grid-column: 1 / span 5; }
.dm-feature-visual { grid-column: 7 / span 6; }
.dm-feature--reverse .dm-feature-copy { grid-column: 8 / span 5; order: 2; }
.dm-feature--reverse .dm-feature-visual { grid-column: 1 / span 6; order: 1; }
.dm-feature-num {
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dm-bone-dim);
  margin-bottom: 24px;
}
.dm-section--paper .dm-feature-num,
body.dm.dm-paper .dm-feature-num { color: var(--dm-smoke); }
@media (max-width: 880px) {
  .dm-feature-copy, .dm-feature-visual,
  .dm-feature--reverse .dm-feature-copy, .dm-feature--reverse .dm-feature-visual { grid-column: 1 / -1; order: initial; }
}

/* ── Price card ──────────────────────────────────────────── */
.dm-price-card {
  display: flex;
  flex-direction: column;
  padding: 32px;
  background: var(--dm-ink-2);
  border: 1px solid var(--dm-line);
  border-radius: var(--dm-r-2);
  position: relative;
  transition: border-color 0.4s var(--dm-ease), transform 0.4s var(--dm-ease-out);
  min-height: 480px;
}
.dm-price-card:hover { border-color: var(--dm-line-strong); transform: translateY(-3px); }
.dm-price-card--featured { background: var(--dm-paper); color: var(--dm-ink); border-color: transparent; }
.dm-price-card--featured:hover { border-color: var(--dm-volt); }
.dm-price-card--ink { background: var(--dm-ink); border-color: var(--dm-line); }
.dm-price-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 32px; }
.dm-price-card-name {
  font-family: var(--dm-display);
  font-weight: 500;
  font-size: var(--dm-step-2);
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 24;
}
.dm-price-card-amt {
  font-family: var(--dm-display);
  font-size: var(--dm-step-7);
  line-height: 0.9;
  letter-spacing: -0.04em;
  font-variation-settings: var(--dm-fraunces-display);
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 8px;
}
.dm-price-card-amt small {
  font-family: var(--dm-mono);
  font-size: var(--dm-step--1);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 400;
  color: var(--dm-bone-dim);
}
.dm-price-card--featured .dm-price-card-amt small { color: var(--dm-smoke); }
.dm-price-card-desc { color: var(--dm-bone-dim); font-size: var(--dm-step--1); line-height: 1.55; margin-bottom: 24px; }
.dm-price-card--featured .dm-price-card-desc { color: var(--dm-smoke); }
.dm-price-card-feats { list-style: none; margin: 0 0 32px; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.dm-price-card-feats li { display: flex; gap: 10px; font-size: var(--dm-step--1); line-height: 1.4; }
.dm-price-card-feats li::before {
  content: "→";
  color: var(--dm-volt);
  font-family: var(--dm-mono);
  flex-shrink: 0;
}
.dm-price-card-foot { margin-top: auto; }

/* ── Utility ─────────────────────────────────────────────── */
.dm-only-mobile { display: none; }
.dm-only-desktop { display: block; }
@media (max-width: 760px) {
  .dm-only-mobile { display: block; }
  .dm-only-desktop { display: none; }
}
.dm-flex { display: flex; }
.dm-flex-wrap { display: flex; flex-wrap: wrap; }
.dm-flex-col { display: flex; flex-direction: column; }
.dm-gap-1 { gap: 8px; }
.dm-gap-2 { gap: 16px; }
.dm-gap-3 { gap: 24px; }
.dm-gap-4 { gap: 32px; }
.dm-center { text-align: center; }
.dm-mt-0 { margin-top: 0; }
.dm-mt-1 { margin-top: 8px; }
.dm-mt-2 { margin-top: 16px; }
.dm-mt-3 { margin-top: 24px; }
.dm-mt-4 { margin-top: 32px; }
.dm-mt-5 { margin-top: 48px; }
.dm-mt-6 { margin-top: 64px; }
.dm-mb-0 { margin-bottom: 0; }
.dm-mb-1 { margin-bottom: 8px; }
.dm-mb-2 { margin-bottom: 16px; }
.dm-mb-3 { margin-bottom: 24px; }
.dm-mb-4 { margin-bottom: 32px; }
.dm-mb-5 { margin-bottom: 48px; }
.dm-mb-6 { margin-bottom: 64px; }

/* ── Legacy retheme — overrides for old prefixed classes ── */
/* So pages keep their JS-required class names but inherit the new look */

body.dm .lp-nav,
body.dm .sp-nav,
body.dm .bp-nav,
body.dm .top-bar {
  background: rgba(10,10,11,0.65) !important;
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-bottom: 1px solid transparent;
  color: var(--dm-bone);
}
body.dm.dm-paper .lp-nav,
body.dm.dm-paper .sp-nav,
body.dm.dm-paper .bp-nav,
body.dm.dm-paper .top-bar {
  background: rgba(244,240,232,0.78) !important;
}

body.dm .btn:not(.dm-btn) {
  font-family: var(--dm-body);
  font-weight: 500;
  letter-spacing: -0.01em;
  border-radius: var(--dm-r-pill);
}

/* For pages that still reference the existing primary plan card */
body.dm .plan-card,
body.dm .pricing-card { font-family: var(--dm-body); }
body.dm .plan-name,
body.dm .pricing-name { font-family: var(--dm-display); font-variation-settings: "opsz" 24; }
body.dm .plan-price,
body.dm .pricing-price { font-family: var(--dm-display); font-variation-settings: var(--dm-fraunces-display); letter-spacing: -0.04em; }

/* Toast retheme */
body.dm .toast-container,
body.dm .toast-message {
  font-family: var(--dm-body);
}

/* ── Closer (large italic quote at section end) ─────────── */
.dm-closer { padding-block: clamp(120px, 18vw, 240px); }
.dm-closer-text {
  font-family: var(--dm-display-italic);
  font-style: italic;
  font-weight: 400;
  font-size: var(--dm-step-7);
  line-height: 1.0;
  letter-spacing: -0.03em;
  font-variation-settings: normal;
  max-width: 18ch;
  margin: 0;
}
.dm-closer-cite {
  margin-top: 36px;
  font-family: var(--dm-mono);
  font-size: var(--dm-step--2);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dm-bone-dim);
}
.dm-section--paper .dm-closer-cite,
body.dm.dm-paper .dm-closer-cite { color: var(--dm-smoke); }

/* ============================================================
   DM v4 — global fixes
   1. Override legacy style-system.css rule that colors em volt
      inside section h1 (line 2184): `section h1 em { color: var(--brand-pri) !important; }`
   2. Defensive italic-leak guard: force normal style on chrome
      elements that should never appear italic (buttons, badges, pills, chips, nav links, inputs).
   ============================================================ */

/* 1. Re-bone all em inside display headlines — beats `section h1 em { color: ... !important }` from legacy */
body.dm section h1 em,
body.dm section h1 strong,
body.dm section h2 em,
body.dm section h2 strong,
body.dm .dm-display em,
body.dm .dm-headline em,
body.dm .dm-title em,
body.dm .dm-subtitle em,
body.dm .dm-pullquote em,
body.dm .dm-closer-text em,
body.dm h1 em,
body.dm h2 em,
body.dm h3 em {
  color: inherit !important;
  font-family: var(--dm-display-italic) !important;
  font-style: italic !important;
  font-variation-settings: normal !important;
  font-synthesis: none !important;
}
body.dm.dm-paper section h1 em,
body.dm.dm-paper section h1 strong,
body.dm.dm-paper section h2 em,
body.dm.dm-paper section h2 strong,
body.dm.dm-paper h1 em,
body.dm.dm-paper h2 em { color: inherit !important; }

/* 2. Italic-leak guard for all chrome — prevent Newsreader italic axis
      from rendering on buttons/badges/inputs at rest. They should always
      be upright in the body font. */
body.dm .dm-btn,
body.dm .dm-btn-arrow,
body.dm .dm-nav-link,
body.dm .dm-logo,
body.dm .dm-badge,
body.dm .dm-chip,
body.dm .dm-input,
body.dm .dm-input-label,
body.dm .dm-textarea,
body.dm .dm-select,
body.dm .dm-cap,
body.dm .dm-eyebrow,
body.dm .dm-chapter,
body.dm .dm-foot-col-title,
body.dm .dm-foot-bottom,
body.dm .dm-foot-links a,
body.dm button:not(.dm-display):not([class*="display"]):not([class*="italic"]),
body.dm input,
body.dm select,
body.dm textarea {
  font-style: normal !important;
  font-variation-settings: normal !important;
  font-synthesis: none !important;
}

/* ============================================================
   DM v5 — chrome rendering reset
   Kills colored glow shadows + stray transforms on rest state
   of pills/buttons across the site. The combination of asymmetric
   box-shadow (only bottom glow) + thin border on transparent fill
   creates the visual illusion of a tilted box. This neutralizes it.
   ============================================================ */
body.dm .btn-canvas-mini,
body.dm .btn-canvas-pro,
body.dm .user-pill,
body.dm .brand-chip,
body.dm .v12-badge,
body.dm .compact-card,
body.dm .kpi-card,
body.dm .campaign-card,
body.dm .funnel-row,
body.dm .type-tab,
body.dm .type-select-card,
body.dm .row-btn,
body.dm .action-btn,
body.dm .tool-btn,
body.dm .epg-cta,
body.dm .epg-step,
body.dm .btn-add-brand,
body.dm .switch-btn,
body.dm .ai-fab,
body.dm .btn-tour,
body.dm .btn-help,
body.dm .filter-btn,
body.dm .badge,
body.dm .suspended-badge,
body.dm #btn-new-project,
body.dm #btn-canvas-pro {
  box-shadow: none !important;
  filter: none !important;
  -webkit-filter: none !important;
  will-change: auto !important;
  transform: none;
  transition-property: background-color, color, border-color, opacity, transform !important;
}
/* Hover allowance for translateY (subtle lift), still no skew/rotate */
body.dm .btn-canvas-mini:hover,
body.dm .compact-card:hover,
body.dm .kpi-card:hover,
body.dm .campaign-card:hover,
body.dm #btn-new-project:hover,
body.dm #btn-canvas-pro:hover {
  transform: translateY(-1px) !important;
  box-shadow: none !important;
  filter: none !important;
}

/* ============================================================
   DM v6 — sub-pixel pill rendering fix
   On Retina (DPR 2), pills with 1px border + 999px radius + flex-content
   widths that fall on fractional pixel positions appear as
   parallelograms due to Chrome's anti-aliasing distributing the
   top vs bottom edge to different pixel rows.

   Fix: force GPU compositing (translateZ snaps to whole pixels)
   AND replace 1px border with 1px outline (outline lives outside
   layout and rasterizes from element bounds, not via flex math).
   ============================================================ */
body.dm .action-btn,
body.dm .btn-canvas-mini,
body.dm .user-pill,
body.dm .brand-chip,
body.dm .tag-chip,
body.dm .filter-btn,
body.dm .days-chip,
body.dm .badge,
body.dm .compact-card .card-type-tag,
body.dm .subnav-pill,
body.dm .type-tab,
body.dm .switch-btn,
body.dm .btn-add-brand,
body.dm .v12-badge {
  transform: translateZ(0) !important;
  backface-visibility: hidden !important;
  -webkit-backface-visibility: hidden !important;
  border: 1px solid transparent !important;
  outline: 1px solid var(--dm-line-strong) !important;
  outline-offset: -1px !important;
}

body.dm .action-btn:hover,
body.dm .btn-canvas-mini:hover,
body.dm .user-pill:hover,
body.dm .brand-chip:hover {
  outline-color: var(--dm-bone) !important;
  border-color: transparent !important;
  transform: translateZ(0) translateY(-1px) !important;
}

/* Volt-bordered variants (e.g. copy/active/featured pills) */
body.dm .action-btn[data-action="copy"],
body.dm .action-btn.is-volt,
body.dm .compact-card .tag-chip.is-active,
body.dm .filter-btn.is-active,
body.dm .type-tab.active {
  outline-color: var(--dm-volt) !important;
  border-color: transparent !important;
}

/* Solid bone/volt fills — disable the outline trick (they don't need it) */
body.dm .dm-btn--primary,
body.dm .dm-btn--volt,
body.dm #btn-new-project,
body.dm .btn-publish,
body.dm .btn-primary {
  outline: 0 !important;
  border: 0 !important;
}

/* ============================================================
   DM v8 — Editorial enforcement layer (backoffice + cross-page).
   This block is the loudest in the cascade on purpose: previous
   overlays lost specificity fights against inline styles and
   legacy chrome stylesheets. Three goals:
     1) Force Newsreader on display headings.
     2) Strip Inter / Arial out everywhere, fall back to DM Sans.
     3) Tame volt usage to accents only (not big fills).
   Only activates when <body class="dm"> is present.
   ============================================================ */

/* 1. Display family on h1–h3 and named display surfaces */
body.dm h1,
body.dm h2,
body.dm h3,
body.dm .page-hero h1,
body.dm .bd-page-hero,
body.dm .bd-page-hero h1,
body.dm .page-hero-title,
body.dm .admin-stat-value,
body.dm .stat-value,
body.dm .kpi-value,
body.dm .dm-display,
body.dm .dm-headline,
body.dm .dm-title,
body.dm .dm-pullquote,
body.dm .dm-closer-text,
body.dm [class*="-headline"]:not(.dm-mono):not([class*="mono"]),
body.dm [class*="-display"]:not(.dm-mono):not([class*="mono"]) {
  font-family: var(--dm-display), 'Noto Serif TC', Georgia, serif !important;
  font-variation-settings: var(--dm-fraunces-headline) !important;
  font-style: normal !important;
}

/* 2. Body default — DM Sans on everything else.
   Exclude SVG primitives (which honour their own font-family attr). */
body.dm,
body.dm *:not(svg):not(path):not(circle):not(rect):not(line):not(polyline):not(polygon):not(text):not(tspan):not(g):not(use):not(defs):not(symbol):not(mask):not(clipPath):not(linearGradient):not(radialGradient):not(stop):not(filter):not(feGaussianBlur):not(feMerge):not(feMergeNode) {
  font-family: var(--dm-body), 'Noto Sans TC', sans-serif;
}

/* 3. Restore mono where intended — labels / caps / chrome / code */
body.dm .dm-cap,
body.dm .dm-eyebrow,
body.dm .dm-mono,
body.dm [class*="-mono"],
body.dm [class*="mono-"],
body.dm code,
body.dm pre,
body.dm kbd,
body.dm samp,
body.dm .badge,
body.dm .filter-btn,
body.dm .v12-badge,
body.dm .nav-section-label,
body.dm .stat-label,
body.dm .kpi-label,
body.dm [class*="-label"]:not([class*="form-label"]):not([class*="-label-"]) {
  font-family: var(--dm-mono), ui-monospace, 'SF Mono', Menlo, monospace !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
}

/* 4. Inline-style guard — kill Inter / Arial pinned via style="…"  */
body.dm [style*="font-family:Inter"],
body.dm [style*="font-family: Inter"],
body.dm [style*="font-family:'Inter"],
body.dm [style*="font-family: 'Inter"],
body.dm [style*="font-family:\"Inter"],
body.dm [style*="font-family: \"Inter"],
body.dm [style*="font-family:Arial"],
body.dm [style*="font-family: Arial"],
body.dm [style*="font-family:'Arial"],
body.dm [style*="font-family: 'Arial"] {
  font-family: var(--dm-body), 'Noto Sans TC', sans-serif !important;
}

/* 5. Editorial CTA discipline — primary buttons across all marketing.
   Bone fill + ink text + volt wipe on hover. NEVER solid volt. */
body.dm .dm-btn--primary,
body.dm a.dm-btn--primary,
body.dm button.dm-btn--primary,
body.dm .lp-nav-cta {
  background: var(--dm-bone) !important;
  color: var(--dm-ink) !important;
  font-family: var(--dm-body) !important;
  font-weight: 500 !important;
  border: 0 !important;
  border-radius: 999px !important;
  position: relative !important;
  overflow: hidden !important;
  isolation: isolate !important;
  letter-spacing: -0.01em !important;
}
body.dm .dm-btn--primary::before,
body.dm a.dm-btn--primary::before,
body.dm button.dm-btn--primary::before,
body.dm .lp-nav-cta::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: var(--dm-volt) !important;
  transform: translateX(-101%);
  transition: transform 0.5s var(--dm-ease-out);
  z-index: -1 !important;
}
body.dm .dm-btn--primary:hover::before,
body.dm a.dm-btn--primary:hover::before,
body.dm button.dm-btn--primary:hover::before,
body.dm .lp-nav-cta:hover::before {
  transform: translateX(0) !important;
}
body.dm .dm-btn--primary:hover,
body.dm a.dm-btn--primary:hover,
body.dm button.dm-btn--primary:hover,
body.dm .lp-nav-cta:hover {
  color: var(--dm-ink) !important;
}

/* 5b. Section H2 — keep bone color. Specific volt accents should live
       on inline <em>/<span> tokens, not whole headings. */
body.dm h2,
body.dm .lp-section-title {
  color: var(--dm-bone) !important;
}
/* Volt-tinted inline highlight inside headings stays volt */
body.dm h2 em,
body.dm h2 .dm-volt,
body.dm .lp-section-title em,
body.dm .lp-section-title .dm-volt {
  color: var(--dm-volt) !important;
  -webkit-text-fill-color: var(--dm-volt) !important;
  background: none !important;
  -webkit-background-clip: initial !important;
          background-clip: initial !important;
}

/* 6. The "已登入…主控台→" pill — restyle to bone, hide on marketing.
      Banner is created inline in login.html with cssText (very high
      specificity from inline style attr). We need !important on every
      property to win. */
body.dm #_loginBanner {
  background: var(--dm-bone) !important;
  color: var(--dm-ink) !important;
  font-family: var(--dm-mono), ui-monospace, monospace !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  font-size: 10px !important;
  padding: 8px 14px !important;
  border-radius: 999px !important;
  position: fixed !important;
  bottom: 16px !important;
  right: 16px !important;
  top: auto !important;
  left: auto !important;
  z-index: 60 !important;
  box-shadow: none !important;
  border: 1px solid var(--dm-line-paper-strong) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  max-width: calc(100vw - 32px) !important;
  animation: none !important;
}
body.dm #_loginBanner * {
  color: var(--dm-ink) !important;
  font-family: inherit !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  font-weight: 500 !important;
}
body.dm #_loginBanner a,
body.dm #_loginBanner #_logoutLink {
  color: var(--dm-ink) !important;
  text-decoration: underline !important;
  text-decoration-color: var(--dm-volt) !important;
  text-decoration-thickness: 1px !important;
  text-underline-offset: 3px !important;
  padding: 4px 8px !important;
  border-radius: 0 !important;
}
body.dm #_loginBanner > div > div:first-child { border-right: 0 !important; padding-right: 0 !important; }
body.dm #_loginBanner div[style*="background:#06C755"],
body.dm #_loginBanner div[style*="background: #06C755"] {
  background: var(--dm-volt) !important;
  box-shadow: 0 0 0 2px rgba(6,199,85,0.18) !important;
}
body.dm #_loginBanner strong { font-family: var(--dm-body) !important; letter-spacing: 0 !important; text-transform: none !important; font-size: 11px !important; }
body.dm #_loginBanner span[style*="rgba(237,234,226,0.5)"] { color: var(--dm-smoke) !important; }

/* Hide on marketing routes (body class set by dm-motion.js initLoginBannerScope) */
body.dm.dm-marketing-route #_loginBanner { display: none !important; }

/* 8. Backoffice editorial polish — collapse stat values that wrap.
      Audit pointed out NT$20,000 wrapping in admin. Add tabular-nums
      + nowrap + sane min-width on common stat slots. */
body.dm .admin-stat-value,
body.dm .stat-value,
body.dm .kpi-value,
body.dm .bd-stat-value {
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1 !important;
  white-space: nowrap !important;
}

/* 9. Force-restore editorial body color on backoffice dark surfaces
      that legacy CSS painted white via #fff. */
body.dm .al-logo,
body.dm .dashboard-greeting,
body.dm .top-bar .greeting {
  color: var(--dm-bone) !important;
}

/* 11. Kill the intentional -1deg rotation on type badges
       (style-system.css:3267 sets `:where(.card-type-badge,...) transform: rotate(-1deg)`).
       Editorial design wants axis-aligned chrome — no skew. */
body.dm .card-type-badge,
body.dm .type-quiz,
body.dm .type-flex,
body.dm .type-menu,
body.dm .ent-badge,
body.dm .badge.card-type-badge {
  transform: none !important;
  transition: transform 0.3s var(--dm-ease) !important;
}
body.dm .card-type-badge:hover,
body.dm .type-quiz:hover,
body.dm .type-flex:hover,
body.dm .type-menu:hover { transform: none !important; }

/* 10. Logo wordmark — force the ORIGINAL Inter-based brand logo
       across every page. The v8 enforcement layer above forces DM Sans
       on most elements, but the user wants the brand logo to keep its
       original look: Inter, 800 weight, 0.5px tracking, uppercase.
       This rule has higher specificity than v8 so it wins. */
body.dm .brand-logo-name,
body.dm .lp-nav-logo-name,
body.dm .sp-nav-logo-name,
body.dm .bp-nav-logo-name,
body.dm .form-brand-name,
body.dm .al-logo-name,
body.dm .nav-logo-name {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  font-weight: 800 !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  font-style: normal !important;
  color: #FFFFFF !important;
}

/* 手機版 nav 收合修正:.dm-nav-links 被 JS 注入 inline style="display:flex",
   壓過原本 @media 的 display:none → 手機上連結與漢堡並存。用 !important
   讓收合贏過 inline;.is-open(點漢堡後 JS 加)再以 !important 重新展開。 */
@media (max-width: 880px) {
  .dm-nav-links { display: none !important; }
  .dm-nav-links.is-open { display: flex !important; }
  #lp-hamburger.dm-nav-burger,
  .dm-nav-burger { display: inline-flex !important; }
  /* 頂列「登入 / 免費申請」也帶 inline display:flex,手機應收進漢堡抽屜
     (#lp-mobile-menu 已含登入 + 免費試用 CTA)。!important 打敗 inline。 */
  .lp-nav-actions { display: none !important; }
}


/* ════════════════════════════════════════════════════════════════════
   SHARED PRIMITIVES — admin + Studio + (future) public-site overlays
   ────────────────────────────────────────────────────────────────────
   These are the cross-surface UI atoms. Studio + admin opt-in by using
   the `.dm-*` class. Existing admin classes (.sc-btn / .bd-btn / .ent-btn
   etc.) are NOT touched — those keep their current behaviour. New code
   should reach for these instead so the design language converges over
   time. (B4 / B8 / B13 in 2026-05-22 alignment audit.)
   ════════════════════════════════════════════════════════════════════ */

/* ── DM Toast — single visual language for transient feedback ────── */
.dm-toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9000;
  max-width: 360px;
  padding: 12px 16px;
  background: var(--dm-bone);
  color: var(--dm-ink);
  font-family: var(--dm-mono), ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.06em;
  line-height: 1.5;
  border-radius: 2px;
  box-shadow: var(--dm-shadow-lg);
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity 0.25s var(--dm-ease-out), transform 0.25s var(--dm-ease-out);
}
.dm-toast::before { content: "§ "; color: var(--dm-volt); font-weight: 600; }
.dm-toast--show { opacity: 1; transform: translateY(0); }
.dm-toast--warn { background: var(--dm-warn); color: var(--dm-ink); }
.dm-toast--error { background: var(--dm-danger); color: var(--dm-bone); }

/* ── DM Button — canonical pill primary / ghost ─────────────────── */
.dm-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 24px;
  font-family: var(--dm-mono), ui-monospace, monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: var(--dm-r-pill);
  border: 0;
  cursor: pointer;
  isolation: isolate;
  overflow: hidden;
  transition: color 0.3s var(--dm-ease-out), border-color 0.3s var(--dm-ease-out), opacity 0.2s;
}
.dm-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.dm-btn--primary {
  background: var(--dm-bone);
  color: var(--dm-ink) !important;
  box-shadow: inset 0 0 0 1px var(--dm-bone);
}
.dm-btn--primary::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--dm-volt);
  transform: translateX(-101%);
  transition: transform 0.4s var(--dm-ease-out);
  z-index: -1;
}
.dm-btn--primary:hover::before { transform: translateX(0); }
.dm-btn--primary:hover { color: var(--dm-ink) !important; box-shadow: inset 0 0 0 1px var(--dm-volt); }
.dm-btn--ghost {
  background: transparent;
  color: var(--dm-bone);
  box-shadow: inset 0 0 0 1px var(--dm-line-strong);
}
.dm-btn--ghost:hover { color: var(--dm-bone); box-shadow: inset 0 0 0 1px var(--dm-bone); }
.dm-btn--danger { background: var(--dm-danger); color: var(--dm-bone) !important; }
.dm-btn--danger:hover { background: var(--dm-danger); filter: brightness(1.08); }

/* Light theme button variants (paper background) */
body.dm.dm-paper .dm-btn--primary,
body.studio--light .dm-btn--primary {
  background: var(--dm-ink);
  color: var(--dm-paper) !important;
  box-shadow: inset 0 0 0 1px var(--dm-ink);
}
body.dm.dm-paper .dm-btn--ghost,
body.studio--light .dm-btn--ghost {
  color: var(--dm-ink);
  box-shadow: inset 0 0 0 1px var(--dm-line-paper-strong);
}
body.dm.dm-paper .dm-btn--ghost:hover,
body.studio--light .dm-btn--ghost:hover {
  color: var(--dm-ink);
  box-shadow: inset 0 0 0 1px var(--dm-ink);
}

/* ── DM Modal — canonical backdrop + panel ───────────────────────── */
.dm-modal {
  position: fixed; inset: 0; z-index: var(--dm-z-modal, 80);
  display: flex; align-items: center; justify-content: center;
}
.dm-modal[hidden] { display: none !important; }
.dm-modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.dm-modal__panel {
  position: relative;
  background: var(--dm-ink-2);
  color: var(--dm-bone);
  width: min(480px, 92vw);
  padding: 28px 32px 24px;
  border-radius: 4px;
  box-shadow: var(--dm-shadow-lg);
}
body.dm.dm-paper .dm-modal__panel,
body.studio--light .dm-modal__panel {
  background: var(--dm-paper);
  color: var(--dm-ink);
}
.dm-modal__eyebrow {
  font-family: var(--dm-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dm-volt);
  margin-bottom: 8px;
}
.dm-modal__title {
  font-family: var(--dm-display);
  font-weight: 400;
  font-size: 22px;
  letter-spacing: -0.01em;
  margin: 0 0 12px;
}
.dm-modal__body { font-size: 14px; line-height: 1.6; color: var(--dm-bone-dim); margin-bottom: 22px; }
body.dm.dm-paper .dm-modal__body,
body.studio--light .dm-modal__body { color: rgba(10, 10, 11, 0.78); }
.dm-modal__actions { display: flex; gap: 10px; justify-content: flex-end; }
