/* ============================================================
   WriteUpCafe — App nav (signed-in) — design system implementation
   Loads AFTER app.css so these rules win.
   Spec reference: src/design-system/design.md §9 (layout), §6 (icons).
   Dark espresso frame over the parchment app body.
   ============================================================ */

/* ── Nav wrapper ─────────────────────────────────────────────── */
.nav-app {
  position: sticky; top: 0; z-index: 100;
  background: rgba(26, 15, 6, 0.88);
  backdrop-filter: saturate(1.2) blur(12px);
  -webkit-backdrop-filter: saturate(1.2) blur(12px);
  border-bottom: 1px solid rgba(193, 125, 60, 0.18);
  color: var(--wuc-cream);
}
.nav-app__inner {
  display: flex;
  align-items: center;
  gap: clamp(12px, 2vw, 24px);
  height: 64px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 24px);
}

/* ── Logo ────────────────────────────────────────────────────── */
.nav-app .site-logo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--wuc-font-display);
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1;
  color: #ffffff;
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.nav-app .site-logo em {
  color: var(--wuc-primary);
  font-style: italic;
}
.nav-app .site-logo-icon {
  width: 28px; height: 28px;
  object-fit: contain;
  flex-shrink: 0;
}

/* ── Search ──────────────────────────────────────────────────── */
.nav-app .nav-search {
  flex: 1;
  max-width: 440px;
  position: relative;
}
.nav-app .nav-search__icon {
  position: absolute;
  left: 12px; top: 50%;
  transform: translateY(-50%);
  color: var(--wuc-cream-muted);
  pointer-events: none;
}
.nav-app .nav-search__input {
  width: 100%;
  height: 38px;
  padding: 0 12px 0 38px;
  border: 1px solid rgba(193, 125, 60, 0.25);
  border-radius: var(--wuc-r-pill);
  font: 400 14px/1 var(--wuc-font-body);
  background: rgba(255, 255, 255, 0.06);
  color: var(--wuc-cream);
  outline: none;
  transition: background 150ms ease-out, border-color 150ms ease-out;
}
.nav-app .nav-search__input::placeholder { color: rgba(221, 208, 192, 0.55); }
.nav-app .nav-search__input:hover        { background: rgba(255, 255, 255, 0.09); border-color: rgba(193, 125, 60, 0.40); }
.nav-app .nav-search__input:focus        { background: rgba(255, 255, 255, 0.10); border-color: var(--wuc-primary); box-shadow: 0 0 0 3px rgba(232, 122, 53, 0.25); }

/* ── Right actions row ───────────────────────────────────────── */
.nav-app .nav__actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}

/* ── Icon buttons (bell, messages, mobile search toggle, hamburger) ── */
.nav-app .nav-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  padding: 0;
  border-radius: var(--wuc-r-pill);
  background: transparent;
  border: 1px solid transparent;
  color: var(--wuc-cream);
  cursor: pointer;
  position: relative;
  transition: background 150ms ease-out, border-color 150ms ease-out, color 150ms ease-out;
}
.nav-app .nav-icon-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(193, 125, 60, 0.28);
  color: #ffffff;
}
.nav-app .nav-icon-btn svg { stroke-width: 1.75; }

/* ── Create button (primary pill, per design.md §4.1) ────────── */
/* Targets .nav-icon-btn.nav-btn-create since HTML has both classes on the
   same element; !important on dimensions explicitly beats .nav-icon-btn's
   40×40 square sizing. */
.nav-app .nav-btn-create {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: auto !important;
  height: 40px !important;
  padding: 0 22px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: var(--wuc-primary) !important;
  border: 1px solid var(--wuc-primary) !important;
  color: #ffffff !important;
  font: 500 14px/1 var(--wuc-font-body) !important;
  text-decoration: none !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.nav-app .nav-btn-create:hover {
  background: var(--wuc-primary-hover) !important;
  border-color: var(--wuc-primary-hover) !important;
  color: #ffffff !important;
}
.nav-app .nav-btn-create:active {
  background: var(--wuc-primary-press) !important;
  border-color: var(--wuc-primary-press) !important;
  box-shadow: none !important;
}
.nav-app .nav-btn-create .nav-create-icon,
.nav-app .nav-btn-create svg {
  width: 16px;
  height: 16px;
  stroke-width: 2;
  stroke: currentColor;
}
.nav-app .nav-btn-create .nav-create-label {
  display: inline;
  font: 500 14px/1 var(--wuc-font-body);
}
@media (max-width: 720px) {
  .nav-app .nav-btn-create {
    width: 40px !important;
    padding: 0 !important;
  }
  .nav-app .nav-btn-create .nav-create-label { display: none; }
}

/* ── Badges (notifications + messages) ───────────────────────── */
.nav-app .notif-badge,
.nav-app .msg-nav-badge {
  position: absolute;
  top: 4px; right: 4px;
  min-width: 16px; height: 16px;
  padding: 0 4px;
  border-radius: var(--wuc-r-pill);
  background: var(--wuc-primary);
  color: #ffffff;
  font: 600 10px/16px var(--wuc-font-body);
  text-align: center;
  border: 1.5px solid rgba(26, 15, 6, 0.88);
}
.nav-app .notif-bell.has-unread .notif-badge { box-shadow: 0 0 0 2px rgba(232, 122, 53, 0.25); }

/* ── Notification dropdown ───────────────────────────────────── */
.notification-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 360px;
  max-width: calc(100vw - 32px);
  background: var(--wuc-espresso-mid);
  border: 1px solid rgba(193, 125, 60, 0.28);
  border-radius: var(--wuc-r-lg);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45);
  overflow: hidden;
  z-index: 200;
}
.notification-dropdown.hidden { display: none; }
.notification-dropdown__header {
  padding: 14px 18px;
  font: 600 10px/1 var(--wuc-font-body);
  letter-spacing: var(--wuc-ls-caps);
  text-transform: uppercase;
  color: var(--wuc-primary);
  border-bottom: 1px solid rgba(193, 125, 60, 0.18);
}
.notification-dropdown__body {
  max-height: 360px;
  overflow-y: auto;
  color: var(--wuc-cream);
}
.notification-dropdown .dropdown-footer {
  padding: 10px 18px;
  border-top: 1px solid rgba(193, 125, 60, 0.18);
  text-align: center;
}
.notification-dropdown .view-all-link {
  font: 500 13px/1 var(--wuc-font-body);
  color: var(--wuc-primary);
  text-decoration: none;
}
.notification-dropdown .view-all-link:hover { color: var(--wuc-primary-hover); }

.notif-drop-loading, .notif-drop-error, .notif-drop-empty {
  padding: 24px 18px;
  text-align: center;
  font-size: 13px;
  color: var(--wuc-cream-muted);
}
.notif-drop-error { color: var(--wuc-coral); }

.notif-drop-item {
  display: flex;
  gap: 12px;
  padding: 12px 18px;
  border-bottom: 1px solid rgba(193, 125, 60, 0.10);
  text-decoration: none;
}
.notif-drop-item:last-child { border-bottom: none; }
.notif-drop-item:hover { background: rgba(255, 255, 255, 0.03); }
.notif-drop-item--unread { background: rgba(232, 122, 53, 0.06); }
.notif-drop-item__avatar {
  width: 34px; height: 34px;
  border-radius: var(--wuc-r-pill);
  overflow: hidden;
  background: var(--wuc-espresso-dark);
  color: var(--wuc-gold-highlight);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font: 600 14px/1 var(--wuc-font-display);
}
.notif-drop-item__avatar img { width: 100%; height: 100%; object-fit: cover; }
.notif-drop-item__content { flex: 1; min-width: 0; }
.notif-drop-item__text {
  display: block;
  font: 400 13px/1.4 var(--wuc-font-body);
  color: var(--wuc-cream);
  text-decoration: none;
  margin-bottom: 4px;
}
.notif-drop-item__text:hover { color: var(--wuc-primary); }
.notif-drop-item__time {
  display: block;
  font: 400 11px/1 var(--wuc-font-body);
  color: rgba(221, 208, 192, 0.55);
}

/* Reset hints baked into app.css */
.notif-bell { background: transparent; }
.notif-bell:hover { background: rgba(255, 255, 255, 0.08); }

/* ── Profile dropdown ────────────────────────────────────────── */
.nav-app .nav-profile-wrap { position: relative; }
.nav-app .nav-profile-btn {
  width: 40px; height: 40px;
  border-radius: var(--wuc-r-pill);
  background: var(--wuc-espresso-dark);
  border: 1px solid rgba(193, 125, 60, 0.28);
  color: var(--wuc-cream);
  font: 600 14px/1 var(--wuc-font-display);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 0;
  transition: border-color 150ms ease-out;
}
.nav-app .nav-profile-btn:hover { border-color: rgba(193, 125, 60, 0.55); }
.nav-app .nav-profile-btn img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: var(--wuc-r-pill);
}

.nav-profile-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 260px;
  background: var(--wuc-espresso-mid);
  border: 1px solid rgba(193, 125, 60, 0.28);
  border-radius: var(--wuc-r-lg);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45);
  overflow: hidden;
  z-index: 200;
}
.nav-profile-dropdown.hidden { display: none; }
.nav-profile-dropdown__header {
  padding: 14px 16px;
  border-bottom: 1px solid rgba(193, 125, 60, 0.18);
}
.nav-profile-dropdown__name {
  font: 600 14px/1.2 var(--wuc-font-body);
  color: var(--wuc-cream);
  margin-bottom: 2px;
}
.nav-profile-dropdown__username {
  font: 400 12px/1.2 var(--wuc-font-body);
  color: rgba(221, 208, 192, 0.55);
}
.nav-profile-dropdown__links {
  padding: 6px 0;
}
.nav-profile-dropdown__link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px;
  font: 500 13px/1 var(--wuc-font-body);
  color: var(--wuc-cream);
  text-decoration: none;
  transition: background 150ms ease-out, color 150ms ease-out;
}
.nav-profile-dropdown__link:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--wuc-primary);
}
.nav-profile-dropdown__link svg {
  stroke-width: 1.75;
  color: var(--wuc-copper);
  flex-shrink: 0;
}
.nav-profile-dropdown__link:hover svg { color: var(--wuc-primary); }
.nav-profile-dropdown__logout {
  border-top: 1px solid rgba(193, 125, 60, 0.18);
  padding: 4px 0;
}
.nav-profile-dropdown__logout form { margin: 0; }
.nav-profile-dropdown__logout .nav-profile-dropdown__link {
  color: rgba(221, 208, 192, 0.55) !important;
  padding: 9px 16px !important;
  background: none !important;
  border: 0;
  cursor: pointer;
}
.nav-profile-dropdown__logout .nav-profile-dropdown__link:hover {
  background: rgba(255, 255, 255, 0.05) !important;
  color: var(--wuc-coral) !important;
}

/* ── Mobile search overlay ───────────────────────────────────── */
.nav-mobile-search {
  position: fixed;
  top: 64px;
  left: 0; right: 0;
  background: var(--wuc-espresso-mid);
  border-bottom: 1px solid rgba(193, 125, 60, 0.18);
  padding: 12px 16px;
  z-index: 90;
  transform: translateY(-12px);
  opacity: 0;
  pointer-events: none;
  transition: transform 150ms ease-out, opacity 150ms ease-out;
}
.nav-mobile-search.open { opacity: 1; transform: none; pointer-events: auto; }
.nav-mobile-search__inner {
  position: relative;
  max-width: 600px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 8px;
}
.nav-mobile-search__icon {
  position: absolute;
  left: 12px; top: 50%;
  transform: translateY(-50%);
  color: var(--wuc-cream-muted);
}
.nav-mobile-search__input {
  flex: 1;
  height: 40px;
  padding: 0 12px 0 38px;
  border: 1px solid rgba(193, 125, 60, 0.25);
  border-radius: var(--wuc-r-pill);
  background: rgba(255, 255, 255, 0.06);
  color: var(--wuc-cream);
  font: 400 14px/1 var(--wuc-font-body);
  outline: none;
}
.nav-mobile-search__input::placeholder { color: rgba(221, 208, 192, 0.55); }
.nav-mobile-search__input:focus { border-color: var(--wuc-primary); box-shadow: 0 0 0 3px rgba(232, 122, 53, 0.25); }
.nav-mobile-search__close {
  width: 36px; height: 36px;
  border-radius: var(--wuc-r-pill);
  background: transparent;
  border: 1px solid rgba(193, 125, 60, 0.25);
  color: var(--wuc-cream);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.nav-mobile-search__close:hover { background: rgba(255, 255, 255, 0.06); }

/* ── Mobile drawer ───────────────────────────────────────────── */
/* Note: app.css also defines .nav-drawer{left:0;bottom:0;transform:translateX(-100%)}
   with display:none on the backdrop. Because app.css is loaded via async preload,
   its rules can win the cascade. We use !important on positioning + transform to
   guarantee the drawer stays off-screen until .open. */
.nav-drawer-backdrop {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(2px);
  display: none !important;
  z-index: 140;
}
.nav-drawer-backdrop.open { display: block !important; }
.nav-drawer {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  left: auto !important;
  bottom: auto !important;
  width: 320px;
  max-width: 90vw;
  height: 100vh;
  background: var(--wuc-espresso-mid);
  border-left: 1px solid rgba(193, 125, 60, 0.18);
  color: var(--wuc-cream);
  transform: translateX(100%) !important;
  transition: transform 220ms ease-out;
  z-index: 150;
  display: flex;
  flex-direction: column;
}
.nav-drawer.open { transform: translateX(0) !important; }
.nav-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(193, 125, 60, 0.18);
}
.nav-drawer__title {
  font: 600 10px/1 var(--wuc-font-body);
  letter-spacing: var(--wuc-ls-caps);
  text-transform: uppercase;
  color: var(--wuc-primary);
}
.nav-drawer__close {
  width: 36px; height: 36px;
  border-radius: var(--wuc-r-pill);
  background: transparent;
  border: 1px solid rgba(193, 125, 60, 0.25);
  color: var(--wuc-cream);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.nav-drawer__close:hover { background: rgba(255, 255, 255, 0.06); }

.nav-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0 16px;
}
.nav-drawer__profile {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
}
.nav-drawer__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: var(--wuc-r-pill);
  background: var(--wuc-espresso-dark);
  color: var(--wuc-gold-highlight);
  font: 600 16px/1 var(--wuc-font-display);
  overflow: hidden;
  text-decoration: none;
  flex-shrink: 0;
}
.nav-drawer__avatar img { width: 100%; height: 100%; object-fit: cover; }
.nav-drawer__profile-name {
  display: block;
  font: 600 14px/1.2 var(--wuc-font-body);
  color: var(--wuc-cream);
  text-decoration: none;
}
.nav-drawer__profile-name:hover { color: var(--wuc-primary); }
.nav-drawer__profile-handle {
  font: 400 12px/1.2 var(--wuc-font-body);
  color: rgba(221, 208, 192, 0.55);
  margin-top: 2px;
}
.nav-drawer__profile-links {
  display: flex;
  flex-direction: column;
  padding: 0 12px;
}
.nav-drawer__section-label {
  padding: 12px 20px 6px;
  font: 600 10px/1 var(--wuc-font-body);
  letter-spacing: var(--wuc-ls-caps);
  text-transform: uppercase;
  color: var(--wuc-primary);
}
.nav-drawer__links {
  display: flex;
  flex-direction: column;
  padding: 0 12px;
}
.nav-drawer__link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--wuc-r-md);
  font: 500 14px/1 var(--wuc-font-body);
  color: var(--wuc-cream);
  text-decoration: none;
  background: transparent;
  border: 0;
  cursor: pointer;
  transition: background 150ms ease-out, color 150ms ease-out;
}
.nav-drawer__link:hover { background: rgba(255, 255, 255, 0.05); color: var(--wuc-primary); }
.nav-drawer__link svg { stroke-width: 1.75; color: var(--wuc-copper); flex-shrink: 0; }
.nav-drawer__link:hover svg { color: var(--wuc-primary); }
.nav-drawer__link--danger { color: rgba(221, 208, 192, 0.65); }
.nav-drawer__link--danger:hover { color: var(--wuc-coral); }
.nav-drawer__link--danger svg { color: rgba(221, 208, 192, 0.55); }
.nav-drawer__link--danger:hover svg { color: var(--wuc-coral); }
.nav-drawer__divider {
  height: 1px;
  margin: 8px 20px;
  background: rgba(193, 125, 60, 0.15);
}
.nav-drawer__logout { padding: 0 12px; }
.nav-drawer__logout form { margin: 0; }
.nav-drawer__logout .nav-drawer__link {
  width: 100%;
  text-align: left;
  font: 500 14px/1 var(--wuc-font-body);
}

/* ── Logged-out fallback buttons ─────────────────────────────── */
.nav-app .nav__actions .btn-outline,
.nav-app .nav__actions a.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 0 16px;
  border-radius: var(--wuc-r-pill);
  background: transparent;
  border: 1px solid rgba(193, 125, 60, 0.40) !important;
  color: var(--wuc-cream) !important;
  font: 500 13px/1 var(--wuc-font-body);
  text-decoration: none;
}
.nav-app .nav__actions .btn-outline:hover { background: rgba(255, 255, 255, 0.06); border-color: rgba(193, 125, 60, 0.60) !important; }
.nav-app .nav__actions .btn-primary,
.nav-app .nav__actions a.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 0 16px;
  border-radius: var(--wuc-r-pill);
  background: var(--wuc-primary);
  border: 1px solid var(--wuc-primary);
  color: #ffffff;
  font: 500 13px/1 var(--wuc-font-body);
  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}
.nav-app .nav__actions .btn-primary:hover { background: var(--wuc-primary-hover); border-color: var(--wuc-primary-hover); }

/* ── Responsive: hide search on tight screens, show mobile toggle ── */
@media (max-width: 720px) {
  .nav-app .nav-search { display: none; }
  .nav-app .nav-mobile-search-btn { display: inline-flex; }
}
@media (min-width: 721px) {
  .nav-app .nav-mobile-search-btn { display: none; }
  .nav-app .nav-hamburger { display: none; }
}

/* ── Legacy dropdown search results (srch-dropdown) ──────────── */
.srch-dropdown:not(:empty) {
  position: absolute;
  top: calc(100% + 6px);
  left: 0; right: 0;
  background: var(--wuc-espresso-mid);
  border: 1px solid rgba(193, 125, 60, 0.28);
  border-radius: var(--wuc-r-md);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45);
  overflow: hidden;
  z-index: 180;
  max-height: 420px;
  overflow-y: auto;
  color: var(--wuc-cream);
}

/* ============================================================
   Legacy site-wide token remappings
   Rebinds a few global legacy tokens declared in app.css so the entire
   signed-in UI flows through the design system without touching app.css.
   ============================================================ */
:root {
  --accent:      var(--wuc-primary);        /* was #e8553d — unify brand accent */
  --dir-copper:  var(--wuc-primary);        /* blog-directory legacy copper */
  --dir-teal:    var(--wuc-teal);
  --dir-amber:   var(--wuc-gold-warm);
  --dir-border:  var(--wuc-border-strong);
  --dir-muted:   var(--wuc-fg3);
}

/* ============================================================
   Profile page components — spec-compliant overrides for author/show.php
   ============================================================ */

/* .prof-btn-follow — primary CTA on profile header (Follow / Following) */
.prof-btn-follow {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  height: 40px !important;
  padding: 0 22px !important;
  background: var(--wuc-primary) !important;
  color: #ffffff !important;
  border: 1px solid var(--wuc-primary) !important;
  border-radius: var(--wuc-r-pill) !important;
  font: 500 14px/1 var(--wuc-font-body) !important;
  text-decoration: none;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.prof-btn-follow:hover {
  background: var(--wuc-primary-hover) !important;
  border-color: var(--wuc-primary-hover) !important;
  transform: none !important;                /* spec §7: no transforms */
}
.prof-btn-follow:active {
  background: var(--wuc-primary-press) !important;
  border-color: var(--wuc-primary-press) !important;
  box-shadow: none !important;
}
/* "Following" state — self-contained light-surface pill so it reads on any
   ambient bg (parchment or espresso). Shows a clear copper accent hover. */
.prof-btn-follow.following {
  background: var(--wuc-parchment-raised) !important;
  color: var(--wuc-fg1) !important;
  border: 1px solid var(--wuc-border-strong) !important;
  box-shadow: none !important;
}
.prof-btn-follow.following:hover {
  background: rgba(232, 122, 53, 0.10) !important;
  color: var(--wuc-primary) !important;
  border-color: var(--wuc-primary) !important;
}

/* .profile-tab — sits inside .profile-tabs-wrap which has a dark espresso
   bg (#2C1F14). Inactive tabs need cream-muted text to be readable. */
.profile-tabs-wrap .profile-tab,
.profile-tab {
  padding: 14px 20px !important;
  font: 500 14px/1 var(--wuc-font-body) !important;
  color: var(--wuc-cream-muted) !important;
  border-bottom: 2px solid transparent !important;
  white-space: nowrap;
  transition: color 150ms ease-out, border-color 150ms ease-out !important;
  text-decoration: none;
}
.profile-tabs-wrap .profile-tab.active,
.profile-tab.active {
  color: var(--wuc-primary) !important;
  border-bottom-color: var(--wuc-primary) !important;
}
.profile-tabs-wrap .profile-tab:hover,
.profile-tab:hover {
  color: #ffffff !important;
  text-decoration: none;
}
.profile-tabs-wrap .profile-tab.active:hover,
.profile-tab.active:hover { color: var(--wuc-primary) !important; }

/* .prof-btn-chat — "Message" secondary button in profile hero. Sits on the
   dark espresso cover, so it keeps its white-on-dark appearance — but gets
   the spec pill radius, weight, and no transform. */
.prof-btn-chat {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  height: 40px !important;
  padding: 0 22px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  border: 1px solid rgba(193, 125, 60, 0.35) !important;
  font: 500 14px/1 var(--wuc-font-body) !important;
  text-decoration: none;
  cursor: pointer;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.prof-btn-chat:hover {
  background: rgba(255, 255, 255, 0.14) !important;
  border-color: rgba(193, 125, 60, 0.55) !important;
  transform: none !important;
}
.prof-btn-chat:active {
  background: rgba(255, 255, 255, 0.06) !important;
}
.prof-btn-chat:disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
}

/* .prof-user-card__follow — Follow button inside user-list cards
   (Followers / Following tabs, recommended users). Same spec as primary
   pill but smaller footprint to suit the inline card context. */
.prof-user-card__follow {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 32px !important;
  padding: 0 14px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: var(--wuc-primary) !important;
  color: #ffffff !important;
  border: 1px solid var(--wuc-primary) !important;
  font: 500 13px/1 var(--wuc-font-body) !important;
  white-space: nowrap;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  transition: background 150ms ease-out, border-color 150ms ease-out, color 150ms ease-out !important;
}
.prof-user-card__follow:hover {
  background: var(--wuc-primary-hover) !important;
  border-color: var(--wuc-primary-hover) !important;
  color: #ffffff !important;
}
.prof-user-card__follow:active {
  background: var(--wuc-primary-press) !important;
  border-color: var(--wuc-primary-press) !important;
  box-shadow: none !important;
}
.prof-user-card__follow.following {
  background: var(--wuc-parchment-raised) !important;
  color: var(--wuc-fg1) !important;
  border: 1px solid var(--wuc-border-strong) !important;
  box-shadow: none !important;
}
.prof-user-card__follow.following:hover {
  background: rgba(232, 122, 53, 0.10) !important;
  color: var(--wuc-primary) !important;
  border-color: var(--wuc-primary) !important;
}

/* ============================================================
   Blog card components (.bc-*) — spec-compliant overrides
   Used by blog directory + profile blog tab. Structural classes
   inherit via --dir-* rebindings above; Follow button needs its
   own recipe.
   ============================================================ */
.bc-follow-btn {
  display: inline-flex !important;
  align-items: center !important;
  height: 28px !important;
  padding: 0 12px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: var(--wuc-primary) !important;
  color: #ffffff !important;
  border: 1px solid var(--wuc-primary) !important;
  font: 500 12px/1 var(--wuc-font-body) !important;
  white-space: nowrap;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.bc-follow-btn:hover {
  background: var(--wuc-primary-hover) !important;
  border-color: var(--wuc-primary-hover) !important;
}
.bc-follow-btn.on {
  background: transparent !important;
  color: var(--wuc-fg2) !important;
  border: 1px solid var(--wuc-border-strong) !important;
  box-shadow: none !important;
}
.bc-follow-btn.on:hover {
  background: rgba(232, 122, 53, 0.08) !important;
  color: var(--wuc-primary) !important;
  border-color: var(--wuc-primary) !important;
}

/* .tpc-fc-follow — Follow button on the featured-topic card (dark hero) */
.tpc-fc-follow {
  display: inline-flex !important;
  align-items: center !important;
  height: 32px !important;
  padding: 0 14px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  border: 1px solid rgba(193, 125, 60, 0.35) !important;
  font: 500 13px/1 var(--wuc-font-body) !important;
  cursor: pointer;
  white-space: nowrap;
  transition: background 150ms ease-out, border-color 150ms ease-out, color 150ms ease-out !important;
}
.tpc-fc-follow:hover {
  background: rgba(255, 255, 255, 0.14) !important;
  border-color: rgba(193, 125, 60, 0.55) !important;
}
.tpc-fc-follow.following {
  background: var(--wuc-primary) !important;
  color: #ffffff !important;
  border-color: var(--wuc-primary) !important;
}
.tpc-fc-follow.following:hover {
  background: var(--wuc-primary-hover) !important;
  border-color: var(--wuc-primary-hover) !important;
}

/* .tpc-card__follow — Follow chip inside each topic card (parchment).
   Reveal on card hover is kept (that's a card-UX convention, not a button-
   hover transform per spec §7 which targets button states). */
.tpc-card__follow {
  display: inline-flex !important;
  align-items: center !important;
  height: 28px !important;
  padding: 0 12px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: transparent !important;
  color: var(--wuc-primary) !important;
  border: 1px solid var(--wuc-primary) !important;
  font: 500 12px/1 var(--wuc-font-body) !important;
  cursor: pointer;
  white-space: nowrap;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 150ms ease-out, transform 150ms ease-out, background 150ms ease-out, color 150ms ease-out !important;
}
.tpc-card__follow:hover {
  background: rgba(232, 122, 53, 0.10) !important;
  color: var(--wuc-primary) !important;
  border-color: var(--wuc-primary) !important;
}
.tpc-card__follow.following {
  opacity: 1 !important;
  transform: translateY(0) !important;
  background: var(--wuc-primary) !important;
  color: #ffffff !important;
  border-color: var(--wuc-primary) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
}
.tpc-card__follow.following:hover {
  background: var(--wuc-primary-hover) !important;
  border-color: var(--wuc-primary-hover) !important;
  color: #ffffff !important;
}

/* .ts-tab — topic-show page tabs (Latest / Top / Following).
   Matches .profile-tab treatment so both tab systems are consistent:
   cream-muted inactive → white hover → primary-orange active, with matching
   primary-orange underline. Spec §5.3. */
.ts-tab {
  color: var(--wuc-cream-muted) !important;
  font: 500 13px/1 var(--wuc-font-body) !important;
  transition: color 150ms ease-out, border-color 150ms ease-out !important;
}
.ts-tab:hover { color: #ffffff !important; }
.ts-tab.active {
  color: var(--wuc-primary) !important;
  border-bottom-color: var(--wuc-primary) !important;
}
.ts-tab.active:hover { color: var(--wuc-primary) !important; }

/* .ts-sc__tag — related-topic chips inside topic/show.php cards.
   Design.md §5.3 topic-chip recipe: pill, 4×10 padding, 11/500, copper tint. */
.ts-sc__tag {
  display: inline-flex !important;
  align-items: center !important;
  padding: 4px 10px !important;
  height: 26px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: rgba(232, 122, 53, 0.10) !important;
  border: 1px solid rgba(232, 122, 53, 0.30) !important;
  color: var(--wuc-primary) !important;
  font: 500 11px/1 var(--wuc-font-body) !important;
  text-decoration: none !important;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
  white-space: nowrap;
}
.ts-sc__tag:hover {
  background: rgba(232, 122, 53, 0.16) !important;
  border-color: rgba(232, 122, 53, 0.50) !important;
  color: var(--wuc-primary) !important;
}

/* ============================================================
   Blog hero components — buttons on /blog/{slug} hero band (dark espresso).
   Classes live under .bp2-hero-content. All forced pill + spec weights +
   no transforms per design.md §4, §7.
   Legacy --bp2-copper rebinds to --wuc-primary so related chips/accents
   throughout blog/show.php flow through the design system automatically.
   ============================================================ */
:root {
  --bp2-copper: var(--wuc-primary);
  --bp2-copper-glow: rgba(232, 122, 53, 0.10);
  --bp2-amber: var(--wuc-gold-warm);
  --bp2-teal: var(--wuc-teal);
}

/* .bp2-btn-follow — primary CTA on blog hero (Follow) */
.bp2-btn-follow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px;
  height: 40px !important;
  padding: 0 22px !important;
  background: var(--wuc-primary) !important;
  color: #ffffff !important;
  border: 1px solid var(--wuc-primary) !important;
  border-radius: var(--wuc-r-pill) !important;
  font: 500 14px/1 var(--wuc-font-body) !important;
  text-decoration: none;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.bp2-btn-follow:hover {
  background: var(--wuc-primary-hover) !important;
  border-color: var(--wuc-primary-hover) !important;
  transform: none !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
}
.bp2-btn-follow.is-following {
  background: rgba(255, 255, 255, 0.06) !important;
  color: var(--wuc-cream) !important;
  border: 1px solid rgba(193, 125, 60, 0.35) !important;
  box-shadow: none !important;
}
.bp2-btn-follow.is-following:hover {
  background: rgba(255, 255, 255, 0.12) !important;
  color: #ffffff !important;
  border-color: rgba(193, 125, 60, 0.55) !important;
}

/* .bp2-btn-submit — "Submit post" primary on blog hero */
.bp2-btn-submit {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px;
  height: 40px !important;
  padding: 0 22px !important;
  background: var(--wuc-primary) !important;
  color: #ffffff !important;
  border: 1px solid var(--wuc-primary) !important;
  border-radius: var(--wuc-r-pill) !important;
  font: 500 14px/1 var(--wuc-font-body) !important;
  text-decoration: none;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.bp2-btn-submit:hover {
  background: var(--wuc-primary-hover) !important;
  border-color: var(--wuc-primary-hover) !important;
}

/* .bp2-btn-edit — ghost outline "Edit" / "More" on dark blog hero */
.bp2-btn-edit {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px;
  height: 40px !important;
  padding: 0 22px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  color: var(--wuc-cream) !important;
  border: 1px solid rgba(193, 125, 60, 0.35) !important;
  border-radius: var(--wuc-r-pill) !important;
  font: 500 14px/1 var(--wuc-font-body) !important;
  text-decoration: none;
  cursor: pointer;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.bp2-btn-edit:hover {
  background: rgba(255, 255, 255, 0.14) !important;
  color: #ffffff !important;
  border-color: rgba(193, 125, 60, 0.55) !important;
}

/* .bp2-btn-icon — 40×40 pill icon button on dark hero (bookmark/share/etc.) */
.bp2-btn-icon {
  width: 40px !important;
  height: 40px !important;
  padding: 0 !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(193, 125, 60, 0.25) !important;
  border-radius: var(--wuc-r-pill) !important;
  color: var(--wuc-cream) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer;
  transition: background 150ms ease-out, border-color 150ms ease-out, color 150ms ease-out !important;
}
.bp2-btn-icon:hover {
  background: rgba(255, 255, 255, 0.14) !important;
  color: #ffffff !important;
  border-color: rgba(193, 125, 60, 0.45) !important;
}
.bp2-btn-icon.active {
  background: rgba(232, 122, 53, 0.14) !important;
  color: var(--wuc-primary) !important;
  border-color: rgba(232, 122, 53, 0.45) !important;
}
.bp2-btn-icon svg { width: 16px; height: 16px; stroke-width: 1.75; }

/* .bp2-collab-btn — small "Join collab" chip inside blog hero/cards */
.bp2-collab-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px;
  height: 28px !important;
  padding: 0 12px !important;
  background: rgba(232, 122, 53, 0.10) !important;
  border: 1px solid rgba(232, 122, 53, 0.30) !important;
  color: var(--wuc-primary) !important;
  border-radius: var(--wuc-r-pill) !important;
  font: 500 12px/1 var(--wuc-font-body) !important;
  text-decoration: none;
  cursor: pointer;
  transition: background 150ms ease-out, border-color 150ms ease-out, color 150ms ease-out !important;
}
.bp2-collab-btn:hover {
  background: var(--wuc-primary) !important;
  border-color: var(--wuc-primary) !important;
  color: #ffffff !important;
}
.bp2-collab-btn.is-following,
.bp2-collab-btn.following {
  background: rgba(255, 255, 255, 0.06) !important;
  color: var(--wuc-cream) !important;
  border-color: rgba(193, 125, 60, 0.35) !important;
}
.bp2-collab-btn.is-following:hover,
.bp2-collab-btn.following:hover {
  background: rgba(255, 255, 255, 0.12) !important;
  color: #ffffff !important;
}

/* .bp2-bookmark-btn — inline bookmark toggle inside post-list rows */
.bp2-bookmark-btn:hover { color: var(--wuc-primary) !important; background: transparent !important; }
.bp2-bookmark-btn.saved { color: var(--wuc-primary) !important; }

/* ============================================================
   Topic chips / filter pills — design.md §5.3 unified treatment
   pill radius · 11/500 DM Sans · 12% fill / 30% border / 100% text
   ============================================================ */

/* Blog hero topic chips (.bp2-topic-chip) — dark espresso ancestor */
.bp2-topic-chip {
  display: inline-flex !important;
  align-items: center !important;
  padding: 4px 10px !important;
  height: 26px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: rgba(232, 122, 53, 0.12) !important;
  border: 1px solid rgba(232, 122, 53, 0.35) !important;
  color: var(--wuc-primary) !important;
  font: 500 11px/1 var(--wuc-font-body) !important;
  letter-spacing: 0;
  text-transform: none !important;
  text-decoration: none !important;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.bp2-topic-chip:hover {
  background: rgba(232, 122, 53, 0.20) !important;
  border-color: rgba(232, 122, 53, 0.55) !important;
  color: var(--wuc-primary) !important;
}

/* Sidebar topic chips on blog-show page (.bp2-s-topic) — parchment ancestor */
.bp2-s-topic {
  display: inline-flex !important;
  align-items: center !important;
  padding: 4px 10px !important;
  height: 26px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: rgba(232, 122, 53, 0.10) !important;
  border: 1px solid rgba(232, 122, 53, 0.30) !important;
  color: var(--wuc-primary) !important;
  font: 500 11px/1 var(--wuc-font-body) !important;
  letter-spacing: 0 !important;
  text-decoration: none !important;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.bp2-s-topic:hover {
  background: rgba(232, 122, 53, 0.18) !important;
  border-color: rgba(232, 122, 53, 0.50) !important;
  color: var(--wuc-primary) !important;
}

/* Feed-card topic pill (.feed-card__topic-pill) — shown on feed writeup cards */
.feed-card__topic-pill,
html.app-layout .feed-card__topic-pill {
  display: inline-flex !important;
  align-items: center !important;
  padding: 4px 10px !important;
  height: 24px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: rgba(232, 122, 53, 0.10) !important;
  border: 1px solid rgba(232, 122, 53, 0.30) !important;
  color: var(--wuc-primary) !important;
  font: 500 11px/1 var(--wuc-font-body) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

/* Topic-directory filter pills (.tpc-filter-pill) — parchment ancestor */
.tpc-filter-pill {
  display: inline-flex !important;
  align-items: center !important;
  height: 36px !important;
  padding: 0 16px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: transparent !important;
  border: 1px solid var(--wuc-border-strong) !important;
  color: var(--wuc-fg2) !important;
  font: 500 13px/1 var(--wuc-font-body) !important;
  cursor: pointer;
  transition: background 150ms ease-out, border-color 150ms ease-out, color 150ms ease-out !important;
}
.tpc-filter-pill:hover {
  background: rgba(232, 122, 53, 0.08) !important;
  border-color: var(--wuc-primary) !important;
  color: var(--wuc-primary) !important;
}
.tpc-filter-pill.active {
  background: var(--wuc-primary) !important;
  border-color: var(--wuc-primary) !important;
  color: #ffffff !important;
}

/* Left-rail "Your Topics" pills on /home (.pill — defined in home.css) */
.pill {
  display: inline-flex !important;
  align-items: center !important;
  padding: 4px 12px !important;
  height: 26px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: rgba(232, 122, 53, 0.08) !important;
  border: 1px solid rgba(232, 122, 53, 0.28) !important;
  color: var(--wuc-primary) !important;
  font: 500 12px/1 var(--wuc-font-body) !important;
  text-decoration: none !important;
  transition: background 150ms ease-out, border-color 150ms ease-out !important;
}
.pill:hover,
.pill.on {
  background: rgba(232, 122, 53, 0.14) !important;
  border-color: rgba(232, 122, 53, 0.45) !important;
  color: var(--wuc-primary) !important;
}
.pill.dashed {
  background: transparent !important;
  border: 1px dashed var(--wuc-border-strong) !important;
  color: var(--wuc-fg3) !important;
}
.pill.dashed:hover {
  border-color: var(--wuc-primary) !important;
  color: var(--wuc-primary) !important;
}

/* ============================================================
   Blog hero domain-stats tiles (.bp2-hds-item / .bp2-hds-val / .bp2-hds-label)
   Small DA/Rank/etc. stat cards inside the dark blog hero.
   ============================================================ */
.bp2-hds-item {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(193, 125, 60, 0.22) !important;
  border-radius: var(--wuc-r-md) !important;
  padding: 10px 14px !important;
}
.bp2-hds-val {
  font-family: var(--wuc-font-display) !important;
  font-weight: 700 !important;
  color: var(--wuc-gold-highlight) !important;
}
.bp2-hds-label {
  font-family: var(--wuc-font-body) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: var(--wuc-ls-caps) !important;
  text-transform: uppercase !important;
  color: var(--wuc-cream-muted) !important;
}

/* .dir-hero-btn-primary / .dir-hero-btn-secondary — buttons on the /blogs
   directory hero (dark espresso band). Primary is the orange CTA, secondary
   is a light outline. Per design.md §4 — pill, weight 500, no transforms. */
.dir-hero-btn-primary,
.dir-hero-btn-secondary {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px;
  height: 40px !important;
  padding: 0 22px !important;
  border-radius: var(--wuc-r-pill) !important;
  font: 500 14px/1 var(--wuc-font-body) !important;
  text-decoration: none !important;
  white-space: nowrap;
  cursor: pointer;
  transition: background 150ms ease-out, border-color 150ms ease-out, color 150ms ease-out !important;
}
.dir-hero-btn-primary {
  background: var(--wuc-primary) !important;
  color: #ffffff !important;
  border: 1px solid var(--wuc-primary) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
}
.dir-hero-btn-primary:hover {
  background: var(--wuc-primary-hover) !important;
  border-color: var(--wuc-primary-hover) !important;
  transform: none !important;
}
.dir-hero-btn-primary:active {
  background: var(--wuc-primary-press) !important;
  border-color: var(--wuc-primary-press) !important;
  box-shadow: none !important;
}
.dir-hero-btn-secondary {
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  border: 1px solid rgba(193, 125, 60, 0.35) !important;
}
.dir-hero-btn-secondary:hover {
  background: rgba(255, 255, 255, 0.14) !important;
  border-color: rgba(193, 125, 60, 0.55) !important;
  color: #ffffff !important;
  transform: none !important;
}

/* .bc-visit-btn — "Visit blog" outline chip on blog directory cards */
.bc-visit-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px;
  height: 32px !important;
  padding: 0 14px !important;
  border-radius: var(--wuc-r-pill) !important;
  background: transparent !important;
  color: var(--wuc-primary) !important;
  border: 1px solid var(--wuc-primary) !important;
  font: 500 13px/1 var(--wuc-font-body) !important;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition: background 150ms ease-out !important;
}
.bc-visit-btn:hover {
  background: rgba(232, 122, 53, 0.08) !important;
  color: var(--wuc-primary) !important;
}
.bc-visit-btn:active { background: rgba(232, 122, 53, 0.14) !important; }

/* ============================================================
   .v2e-final — dark espresso base gradient utility.
   Drop onto any full-bleed dark hero/callout section. Pair with
   .wuc-grain for the spec §8.1 glow + vignette overlay.
   Only applies background; layout padding/alignment stays with the host.
   ============================================================ */
.v2e-final {
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(193,125,60,0.20) 0%, rgba(26,15,6,0) 60%),
    linear-gradient(180deg, #1a0f06 0%, #120a04 100%) !important;
}

/* Decorative absolute-positioned children inside hero sections — make sure
   they stay below the .wuc-grain::after vignette. Re-assert absolute pos
   in case a `> *` rule tries to flatten them to relative. */
.cover-grid-bg,
.cover-glow,
.cover-glow-2,
.bp2-hero-cover,
.dir-hero-bg,
.ts-hero-grid-bg,
.ts-hero-glow,
.ts-hero-glow-2 {
  position: absolute !important;
  z-index: -1 !important;
}
/* Drop the grid-line / decorative backgrounds on dark hero decoration layers.
   The .v2e-final + .wuc-grain combo now provides the full hero treatment. */
.cover-grid-bg,
.ts-hero-grid-bg {
  background-image: none !important;
}
.dir-hero-bg,
.bp2-hero-cover {
  background: none !important;
}
/* Hide the corner-glow decorations on the author cover — grain halo replaces them */
.cover-glow,
.cover-glow-2 {
  display: none !important;
}

/* ============================================================
   Site footer — espresso sunken band at the bottom of the app
   ============================================================ */
.site-footer {
  background: var(--wuc-espresso-sunken);
  color: rgba(221, 208, 192, 0.65);
  padding: 32px 24px;
  margin-top: 48px;
  border-top: 1px solid rgba(193, 125, 60, 0.18);
  font-family: var(--wuc-font-body);
}
.site-footer .container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: center;
  text-align: center;
}
.site-footer .footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 22px;
  justify-content: center;
}
.site-footer .footer-links a {
  color: var(--wuc-cream-muted);
  text-decoration: none;
  font: 500 13px/1 var(--wuc-font-body);
  transition: color 150ms ease-out;
}
.site-footer .footer-links a:hover { color: var(--wuc-primary); }
.site-footer .footer-copy {
  font: 400 12px/1.5 var(--wuc-font-body);
  color: rgba(221, 208, 192, 0.45);
}
@media (max-width: 540px) {
  .site-footer { padding: 24px 20px; }
  .site-footer .footer-links { gap: 8px 16px; }
}
