/* ===========================================================================
   HuaMed · Stage 9 · Design Tokens
   --------------------------------------------------------------------------
   Single source of truth for color, type, spacing, radii, shadow, motion.
   This file MUST be loaded BEFORE src/styles.css in every entry HTML.
   See VI.md for the spec these tokens encode.
   ========================================================================= */

:root {
  /* ====== Color · brand palette (matches tailwind.config) ============== */
  --hm-gold-50:   #FBF6E4;
  --hm-gold-100:  #F4E9BE;
  --hm-gold-200:  #E9D37D;
  --hm-gold-300:  #DFC355;
  --hm-gold-400:  #D4AF37;
  --hm-gold-500:  #B9962A;
  --hm-gold-600:  #8C7020;
  --hm-gold-700:  #5F4C15;

  --hm-sea-50:    #E9EEEE;
  --hm-sea-100:   #C7D2D2;
  --hm-sea-200:   #8FA5A5;
  --hm-sea-300:   #577878;
  --hm-sea-400:   #2F4F4F;
  --hm-sea-500:   #263F3F;
  --hm-sea-600:   #1C2F2F;
  --hm-sea-700:   #121E1E;

  --hm-marble-50:  #FDFCF8;
  --hm-marble-100: #F9F7F2;
  --hm-marble-200: #F1ECE1;
  --hm-marble-300: #E6DFCF;
  --hm-marble-400: #C9BFA6;
  --hm-marble-500: #9A8F75;

  /* ====== Color · semantic =========================================== */
  --hm-accent:        var(--hm-gold-400);
  --hm-accent-soft:   var(--hm-gold-100);
  --hm-accent-ink:    var(--hm-gold-700);
  --hm-accent-deep:   var(--hm-gold-500);

  --hm-ink:           var(--hm-sea-500);
  --hm-ink-soft:      var(--hm-sea-300);
  --hm-ink-mute:      var(--hm-marble-500);
  --hm-ink-onDark:    var(--hm-marble-100);

  --hm-paper:         #FFFFFF;
  --hm-bone:          var(--hm-marble-50);
  --hm-bone-soft:     var(--hm-marble-100);
  --hm-deep:          var(--hm-sea-600);
  --hm-deep-strong:   var(--hm-sea-700);

  --hm-line:          rgba(28, 47, 47, 0.08);
  --hm-line-strong:   rgba(28, 47, 47, 0.16);
  --hm-line-gold:     rgba(212, 175, 55, 0.42);
  --hm-line-onDark:   rgba(244, 233, 190, 0.18);

  --hm-success-bg:    #ECFDF5;
  --hm-success-ink:   #065F46;
  --hm-warning-bg:    #FEF3C7;
  --hm-warning-ink:   #92400E;
  --hm-error-bg:      #FFF1F2;
  --hm-error-ink:     #9F1239;

  /* ====== Type · families ============================================= */
  --hm-font-display:  "Cormorant Garamond", Georgia, serif;
  --hm-font-zh:       "Noto Serif SC", "Songti SC", serif;
  --hm-font-sans:     Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --hm-font-mono:     "JetBrains Mono", ui-monospace, monospace;

  /* ====== Type · scale (desktop, mobile via @media below) ============ */
  --hm-text-display-1: 54px;
  --hm-text-display-2: 44px;
  --hm-text-h1:        38px;
  --hm-text-h2:        32px;
  --hm-text-h3:        22px;
  --hm-text-body-lg:   16px;
  --hm-text-body:      14px;
  --hm-text-caption:   12px;
  --hm-text-eyebrow:   11px;

  --hm-lh-tight:    1.06;
  --hm-lh-snug:     1.15;
  --hm-lh-normal:   1.5;
  --hm-lh-relaxed:  1.65;

  --hm-track-display: -0.022em;
  --hm-track-tight:   -0.015em;
  --hm-track-normal:  -0.005em;
  --hm-track-wide:    0.22em;     /* eyebrows */

  /* ====== Spacing scale ============================================= */
  --hm-sp-1:  4px;
  --hm-sp-2:  8px;
  --hm-sp-3:  12px;
  --hm-sp-4:  16px;
  --hm-sp-5:  24px;
  --hm-sp-6:  32px;
  --hm-sp-7:  48px;
  --hm-sp-8:  64px;
  --hm-sp-9:  96px;
  --hm-sp-10: 120px;

  --hm-content-max:    1200px;
  --hm-content-px:     clamp(20px, 4vw, 56px);
  --hm-text-max:       640px;

  /* ====== Radii ===================================================== */
  --hm-radius-pill: 999px;
  --hm-radius-sm:   10px;
  --hm-radius-md:   14px;
  --hm-radius-lg:   20px;
  --hm-radius-xl:   24px;
  --hm-radius-2xl:  32px;

  /* ====== Shadow ==================================================== */
  --hm-shadow-soft: 0 1px 2px rgba(47,79,79,0.04), 0 8px 24px -12px rgba(47,79,79,0.12);
  --hm-shadow-lift: 0 2px 4px rgba(47,79,79,0.06), 0 16px 40px -16px rgba(47,79,79,0.18);
  --hm-shadow-deep: 0 4px 10px rgba(47,79,79,0.08), 0 30px 60px -24px rgba(47,79,79,0.22);
  --hm-shadow-gold: 0 14px 32px -14px rgba(212,175,55,0.55);

  /* ====== Motion ==================================================== */
  --hm-easing:    cubic-bezier(0.2, 0.7, 0.2, 1);
  --hm-dur-fast:  160ms;
  --hm-dur:       240ms;
  --hm-dur-slow:  420ms;
}

/* ====== Mobile overrides ============================================= */
@media (max-width: 760px) {
  :root {
    --hm-text-display-1: 32px;
    --hm-text-display-2: 30px;
    --hm-text-h1:        28px;
    --hm-text-h2:        24px;
    --hm-text-h3:        19px;
    --hm-text-body-lg:   15px;
    --hm-text-body:      13.5px;
    --hm-text-caption:   11.5px;
    --hm-text-eyebrow:   10.5px;
  }
}

/* ===========================================================================
   Utility classes — opt-in. Components in components.jsx can use either these
   or Tailwind utilities; both reach the same values.
   ========================================================================= */

/* ----- Typography ----- */
.hm-display-1 {
  font-family: var(--hm-font-display);
  font-size: var(--hm-text-display-1);
  line-height: var(--hm-lh-tight);
  letter-spacing: var(--hm-track-display);
  font-weight: 600;
  text-wrap: balance;
}
.hm-display-1[lang="zh"], .hm-display-1.is-zh { font-family: var(--hm-font-zh); }

.hm-display-2 {
  font-family: var(--hm-font-display);
  font-size: var(--hm-text-display-2);
  line-height: var(--hm-lh-snug);
  letter-spacing: -0.020em;
  font-weight: 600;
  text-wrap: balance;
}
.hm-display-2.is-zh { font-family: var(--hm-font-zh); }

.hm-h1 {
  font-family: var(--hm-font-display);
  font-size: var(--hm-text-h1);
  line-height: var(--hm-lh-snug);
  letter-spacing: var(--hm-track-tight);
  font-weight: 600;
  text-wrap: balance;
}
.hm-h1.is-zh { font-family: var(--hm-font-zh); }

.hm-h2 {
  font-family: var(--hm-font-display);
  font-size: var(--hm-text-h2);
  line-height: 1.20;
  letter-spacing: -0.010em;
  font-weight: 600;
  text-wrap: balance;
}
.hm-h2.is-zh { font-family: var(--hm-font-zh); }

.hm-h3 {
  font-family: var(--hm-font-display);
  font-size: var(--hm-text-h3);
  line-height: 1.25;
  letter-spacing: var(--hm-track-normal);
  font-weight: 600;
}
.hm-h3.is-zh { font-family: var(--hm-font-zh); }

.hm-body-lg {
  font-family: var(--hm-font-sans);
  font-size: var(--hm-text-body-lg);
  line-height: var(--hm-lh-relaxed);
  color: var(--hm-ink-soft);
  text-wrap: pretty;
}

.hm-body {
  font-family: var(--hm-font-sans);
  font-size: var(--hm-text-body);
  line-height: var(--hm-lh-relaxed);
  color: var(--hm-ink-soft);
  text-wrap: pretty;
}

.hm-caption {
  font-family: var(--hm-font-sans);
  font-size: var(--hm-text-caption);
  color: var(--hm-ink-mute);
  line-height: 1.5;
}

.hm-eyebrow {
  font-family: var(--hm-font-mono);
  font-size: var(--hm-text-eyebrow);
  font-weight: 700;
  letter-spacing: var(--hm-track-wide);
  text-transform: uppercase;
  color: var(--hm-gold-600);
}

.hm-eyebrow-row {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

.hm-eyebrow-line {
  display: block;
  width: 28px;
  height: 1px;
  background: linear-gradient(90deg, var(--hm-gold-400), rgba(212,175,55,0.18));
}

@media (max-width: 640px) {
  .hm-eyebrow-line { width: 20px; }
  .hm-eyebrow-row  { margin-bottom: 10px; }
}

/* ----- Buttons (.hm-btn) ----- */
.hm-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 44px;
  padding: 0 20px;
  border-radius: 16px;
  font-family: var(--hm-font-sans);
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: 0.005em;
  border: 1px solid transparent;
  transition: transform var(--hm-dur) var(--hm-easing),
              box-shadow var(--hm-dur) var(--hm-easing),
              background var(--hm-dur) var(--hm-easing),
              background-position var(--hm-dur) var(--hm-easing),
              color var(--hm-dur) var(--hm-easing),
              border-color var(--hm-dur) var(--hm-easing);
  white-space: nowrap;
  cursor: pointer;
}
.hm-btn:disabled, .hm-btn[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.5;
  filter: saturate(0.4);
}
.hm-btn:not(:disabled):hover { transform: translateY(-1px); }
.hm-btn:not(:disabled):active { transform: translateY(0); }

.hm-btn--sm { height: 36px; padding: 0 14px; font-size: 12.5px; }
.hm-btn--lg { height: 52px; padding: 0 26px; font-size: 14.5px; }

.hm-btn--primary {
  background: linear-gradient(135deg, #F0DC8A 0%, #D4AF37 52%, #A8851F 100%);
  background-size: 200% 200%;
  background-position: 0% 0%;
  color: var(--hm-sea-500);
  border-color: rgba(140, 112, 32, 0.20);
  box-shadow: 0 1px 2px rgba(47,79,79,0.06), 0 14px 32px -14px rgba(212,175,55,0.55);
}
.hm-btn--primary:not(:disabled):hover {
  background-position: 100% 100%;
  box-shadow: 0 2px 4px rgba(47,79,79,0.08), 0 22px 50px -16px rgba(212,175,55,0.7);
}

.hm-btn--secondary {
  background: linear-gradient(160deg, #2F4F4F 0%, #1C2F2F 100%);
  color: var(--hm-marble-100);
  border-color: rgba(255,255,255,0.10);
  box-shadow: var(--hm-shadow-soft);
}
.hm-btn--secondary:not(:disabled):hover {
  box-shadow: var(--hm-shadow-lift);
}

.hm-btn--ghost {
  background: #FFFFFF;
  color: var(--hm-ink);
  border-color: var(--hm-line);
  box-shadow: var(--hm-shadow-soft);
}
.hm-btn--ghost:not(:disabled):hover {
  border-color: var(--hm-line-gold);
}

.hm-btn--glass {
  background: rgba(255,255,255,0.10);
  color: var(--hm-marble-100);
  border-color: rgba(255,255,255,0.20);
  backdrop-filter: blur(8px);
}
.hm-btn--glass:not(:disabled):hover {
  background: rgba(255,255,255,0.16);
  border-color: rgba(244, 233, 190, 0.42);
}

/* Icon shifts on hover */
.hm-btn svg, .hm-btn [data-icon] {
  transition: transform var(--hm-dur) var(--hm-easing);
}
.hm-btn:not(:disabled):hover [data-icon="right"] { transform: translateX(2px); }
.hm-btn:not(:disabled):hover [data-icon="left"]  { transform: translateX(-1px); }

/* ----- Pill ----- */
.hm-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 22px;
  padding: 0 9px;
  border-radius: var(--hm-radius-pill);
  font-family: var(--hm-font-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid transparent;
}
.hm-pill--gold    { background: var(--hm-gold-50);     color: var(--hm-gold-700);  border-color: rgba(212,175,55,0.36); }
.hm-pill--sea     { background: rgba(47,79,79,0.08);   color: var(--hm-sea-500);   border-color: rgba(47,79,79,0.12); }
.hm-pill--marble  { background: var(--hm-marble-100);  color: var(--hm-sea-400);   border-color: var(--hm-marble-200); }
.hm-pill--success { background: var(--hm-success-bg);  color: var(--hm-success-ink); border-color: rgba(6,95,70,0.16); }
.hm-pill--warning { background: var(--hm-warning-bg);  color: var(--hm-warning-ink); border-color: rgba(146,64,14,0.16); }
.hm-pill--error   { background: var(--hm-error-bg);    color: var(--hm-error-ink); border-color: rgba(159,18,57,0.18); }
.hm-pill--glass   { background: rgba(255,255,255,0.12);color: var(--hm-marble-100);border-color: rgba(255,255,255,0.20); }

/* ----- Card ----- */
.hm-card {
  background: linear-gradient(180deg, #FFFFFF 0%, var(--hm-marble-50) 100%);
  border: 1px solid var(--hm-line);
  border-radius: var(--hm-radius-xl);
  box-shadow: var(--hm-shadow-soft);
  padding: 24px;
  transition: transform var(--hm-dur) var(--hm-easing),
              border-color var(--hm-dur) var(--hm-easing),
              box-shadow var(--hm-dur) var(--hm-easing);
}
.hm-card[data-interactive="true"] { cursor: pointer; }
.hm-card[data-interactive="true"]:hover {
  transform: translateY(-2px);
  border-color: var(--hm-line-gold);
  box-shadow: 0 18px 40px -24px rgba(47,79,79,0.22),
              0 4px 14px -10px rgba(212,175,55,0.20);
}
.hm-card.is-featured {
  border-color: var(--hm-line-gold);
  box-shadow: var(--hm-shadow-soft), 0 8px 20px -12px rgba(212,175,55,0.32);
}
@media (max-width: 640px) {
  .hm-card { padding: 20px; }
}

/* ----- Field (input / select / textarea) ----- */
.hm-field { display: grid; gap: 8px; }
.hm-field-label {
  font-family: var(--hm-font-sans);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--hm-ink-mute);
}
.hm-field-label .req { color: var(--hm-accent); margin-left: 2px; }
.hm-field-input {
  height: 48px;
  padding: 0 14px;
  border: 1px solid var(--hm-line-strong);
  border-radius: var(--hm-radius-md);
  background: #FFFFFF;
  font-family: var(--hm-font-sans);
  font-size: 14px;
  color: var(--hm-ink);
  transition: border-color var(--hm-dur-fast) var(--hm-easing),
              box-shadow var(--hm-dur-fast) var(--hm-easing);
  width: 100%;
}
.hm-field-input::placeholder { color: var(--hm-marble-400); }
.hm-field-input:focus {
  outline: none;
  border-color: var(--hm-accent);
  box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.18);
}
.hm-field-input.is-error {
  border-color: var(--hm-error-ink);
  box-shadow: 0 0 0 3px rgba(159, 18, 57, 0.12);
}
textarea.hm-field-input { height: auto; min-height: 96px; padding: 12px 14px; line-height: 1.55; resize: vertical; }
.hm-field-hint  { font-size: 11.5px; color: var(--hm-ink-mute); line-height: 1.5; }
.hm-field-error { font-size: 11.5px; color: var(--hm-error-ink); line-height: 1.5; }
@media (max-width: 640px) {
  .hm-field-input { font-size: 16px; min-height: 48px; }
}

/* ----- Section header ----- */
.hm-section-header { display: grid; gap: 12px; margin-bottom: 32px; max-width: 760px; }
@media (min-width: 768px) { .hm-section-header { margin-bottom: 40px; } }

/* ----- Section numerals (editorial detail used on static pages) ----- */
.hm-numeral {
  font-family: var(--hm-font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.28em;
  color: var(--hm-gold-700);
  text-transform: uppercase;
}

/* ----- Focus ring (global) ----- */
:where(button, a, input, select, textarea):focus-visible {
  outline: 2px solid var(--hm-accent);
  outline-offset: 2px;
  border-radius: 6px;
}

/* ----- Reduced motion ----- */
@media (prefers-reduced-motion: reduce) {
  .hm-btn:hover { transform: none !important; }
  .hm-card[data-interactive="true"]:hover { transform: none !important; }
  * { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
}


/* ===========================================================================
   Stage 9 · Patterns (see patterns.md)
   Reusable UI pieces beyond the core components.
   ========================================================================= */

/* ----- 1 · Dividers ----- */
.hm-divider {
  height: 1px;
  width: 100%;
  background: var(--hm-line);
  border: 0;
  margin: 0;
}
.hm-divider--dashed {
  background: transparent;
  border-top: 1px dashed var(--hm-line-strong);
}
.hm-divider--label {
  display: flex; align-items: center; gap: 16px;
  width: 100%;
}
.hm-divider--label::before,
.hm-divider--label::after {
  content: ""; flex: 1; height: 1px; background: var(--hm-line);
}
.hm-divider--vertical {
  display: inline-block;
  width: 1px; height: 1em;
  background: var(--hm-line-strong);
  margin: 0 10px;
  vertical-align: middle;
}

/* ----- 2 · Alert / Banner ----- */
.hm-alert {
  display: flex;
  gap: 14px;
  padding: 16px 18px;
  border-radius: var(--hm-radius-md);
  border: 1px solid transparent;
  align-items: flex-start;
  font-family: var(--hm-font-sans);
}
.hm-alert-icon { flex: 0 0 auto; margin-top: 2px; }
.hm-alert-body { flex: 1; min-width: 0; }
.hm-alert-title {
  font-size: 14px; font-weight: 600; line-height: 1.4;
  margin-bottom: 4px;
}
.hm-alert-text { font-size: 13px; line-height: 1.55; opacity: 0.9; }
.hm-alert-close {
  flex: 0 0 auto;
  width: 28px; height: 28px; border-radius: 8px;
  background: transparent; border: 0; cursor: pointer;
  display: grid; place-items: center;
  color: inherit; opacity: 0.5;
  transition: background var(--hm-dur-fast) var(--hm-easing), opacity var(--hm-dur-fast) var(--hm-easing);
}
.hm-alert-close:hover { background: rgba(0,0,0,0.06); opacity: 1; }

.hm-alert--gold    { background: var(--hm-gold-50);    color: var(--hm-gold-700);   border-color: rgba(212,175,55,0.32); }
.hm-alert--info    { background: rgba(47,79,79,0.05);  color: var(--hm-sea-500);    border-color: var(--hm-line-strong); }
.hm-alert--success { background: var(--hm-success-bg); color: var(--hm-success-ink);border-color: rgba(6,95,70,0.18); }
.hm-alert--warning { background: var(--hm-warning-bg); color: var(--hm-warning-ink);border-color: rgba(146,64,14,0.18); }
.hm-alert--error   { background: var(--hm-error-bg);   color: var(--hm-error-ink);  border-color: rgba(159,18,57,0.18); }

/* ----- 3 · Tabs (underline) ----- */
.hm-tabs {
  display: inline-flex;
  gap: 4px;
  border-bottom: 1px solid var(--hm-line);
  padding: 0;
}
.hm-tab {
  position: relative;
  height: 40px; padding: 0 14px;
  background: transparent; border: 0; cursor: pointer;
  font-family: var(--hm-font-sans);
  font-size: 13.5px; font-weight: 500; color: var(--hm-ink-soft);
  transition: color var(--hm-dur-fast) var(--hm-easing);
}
.hm-tab:hover { color: var(--hm-ink); }
.hm-tab.is-active { color: var(--hm-ink); font-weight: 600; }
.hm-tab.is-active::after {
  content: ""; position: absolute; left: 14px; right: 14px; bottom: -1px;
  height: 2px; background: var(--hm-accent); border-radius: 2px 2px 0 0;
}

/* ----- 3b · Segmented pills ----- */
.hm-segmented {
  display: inline-flex; padding: 3px; gap: 0;
  border-radius: var(--hm-radius-pill);
  background: rgba(28,47,47,0.06);
}
.hm-segmented-item {
  height: 30px; padding: 0 14px;
  border-radius: var(--hm-radius-pill); border: 0; cursor: pointer;
  font-family: var(--hm-font-sans);
  font-size: 12.5px; font-weight: 600; letter-spacing: 0.02em;
  color: var(--hm-ink-soft);
  background: transparent;
  transition: background var(--hm-dur-fast) var(--hm-easing), color var(--hm-dur-fast) var(--hm-easing);
}
.hm-segmented-item.is-on {
  background: var(--hm-paper); color: var(--hm-ink);
  box-shadow: 0 1px 2px rgba(0,0,0,0.06);
}

/* ----- 4 · Breadcrumb ----- */
.hm-breadcrumb ol {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; align-items: center;
  font-family: var(--hm-font-sans);
  font-size: 12.5px;
}
.hm-breadcrumb li {
  display: inline-flex; align-items: center;
  color: var(--hm-ink-mute);
}
.hm-breadcrumb li a { color: var(--hm-ink-soft); }
.hm-breadcrumb li a:hover { color: var(--hm-ink); }
.hm-breadcrumb li[aria-current="page"] { color: var(--hm-ink); font-weight: 600; }
.hm-breadcrumb li + li::before {
  content: "›";
  margin: 0 10px;
  color: var(--hm-marble-400);
  font-size: 14px;
}
@media (max-width: 640px) { .hm-breadcrumb { display: none; } }

/* ----- 5 · Tooltip (CSS-only via [data-tooltip]) ----- */
[data-tooltip] { position: relative; }
[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  left: 50%; bottom: calc(100% + 10px); transform: translateX(-50%) translateY(4px);
  white-space: nowrap;
  max-width: 240px;
  padding: 7px 11px;
  border-radius: 8px;
  background: var(--hm-sea-700); color: var(--hm-marble-100);
  font-family: var(--hm-font-sans);
  font-size: 11px; font-weight: 500; line-height: 1.4;
  pointer-events: none; opacity: 0;
  transition: opacity var(--hm-dur-fast) var(--hm-easing), transform var(--hm-dur-fast) var(--hm-easing);
  z-index: 60;
}
[data-tooltip]::before {
  content: "";
  position: absolute;
  left: 50%; bottom: calc(100% + 4px); transform: translateX(-50%) translateY(4px);
  width: 0; height: 0;
  border: 5px solid transparent;
  border-top-color: var(--hm-sea-700);
  pointer-events: none; opacity: 0;
  transition: opacity var(--hm-dur-fast) var(--hm-easing), transform var(--hm-dur-fast) var(--hm-easing);
}
[data-tooltip]:hover::after, [data-tooltip]:focus-visible::after,
[data-tooltip]:hover::before, [data-tooltip]:focus-visible::before {
  opacity: 1; transform: translateX(-50%) translateY(0);
}

/* ----- 6 · Empty state ----- */
.hm-empty {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 56px 24px;
  gap: 12px;
}
.hm-empty-icon {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  border-radius: var(--hm-radius-md);
  background: var(--hm-marble-50);
  color: var(--hm-marble-500);
  margin-bottom: 8px;
}
.hm-empty-title {
  font-family: var(--hm-font-display);
  font-size: 22px; line-height: 1.25; color: var(--hm-ink); font-weight: 600;
}
.hm-empty-text {
  font-family: var(--hm-font-sans);
  font-size: 13.5px; line-height: 1.6; color: var(--hm-ink-soft);
  max-width: 360px;
  margin-bottom: 8px;
}

/* ----- 7 · Skeleton loader ----- */
@keyframes hm-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.hm-skel {
  display: block;
  background: linear-gradient(
    90deg,
    var(--hm-marble-100) 0%,
    var(--hm-marble-200) 50%,
    var(--hm-marble-100) 100%
  );
  background-size: 200% 100%;
  animation: hm-shimmer 1.4s ease-in-out infinite;
  border-radius: 6px;
}
.hm-skel--line { height: 12px; margin-bottom: 8px; }
.hm-skel--avatar { width: 40px; height: 40px; border-radius: 999px; }
.hm-skel--card { width: 100%; border-radius: var(--hm-radius-md); }
@media (prefers-reduced-motion: reduce) {
  .hm-skel { animation: none; }
}

/* ----- 8 · Stat / metric block ----- */
.hm-stat {
  display: flex; flex-direction: column; gap: 12px;
  font-family: var(--hm-font-sans);
}
.hm-stat-num {
  font-family: var(--hm-font-display); font-weight: 500;
  font-size: clamp(40px, 4.4vw, 64px); line-height: 1;
  letter-spacing: -0.025em; color: var(--hm-ink);
  font-variant-numeric: tabular-nums lining-nums;
}
.hm-stat-num small {
  font-size: 0.4em; color: var(--hm-ink-mute); margin-left: 6px;
  letter-spacing: 0; font-weight: 500;
}
.hm-stat-label {
  font-size: 13px; color: var(--hm-ink-soft); line-height: 1.55;
  max-width: 220px;
}
.hm-stat-delta {
  font-family: var(--hm-font-mono);
  font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
}
.hm-stat-delta--up   { color: var(--hm-success-ink); }
.hm-stat-delta--down { color: var(--hm-error-ink); }
.hm-stat-delta--flat { color: var(--hm-ink-mute); }

/* ----- 9 · Pull-quote ----- */
.hm-quote {
  position: relative;
  margin: 0;
  padding: 20px 24px 20px 28px;
  border-left: 3px solid var(--hm-accent);
}
.hm-quote-text {
  margin: 0;
  font-family: var(--hm-font-display);
  font-style: italic; font-weight: 500;
  font-size: 22px; line-height: 1.3; color: var(--hm-ink);
  text-wrap: balance;
}
.hm-quote-source {
  margin-top: 14px;
  display: flex; flex-wrap: wrap; gap: 4px 12px;
  font-family: var(--hm-font-sans);
  font-size: 12px; color: var(--hm-ink-soft);
}
.hm-quote-meta {
  color: var(--hm-ink-mute);
  font-family: var(--hm-font-mono); font-size: 11px;
  letter-spacing: 0.06em;
}

/* ----- 10 · Numbered editorial list ----- */
.hm-numlist {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 24px;
}
.hm-numlist li {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 16px;
  align-items: start;
}
.hm-numlist-num {
  font-family: var(--hm-font-mono); font-weight: 600;
  font-size: 11px; letter-spacing: 0.24em;
  color: var(--hm-gold-700);
  padding-top: 4px;
  position: relative;
}
.hm-numlist-num::after {
  content: "";
  position: absolute;
  left: 30px; right: 6px; top: 11px;
  height: 1px; background: var(--hm-line);
}
.hm-numlist-title {
  font-family: var(--hm-font-display);
  font-size: 20px; font-weight: 600; line-height: 1.25;
  color: var(--hm-ink);
  margin-bottom: 6px;
}
.hm-numlist-body {
  margin: 0;
  font-family: var(--hm-font-sans);
  font-size: 14px; line-height: 1.6;
  color: var(--hm-ink-soft);
}

/* ----- 11 · Filter chip · toggleable ----- */
.hm-chip-row {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.hm-chip {
  display: inline-flex; align-items: center; gap: 6px;
  height: 30px; padding: 0 14px;
  border-radius: var(--hm-radius-pill);
  border: 1px solid var(--hm-line);
  background: var(--hm-paper);
  font-family: var(--hm-font-sans);
  font-size: 12.5px; font-weight: 500;
  color: var(--hm-ink-soft); cursor: pointer;
  transition: background var(--hm-dur-fast) var(--hm-easing),
              color var(--hm-dur-fast) var(--hm-easing),
              border-color var(--hm-dur-fast) var(--hm-easing);
}
.hm-chip:hover { border-color: var(--hm-line-strong); color: var(--hm-ink); }
.hm-chip[aria-pressed="true"] {
  background: var(--hm-gold-50);
  border-color: rgba(212,175,55,0.5);
  color: var(--hm-gold-700);
  font-weight: 600;
}

/* ----- 12 · Progress / step indicator ----- */
.hm-progress {
  width: 100%; height: 6px;
  border-radius: 999px;
  background: var(--hm-marble-200);
  overflow: hidden;
}
.hm-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--hm-gold-300), var(--hm-gold-500));
  border-radius: 999px;
  transition: width var(--hm-dur) var(--hm-easing);
}

.hm-steps {
  list-style: none; padding: 0; margin: 0;
  display: flex; gap: 0; align-items: center;
}
.hm-steps-item {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--hm-font-sans);
  font-size: 12.5px; font-weight: 500; color: var(--hm-ink-mute);
  white-space: nowrap;
}
.hm-steps-item span {
  display: inline-grid; place-items: center;
  width: 24px; height: 24px; border-radius: 999px;
  font-family: var(--hm-font-mono); font-size: 10px; font-weight: 700;
  background: var(--hm-marble-100);
  border: 1px solid var(--hm-line-strong);
  color: var(--hm-ink-mute);
}
.hm-steps-item.is-active { color: var(--hm-ink); font-weight: 600; }
.hm-steps-item.is-active span {
  background: linear-gradient(135deg, #F0DC8A, #D4AF37);
  border-color: rgba(212,175,55,0.6);
  color: var(--hm-sea-500);
}
.hm-steps-item.is-done { color: var(--hm-ink-soft); }
.hm-steps-item.is-done span {
  background: var(--hm-marble-200);
  border-color: rgba(212,175,55,0.4);
  color: var(--hm-gold-700);
}
.hm-steps-item + .hm-steps-item::before {
  content: ""; display: inline-block;
  width: 28px; height: 1px;
  background: var(--hm-line-strong);
  margin: 0 12px;
}

/* ----- 13 · Avatar + stack ----- */
.hm-avatar {
  --hm-avatar-size: 36px;
  display: inline-grid; place-items: center;
  width: var(--hm-avatar-size); height: var(--hm-avatar-size);
  border-radius: 999px;
  background: linear-gradient(160deg, var(--hm-sea-400) 0%, var(--hm-sea-600) 100%);
  color: var(--hm-gold-300);
  font-family: var(--hm-font-sans);
  font-weight: 600;
  font-size: calc(var(--hm-avatar-size) * 0.42);
  overflow: hidden;
  flex: 0 0 auto;
}
.hm-avatar[data-initial]::before { content: attr(data-initial); }
.hm-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: inherit; }
.hm-avatar-stack {
  display: inline-flex;
  align-items: center;
}
.hm-avatar-stack .hm-avatar {
  box-shadow: 0 0 0 2px var(--hm-paper);
}
.hm-avatar-stack .hm-avatar + .hm-avatar {
  margin-left: -10px;
}
.hm-avatar--more {
  background: var(--hm-marble-200) !important;
  color: var(--hm-ink-soft) !important;
  font-size: calc(var(--hm-avatar-size) * 0.36) !important;
}

/* ----- 14 · Search input ----- */
.hm-search {
  position: relative;
  display: block;
}
.hm-search .hm-field-input {
  padding-left: 40px;
  padding-right: 36px;
}
.hm-search-icon {
  position: absolute;
  left: 14px; top: 50%;
  transform: translateY(-50%);
  color: var(--hm-ink-mute);
  pointer-events: none;
}
.hm-search-clear {
  position: absolute;
  right: 8px; top: 50%;
  transform: translateY(-50%);
  width: 28px; height: 28px; border-radius: 8px;
  background: transparent; border: 0; cursor: pointer;
  display: grid; place-items: center;
  color: var(--hm-ink-mute);
  transition: background var(--hm-dur-fast) var(--hm-easing), color var(--hm-dur-fast) var(--hm-easing);
}
.hm-search-clear:hover { background: var(--hm-marble-100); color: var(--hm-ink); }

/* ----- 15 · Spinner ----- */
@keyframes hm-spin { to { transform: rotate(360deg); } }
.hm-spinner {
  display: inline-block;
  width: 16px; height: 16px;
  border-radius: 999px;
  border: 2px solid rgba(212,175,55,0.18);
  border-top-color: var(--hm-gold-400);
  animation: hm-spin 1.1s linear infinite;
  flex: 0 0 auto;
}
.hm-spinner--lg { width: 24px; height: 24px; border-width: 2.5px; }
@media (prefers-reduced-motion: reduce) {
  .hm-spinner { animation-duration: 3s; }
}
