:root {
  /* Keep in sync with packages/shared/src/theme.ts */
  /* Typography */
  --font-family:
    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.85rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --font-size-xl: 1.25rem;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-bold: 700;
  --line-height-tight: 1.25;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.75;

  /* Spacing scale */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;

  /* Border radius */
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 1rem;
  --radius-full: 999px;

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-normal: 200ms ease;
  --transition-slow: 300ms ease;
  --nav-control-color-transition: 500ms ease;
  --nav-control-surface-transition: 200ms cubic-bezier(0.22, 1, 0.36, 1);

  font-family: var(--font-family);
  line-height: var(--line-height-normal);

  /* Light mode is intentionally disabled until it is redesigned. */
  color-scheme: dark;

  /* Three-color palette (+ semantic success/error) */
  --color-ink: #e2e8f0;
  --color-canvas: #0f172a;
  --color-accent: #60a5fa;
  --color-success: #22c55e;
  --color-error: #ef4444;

  --bg-body: var(--color-canvas);
  --bg-panel: color-mix(in srgb, var(--color-canvas) 90%, #000 10%);
  --bg-secondary: color-mix(
    in srgb,
    var(--color-accent) 16%,
    var(--color-canvas) 84%
  );
  --bg-tertiary: color-mix(
    in srgb,
    var(--color-ink) 14%,
    var(--color-canvas) 86%
  );
  --bg-hover: var(--bg-tertiary);
  --bg-input: color-mix(in srgb, var(--color-canvas) 88%, #000 12%);
  --text-primary: var(--color-ink);
  --text-secondary: color-mix(
    in srgb,
    var(--color-ink) 78%,
    var(--color-canvas) 22%
  );
  --text-muted: color-mix(
    in srgb,
    var(--color-ink) 56%,
    var(--color-canvas) 44%
  );
  --text-link: var(--color-accent);
  --accent-primary: var(--color-accent);
  --accent-light: color-mix(
    in srgb,
    var(--color-accent) 24%,
    var(--color-canvas) 76%
  );
  --accent-hover: color-mix(
    in srgb,
    var(--color-accent) 82%,
    var(--color-ink) 18%
  );
  --border-primary: color-mix(
    in srgb,
    var(--color-accent) 30%,
    var(--color-canvas) 70%
  );
  --border-secondary: color-mix(
    in srgb,
    var(--color-ink) 18%,
    var(--color-canvas) 82%
  );
  --shadow-sm: rgba(0, 0, 0, 0.34);
  --shadow-md: rgba(0, 0, 0, 0.44);
  --shadow-lg: rgba(0, 0, 0, 0.54);
  --skeleton-bg: linear-gradient(
    90deg,
    color-mix(in srgb, var(--color-ink) 16%, var(--color-canvas) 84%) 25%,
    color-mix(in srgb, var(--color-canvas) 84%, #000 16%) 50%,
    color-mix(in srgb, var(--color-ink) 16%, var(--color-canvas) 84%) 75%
  );
  --post-bg: var(--bg-secondary);
  --nav-inactive: var(--text-secondary);
  --toast-info: var(--color-accent);
  --toast-success: var(--color-success);
  --toast-error: var(--color-error);
  --tooltip-bg: color-mix(in srgb, var(--bg-panel) 88%, #000 12%);
  --tooltip-border: color-mix(
    in srgb,
    var(--color-accent) 24%,
    var(--color-canvas) 76%
  );
  --tooltip-text: var(--text-primary);
  --badge-bg: color-mix(
    in srgb,
    var(--color-error) 26%,
    var(--color-canvas) 74%
  );
  --badge-text: var(--color-error);
  --flag-badge-bg: var(--accent-light);
  --flag-badge-text: var(--accent-primary);
  --editing-banner-bg: var(--accent-light);
  --editing-banner-text: var(--accent-hover);
  --inline-action: color-mix(
    in srgb,
    var(--color-ink) 44%,
    var(--color-canvas) 56%
  );
  --danger-primary: var(--color-error);
  --danger-hover: color-mix(
    in srgb,
    var(--color-error) 82%,
    var(--color-ink) 18%
  );
  --link-row-bg: var(--bg-secondary);
  --focus-ring: color-mix(
    in srgb,
    var(--color-accent) 72%,
    var(--color-canvas) 28%
  );
  --nav-surface: color-mix(
    in srgb,
    var(--color-accent) 14%,
    var(--color-canvas) 86%
  );
  --profile-link: var(--accent-primary);
  --discussant-link: color-mix(
    in srgb,
    var(--color-accent) 78%,
    var(--color-canvas) 22%
  );
  --star-vote: var(--accent-primary);
  --star-vote-hover: #fbbf24;
  --star-vote-active: #fbbf24;
  --star-vote-active-hover: #fbbf24;
  --hit-target-min: 44px;
  --nav-scale: 0.8;
  --nav-hit-target: calc(var(--hit-target-min) * var(--nav-scale));
  --post-time-col-width: 5.75rem;
  --content-shell-width: 700px;
  --panel-inline-padding: var(--space-md);

  /* Textarea */
  --textarea-bg: var(--bg-panel);
  --textarea-border: var(--border-primary);
  --textarea-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.22);

  /* Avatar colors */
  --avatar-blue: var(--color-accent);
  --avatar-green: color-mix(
    in srgb,
    var(--color-accent) 74%,
    var(--color-ink) 26%
  );
  --avatar-purple: color-mix(
    in srgb,
    var(--color-ink) 58%,
    var(--color-canvas) 42%
  );
  --avatar-orange: color-mix(
    in srgb,
    var(--color-accent) 36%,
    var(--color-ink) 64%
  );
}

body {
  margin: 0;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  background-color: var(--bg-body);
  background-image:
    linear-gradient(
      180deg,
      color-mix(in srgb, #000 24%, transparent) 0,
      transparent 24rem
    ),
    radial-gradient(
      circle at 50% 18%,
      color-mix(in srgb, var(--color-accent) 3%, transparent) 0,
      transparent 24rem
    ),
    url("/background-network.svg"),
    radial-gradient(
      circle,
      color-mix(in srgb, var(--color-ink) 10%, transparent) 0.75px,
      transparent 1.3px
    );
  background-repeat: no-repeat, no-repeat, no-repeat, repeat;
  background-position:
    center top,
    center 1rem,
    center 2rem,
    center top;
  background-size:
    100% 28rem,
    100% 24rem,
    min(1320px, 106vw) auto,
    22px 22px;
  color: var(--text-primary);
}

@media (max-width: 900px) {
  body {
    background-position:
      center top,
      center top,
      center 4rem,
      center top;
    background-size:
      100% 22rem,
      100% 20rem,
      min(920px, 138vw) auto,
      20px 20px;
  }
}

/* Hide visible scrollbars globally (content still scrolls). */
* {
  scrollbar-width: none;
  -ms-overflow-style: none;
}

*::-webkit-scrollbar {
  width: 0;
  height: 0;
}

.static-panel {
  width: var(--content-shell-width);
  margin: 0 auto;
  padding: var(--space-xl) var(--panel-inline-padding)
    calc(var(--space-lg) + var(--space-sm));
}

/* Homepage: center content ~1/3 down the page */
.static-panel[data-route-view="share"] {
  --share-form-width: 25.35rem;
  --share-control-height: 2.36rem;
  --share-input-font-size: 0.94rem;
  --share-submit-min-width: 6.75rem;
  --inline-discuss-control-height: var(--share-control-height);
  --inline-discuss-input-font-size: var(--share-input-font-size);
  --inline-discuss-submit-min-width: var(--share-submit-min-width);
  display: flex;
  flex: 1 0 auto;
  flex-direction: column;
  justify-content: center;
  padding-bottom: clamp(11rem, 28vh, 15rem);
}

.static-panel[data-route-view="share"] #link-form {
  width: min(100%, var(--share-form-width));
  margin: 0 auto;
  align-items: stretch;
}

.static-panel[data-route-view="share"] #link-form > .field {
  width: 100%;
  align-items: stretch;
}

.static-panel[data-route-view="share"] .share-url-field {
  gap: 0.55rem;
}

.static-panel[data-route-view="share"] .inline-discuss-field,
.command-palette-context.is-discuss .inline-discuss-field {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  width: 100%;
  box-sizing: border-box;
  padding: 0.34rem 0.36rem 0.34rem 0.95rem;
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--bg-input) 90%, var(--bg-panel) 10%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 12px 28px rgba(2, 6, 23, 0.1);
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast);
}

.static-panel[data-route-view="share"] .inline-discuss-field,
.command-palette-context.is-discuss .inline-discuss-field {
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 8%,
    var(--border-secondary) 92%
  );
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 4%, transparent 96%),
    0 12px 28px rgba(2, 6, 23, 0.1);
}

.static-panel[data-route-view="share"] .inline-discuss-field,
.command-palette-context.is-discuss .inline-discuss-field {
  background: color-mix(in srgb, var(--bg-input) 96%, var(--accent-primary) 4%);
}

.static-panel[data-route-view="share"] .inline-discuss-field:focus-within,
.command-palette-context.is-discuss .inline-discuss-field:focus-within {
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 12%,
    var(--border-secondary) 88%
  );
  background: color-mix(in srgb, var(--bg-input) 90%, var(--bg-panel) 10%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 10%, transparent 90%),
    0 12px 28px rgba(2, 6, 23, 0.12);
}

.static-panel[data-route-view="share"]
  .inline-discuss-field
  > input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
.command-palette-context.is-discuss
  .inline-discuss-field
  > input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
  appearance: none;
  -webkit-appearance: none;
  flex: 1 1 auto;
  width: 100%;
  max-width: none;
  min-width: 0;
  min-height: var(--inline-discuss-control-height);
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: var(--text-primary);
  font-size: var(--inline-discuss-input-font-size);
  line-height: 1.2;
  text-align: left;
  caret-color: color-mix(
    in srgb,
    var(--text-muted) 78%,
    var(--text-primary) 22%
  );
  opacity: 1;
  transition: color var(--transition-fast);
}

.static-panel[data-route-view="share"]
  .inline-discuss-field
  > input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):hover,
.command-palette-context.is-discuss
  .inline-discuss-field
  > input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover {
  opacity: 1;
}

.static-panel[data-route-view="share"]
  .inline-discuss-field
  > input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):focus,
.command-palette-context.is-discuss
  .inline-discuss-field
  > input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus {
  outline: none;
}

.static-panel[data-route-view="share"]
  .inline-discuss-field
  > input::placeholder,
.command-palette-context.is-discuss .inline-discuss-field > input::placeholder {
  color: var(--text-muted);
  font-size: inherit;
  font-style: normal;
  line-height: 1.2;
}

.static-panel[data-route-view="share"] .inline-discuss-field > button,
.command-palette-context.is-discuss .inline-discuss-field > button {
  flex: 0 0 auto;
  min-width: var(--inline-discuss-submit-min-width);
  min-height: var(--inline-discuss-control-height);
  padding: 0.52rem 0.98rem;
  border-radius: var(--radius-full);
  font-size: 0.85rem;
  font-weight: var(--font-weight-medium);
  line-height: 1;
  white-space: nowrap;
  background: var(--accent-primary);
  color: #fff;
  transition:
    background var(--transition-fast),
    opacity var(--transition-fast);
}

.static-panel[data-route-view="share"] .inline-discuss-field > button:hover,
.static-panel[data-route-view="share"]
  .inline-discuss-field
  > button:focus-visible,
.command-palette-context.is-discuss .inline-discuss-field > button:hover,
.command-palette-context.is-discuss
  .inline-discuss-field
  > button:focus-visible {
  opacity: 1;
  background: var(--accent-hover);
}

.static-panel[data-route-view="share"]
  .inline-discuss-field
  > button:focus-visible,
.command-palette-context.is-discuss
  .inline-discuss-field
  > button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--focus-ring) 42%, transparent);
  outline-offset: 1px;
}

@media (max-width: 732px) {
  .static-panel {
    width: 100%;
    min-width: 0;
  }
}

.panel-title {
  margin: 0 0 var(--space-lg);
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.02em;
  color: var(--text-primary);
  text-align: center;
}

[data-route-view="share"] > .panel-title {
  font-size: clamp(1.82rem, 3.8vw, 2.48rem);
  letter-spacing: -0.035em;
}

[data-route-view="feed"] > .panel-title {
  opacity: var(--feed-title-opacity, 1);
  transition: opacity 260ms cubic-bezier(0.22, 1, 0.36, 1);
}

.top-bar {
  position: sticky;
  top: 0;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: auto 1fr auto;
  width: min(
    var(--content-shell-width),
    calc(100% - (2 * var(--panel-inline-padding)))
  );
  margin: 0 auto;
  align-items: center;
  gap: calc(0.45rem * var(--nav-scale));
  padding-block: calc(0.62rem * var(--nav-scale))
    calc(0.66rem * var(--nav-scale));
  padding-inline: calc(1.25rem * var(--nav-scale));
  background: transparent;
  box-shadow: none;
  pointer-events: none;
  z-index: 10;
}

.master-filter-wrap {
  position: relative;
}

.master-filter-wrap.is-disabled {
  pointer-events: none;
  opacity: 0.45;
}

.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 12px);
  min-width: 140px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-secondary);
  background: var(--bg-panel);
  box-shadow: 0 4px 12px var(--shadow-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  z-index: 100;
}

.nav-dropdown-menu[hidden] {
  display: none;
}

.nav-dropdown-item {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 100%;
  height: calc(var(--hit-target-min) + 6px);
  min-height: calc(var(--hit-target-min) + 6px);
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  appearance: none;
  color: var(--text-primary);
  text-align: center;
  white-space: nowrap;
  line-height: 1;
  font-family: inherit;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  text-decoration: none;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.nav-dropdown-item:visited {
  color: var(--text-primary);
}

.nav-dropdown-item:hover,
.nav-dropdown-item:focus-visible {
  background: var(--bg-tertiary);
}

.nav-dropdown-item[hidden] {
  display: none;
}

.brand {
  display: flex;
  align-items: center;
  min-height: var(--hit-target-min);
  gap: var(--space-sm);
  margin-right: 0.4rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.02em;
  border: none;
  background: transparent;
  color: inherit;
  cursor: pointer;
  text-decoration: none;
}

.logo-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent-primary);
  display: inline-block;
}

.account-wrap {
  display: flex;
  align-items: center;
  gap: calc(0.4rem * var(--nav-scale));
  grid-column: 3;
  justify-self: end;
}

/* User menu dropdown */
.user-menu {
  position: relative;
}

.user-menu-trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(var(--nav-hit-target) + 6px);
  height: calc(var(--nav-hit-target) + 6px);
  padding: 0;
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text-secondary);
  box-shadow: none;
  cursor: pointer;
  transition:
    color var(--nav-control-color-transition),
    background-color var(--nav-control-surface-transition),
    box-shadow var(--nav-control-surface-transition);
}

.user-menu-trigger:not([aria-expanded="true"]):hover {
  color: var(--text-primary);
  background-color: var(--bg-tertiary);
}

.user-menu-trigger[aria-expanded="true"] {
  background-color: var(--accent-primary);
  color: #fff;
  box-shadow: 0 1px 3px var(--shadow-md);
}

.user-menu-trigger svg {
  width: calc((20px * var(--nav-scale)) + 3px);
  height: calc((20px * var(--nav-scale)) + 3px);
}

.notifications-btn svg {
  width: calc((20px * var(--nav-scale)) + 3px);
  height: calc((20px * var(--nav-scale)) + 3px);
}

.user-menu-dropdown {
  right: 0;
  top: auto;
  bottom: calc(100% + 12px);
}

.user-menu-item {
  color: var(--text-primary);
}

.user-menu-item[hidden] {
  display: none;
}

/* Notifications dropdown */
.notifications-wrap {
  position: relative;
}

.notifications-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(var(--nav-hit-target) + 6px);
  height: calc(var(--nav-hit-target) + 6px);
  padding: 0;
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text-secondary);
  box-shadow: none;
  cursor: pointer;
  transition:
    color var(--nav-control-color-transition),
    background-color var(--nav-control-surface-transition),
    box-shadow var(--nav-control-surface-transition);
  position: relative;
}

.notifications-btn:not([aria-expanded="true"]):hover {
  color: var(--text-primary);
  background-color: var(--bg-tertiary);
}

.notifications-btn[aria-expanded="true"] {
  background-color: var(--accent-primary);
  color: #fff;
  box-shadow: 0 1px 3px var(--shadow-md);
}

.notifications-badge {
  position: absolute;
  top: -2px;
  right: -2px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  background: var(--danger-primary);
  color: #fff;
  font-size: 10px;
  font-weight: var(--font-weight-bold);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.notifications-badge[hidden] {
  display: none;
}

.notifications-dropdown {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  width: 320px;
  max-height: 400px;
  background: var(--bg-panel);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-md);
  box-shadow: 0 4px 12px var(--shadow-md);
  overflow: hidden;
  z-index: 100;
  display: flex;
  flex-direction: column;
}

.notifications-dropdown[hidden] {
  display: none;
}

.notifications-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--border-secondary);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-sm);
}

#notifications-mark-all {
  margin-left: auto;
}

.notifications-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  min-width: 1.9rem;
  min-height: 1.9rem;
  padding: 0.2rem;
  background: transparent;
  border: none;
  border-radius: 999px;
  color: var(--accent-primary);
  cursor: pointer;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    opacity var(--transition-fast);
}

.notifications-action-btn svg {
  width: 0.95rem;
  height: 0.95rem;
  display: block;
}

.notifications-action-btn:hover,
.notifications-action-btn:focus-visible {
  opacity: 1;
  color: var(--text-primary);
  background: color-mix(in srgb, var(--accent-primary) 12%, transparent);
}

.notifications-action-btn:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 1px;
}

.notifications-list {
  list-style: none;
  margin: 0;
  padding: 0;
  overflow-y: auto;
  max-height: 340px;
}

.notifications-empty {
  padding: var(--space-xl);
  text-align: center;
  color: var(--text-muted);
  font-size: var(--font-size-sm);
}

.notification-item {
  display: flex;
  gap: var(--space-sm);
  min-height: var(--hit-target-min);
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--border-secondary);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.notification-item:last-child {
  border-bottom: none;
}

.notification-item:hover {
  background: var(--bg-tertiary);
}

.notification-item.unread {
  background: var(--accent-light);
}

.notification-item.unread:hover {
  background: var(--bg-secondary);
}

.notification-avatar {
  flex-shrink: 0;
}

.profile-avatar-wrap.notification-avatar {
  width: 36px;
  height: 36px;
  border-radius: 0.75rem;
  overflow: hidden;
}

.profile-avatar-wrap.notification-avatar .profile-avatar-initial {
  font-size: 0.95rem;
  line-height: 1;
}

.notification-content {
  flex: 1;
  min-width: 0;
}

.notification-message {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  line-height: var(--line-height-tight);
}

.notification-context {
  margin: var(--space-xs) 0 0;
  font-size: var(--font-size-xs);
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.notification-time {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

.notification-skeleton {
  cursor: default;
  pointer-events: none;
}

.notification-skeleton:hover,
.notification-skeleton.unread,
.notification-skeleton.unread:hover {
  background: transparent;
}

.notification-skeleton-avatar {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 0.75rem;
}

.notification-skeleton-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-xs);
}

.notification-skeleton-content .skeleton-line {
  margin: 0;
}

.notification-skeleton-content .skeleton-line.tiny {
  width: 28%;
}

.notification-loading,
.notification-error {
  padding: var(--space-lg);
  text-align: center;
  color: var(--text-muted);
  font-size: var(--font-size-sm);
}

.notification-error {
  color: var(--danger-primary);
}

/* Mobile responsive for notifications */
@media (max-width: 480px) {
  .notifications-dropdown {
    position: fixed;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    max-height: 60vh;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  }
}

.nav-segment-shell {
  --nav-capsule-radius: var(--radius-full);
  --nav-segment-inset: calc(0.08rem * var(--nav-scale));
  --nav-segment-gap: calc(0.03rem * var(--nav-scale));
  --nav-active-inset-block: var(--nav-segment-inset);
  --nav-active-inset-inline: calc(0.025rem * var(--nav-scale));
  display: flex;
  position: relative;
  align-items: center;
  gap: var(--nav-segment-gap);
  padding: var(--nav-segment-inset);
  border-radius: var(--nav-capsule-radius);
  border: 1px solid var(--border-primary);
  background: color-mix(
    in srgb,
    var(--color-canvas) 78%,
    var(--color-accent) 22%
  );
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 70%, transparent);
}

.main-nav {
  --main-nav-outer-pad: calc(0.69rem * var(--nav-scale));
  --main-nav-inner-pad: calc(0.28rem * var(--nav-scale));
  --main-nav-active-edge-inset: calc(0.025rem * var(--nav-scale));
  --main-nav-active-inner-trim: calc(0.225rem * var(--nav-scale));
  margin: 0;
  grid-column: 1;
  justify-self: start;
  padding: 0;
  gap: var(--nav-segment-gap);
}

.main-nav .nav-control-btn {
  z-index: 0;
  padding-inline-start: var(--main-nav-inner-pad);
  padding-inline-end: var(--main-nav-inner-pad);
  transition:
    color var(--nav-control-color-transition),
    background-color var(--nav-control-surface-transition),
    box-shadow var(--nav-control-surface-transition);
}

.main-nav .nav-control-btn:first-child {
  padding-inline-start: var(--main-nav-outer-pad);
  --nav-active-inset-inline-start: var(--main-nav-active-edge-inset);
  --nav-active-inset-inline-end: calc(
    var(--main-nav-active-edge-inset) -
      (var(--main-nav-outer-pad) - var(--main-nav-inner-pad)) +
      var(--main-nav-active-inner-trim)
  );
}

.main-nav .nav-control-btn:last-child {
  padding-inline-end: var(--main-nav-outer-pad);
  --nav-active-inset-inline-start: calc(
    var(--main-nav-active-edge-inset) -
      (var(--main-nav-outer-pad) - var(--main-nav-inner-pad)) +
      var(--main-nav-active-inner-trim)
  );
  --nav-active-inset-inline-end: var(--main-nav-active-edge-inset);
}

.account-nav-shell {
  padding: 0;
}

.account-nav-shell .nav-control-btn {
  width: 100%;
  transition:
    color var(--nav-control-color-transition),
    background-color var(--nav-control-surface-transition),
    box-shadow var(--nav-control-surface-transition);
}

.top-bar .main-nav,
.top-bar .account-wrap,
.top-bar .top-bar-dev-wrap {
  opacity: var(--top-bar-controls-opacity, 1);
  transition: opacity 260ms cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: auto;
  transform: translateY(8px);
}

.top-bar .top-bar-settings-wrap {
  opacity: var(--floating-settings-opacity, 1);
  transition: opacity 260ms cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: auto;
}

body[data-startup-pending="true"] .top-bar .main-nav,
body[data-startup-pending="true"] .top-bar .account-wrap,
body[data-startup-pending="true"] .top-bar .top-bar-settings-wrap,
body[data-startup-pending="true"] .top-bar .top-bar-dev-wrap,
body[data-startup-pending="true"] [data-route-view="feed"] > .panel-title {
  transition: none !important;
}

.top-bar[data-controls-hidden="true"] .main-nav,
.top-bar[data-controls-hidden="true"] .account-wrap,
.top-bar[data-controls-hidden="true"] .top-bar-dev-wrap {
  pointer-events: none;
  visibility: hidden;
}

.top-bar[data-settings-hidden="true"] .top-bar-settings-wrap {
  pointer-events: none;
  visibility: hidden;
}

html[data-startup-controls-hidden="true"]
  body[data-startup-pending="true"]
  .top-bar
  .main-nav,
html[data-startup-controls-hidden="true"]
  body[data-startup-pending="true"]
  .top-bar
  .account-wrap,
html[data-startup-controls-hidden="true"]
  body[data-startup-pending="true"]
  .top-bar
  .top-bar-dev-wrap {
  pointer-events: none;
  visibility: hidden;
}

html[data-startup-settings-hidden="true"]
  body[data-startup-pending="true"]
  .top-bar
  .top-bar-settings-wrap {
  pointer-events: none;
  visibility: hidden;
}

.top-bar-settings-wrap {
  --floating-settings-corner-gap: 0.75rem;
  --floating-settings-corner-nudge: calc(var(--nav-hit-target) * 0.1);
  position: fixed;
  right: calc(
    env(safe-area-inset-right, 0px) + var(--floating-settings-corner-gap) +
      var(--floating-settings-corner-nudge)
  );
  bottom: calc(
    env(safe-area-inset-bottom, 0px) + var(--floating-settings-corner-gap) +
      var(--floating-settings-corner-nudge)
  );
  z-index: 20;
}

.top-bar-dev-wrap {
  position: fixed;
  left: env(safe-area-inset-left, 0px);
  bottom: env(safe-area-inset-bottom, 0px);
  z-index: 20;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  width: 4.5rem;
  height: 4.5rem;
}

.top-bar .top-bar-dev-wrap {
  transform: none;
}

.nav-control-btn {
  display: inline-flex;
  position: relative;
  isolation: isolate;
  align-items: center;
  justify-content: center;
  min-height: var(--nav-hit-target);
  text-decoration: none;
  font-weight: var(--font-weight-medium);
  font-size: calc(var(--font-size-base) * var(--nav-scale));
  color: var(--nav-inactive);
  background: transparent;
  border: none;
  box-shadow: none;
  padding: calc(0.36rem * var(--nav-scale)) calc(0.86rem * var(--nav-scale));
  line-height: 1;
  border-radius: var(--nav-capsule-radius);
  gap: calc(0.4rem * var(--nav-scale));
  transition:
    color var(--transition-fast),
    background-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

.nav-control-btn::before {
  content: "";
  position: absolute;
  inset-block: var(--nav-active-inset-block);
  inset-inline-start: var(
    --nav-active-inset-inline-start,
    var(--nav-active-inset-inline)
  );
  inset-inline-end: var(
    --nav-active-inset-inline-end,
    var(--nav-active-inset-inline)
  );
  border-radius: inherit;
  background-color: var(--accent-primary);
  box-shadow: 0 1px 3px var(--shadow-md);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity var(--nav-control-surface-transition),
    box-shadow var(--nav-control-surface-transition);
  z-index: -1;
}

.nav-control-btn:not(.active):hover {
  color: var(--text-primary);
}

.nav-control-btn.active {
  background-color: transparent;
  color: #fff;
  box-shadow: none;
}

.main-nav .nav-control-btn.active {
  z-index: 1;
}

.nav-control-btn.active::before {
  opacity: 1;
}

.nav-control-btn:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 1px;
}

.dev-btn {
  background: var(--danger-primary);
  color: #fff;
  border: none;
  min-height: var(--hit-target-min);
  padding: 0.3rem 0.75rem;
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translate(-0.55rem, 0.35rem);
  transition:
    opacity 160ms ease,
    transform 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.top-bar-dev-wrap:hover .dev-btn,
.top-bar-dev-wrap:focus-within .dev-btn {
  opacity: 0.8;
  pointer-events: auto;
  transform: translate(0, 0);
}

.dev-btn:hover {
  opacity: 1;
}

.signed-in-info {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.account-panel {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.signed-message {
  font-weight: 600;
}

.landing {
  max-width: 700px;
  margin: 0 auto;
  width: min(700px, 95vw);
  padding: var(--space-xl) var(--space-md) var(--space-2xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

body[data-route="discussion"] .landing {
  display: none;
}

body[data-route="profile"] .landing,
body[data-route="following"] .landing {
  display: none;
}

.flag-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.15rem 0.6rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  background: var(--badge-bg);
  color: var(--badge-text);
}

.hero {
  text-align: center;
}

.hero h1 {
  margin-bottom: 0.25rem;
  font-size: clamp(2.5rem, 4vw, 3.2rem);
  letter-spacing: -0.04em;
}

.panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
}

form {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.field-error,
.status-message {
  margin: 0;
  min-height: 1rem;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

.field-error,
.status-message[data-variant="error"] {
  color: var(--danger-primary);
}

.status-message[data-variant="success"] {
  color: var(--toast-success);
}

label {
  font-weight: 600;
}

input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
  border: 1px solid var(--border-primary);
  border-radius: 999px;
  padding: 0.28rem 0.8rem;
  font-family: inherit;
  font-size: 1rem;
  background: var(--bg-input);
  color: var(--text-primary);
  transition: opacity var(--transition-fast);
  min-height: 1.9rem;
}

input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):hover {
  opacity: 0.7;
}

input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):focus {
  outline: none;
}

input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  )::placeholder,
textarea::placeholder {
  font-family: inherit;
  font-size: var(--font-size-sm);
}

.static-panel[data-route-view="share"] #url-error {
  width: 100%;
  text-align: center;
}

@media (max-width: 520px) {
  .static-panel[data-route-view="share"] .inline-discuss-field {
    gap: 0.32rem;
    padding-left: 0.82rem;
    padding-right: 0.28rem;
  }

  .static-panel[data-route-view="share"] .inline-discuss-field > button {
    min-width: 5.75rem;
    padding-left: 0.82rem;
    padding-right: 0.82rem;
  }
}

.auth-modal-content
  input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
  min-height: 2.1rem;
  padding: 0.34rem 0.85rem;
  font-size: 1.05rem;
}

button {
  border: none;
  border-radius: 999px;
  background: var(--accent-primary);
  color: #fff;
  padding: 0.75rem 1.5rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity var(--transition-fast);
  min-height: var(--hit-target-min);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

[hidden] {
  display: none !important;
}

html[data-startup-route="share"]
  body[data-startup-pending="true"]
  [data-route-view="share"][hidden] {
  display: flex !important;
}

html[data-startup-route="feed"]
  body[data-startup-pending="true"]
  [data-route-view="feed"][hidden],
html[data-startup-route="about"]
  body[data-startup-pending="true"]
  [data-route-view="about"][hidden],
html[data-startup-route="terms"]
  body[data-startup-pending="true"]
  [data-route-view="terms"][hidden],
html[data-startup-route="privacy"]
  body[data-startup-pending="true"]
  [data-route-view="privacy"][hidden],
html[data-startup-route="extensions"]
  body[data-startup-pending="true"]
  [data-route-view="extensions"][hidden],
html[data-startup-route="settings"]
  body[data-startup-pending="true"]
  [data-route-view="settings"][hidden],
html[data-startup-route="profile"]
  body[data-startup-pending="true"]
  [data-route-view="profile"][hidden],
html[data-startup-route="discussion"]
  body[data-startup-pending="true"]
  [data-route-view="discussion"][hidden],
html[data-startup-route="moderation"]
  body[data-startup-pending="true"]
  [data-route-view="moderation"][hidden] {
  display: block !important;
}

html[data-startup-signed-in="true"]
  body[data-startup-pending="true"]
  #notifications-wrap[hidden] {
  display: block !important;
}

select {
  min-height: 1.9rem;
  border: 1px solid var(--border-primary);
  border-radius: 999px;
  padding: 0.28rem 0.8rem;
  font-size: 1rem;
  background: var(--bg-input);
  color: var(--text-primary);
  transition: opacity var(--transition-fast);
}

select:hover {
  opacity: 0.7;
}

select:focus {
  outline: none;
}

button:hover {
  opacity: 0.85;
}

#submit-link-btn,
#post-submit-btn,
#waitlist-submit-btn {
  transition: background var(--transition-fast);
}

#submit-link-btn:hover,
#post-submit-btn:hover,
#waitlist-submit-btn:hover {
  opacity: 1;
  background: var(--accent-hover);
}

button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

button:disabled:hover {
  opacity: 0.6;
}

/* Button loading spinner */
@keyframes btn-spin {
  to {
    transform: rotate(360deg);
  }
}

button.is-loading {
  position: relative;
  color: transparent;
  pointer-events: none;
}

button.is-loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1rem;
  height: 1rem;
  margin: -0.5rem 0 0 -0.5rem;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: btn-spin 0.6s linear infinite;
}

.ghost-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--accent-primary);
  min-height: var(--hit-target-min);
  padding: 0.35rem 0.6rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
}

.ghost-btn.danger {
  color: var(--danger-primary);
}

.links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.links:empty {
  display: none;
}

.link-row {
  background: var(--link-row-bg);
  border-radius: 0.85rem;
  padding: 0.78rem 0.86rem 0.82rem;
  display: flex;
  gap: 0.7rem;
  align-items: flex-start;
  cursor: pointer;
  position: relative;
}

/* Star button positioned top-right on link cards */
.link-row .star-link-btn {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
}

.link-row:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

.link-url {
  font-weight: 600;
  text-decoration: none;
  color: var(--text-link);
  align-self: flex-start;
  display: inline-flex;
}

.link-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.meta {
  font-size: 0.8rem;
  color: var(--text-secondary);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
  row-gap: 0.2rem;
}

.post-count {
  color: var(--text-secondary);
}

.link-meta-actions {
  display: flex;
  gap: 0.35rem;
  margin-left: auto;
  align-items: center;
  padding-left: 0.15rem;
}

.link-inline-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  min-height: var(--hit-target-min);
  padding: 0.35rem 0.6rem;
  margin: 0;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.link-inline-action:hover,
.link-inline-action:focus-visible {
  opacity: 0.7;
}

.link-inline-action.danger {
  color: var(--text-muted);
}

.link-inline-action.danger:hover,
.link-inline-action.danger:focus-visible {
  opacity: 0.7;
}

.list-state:not(:empty) {
  padding: var(--space-lg) 0;
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  text-align: center;
}

.empty-state {
  box-sizing: border-box;
  width: min(100%, 40rem);
  min-height: 10rem;
  margin: 0 auto;
  padding: 1.1rem 1rem;
  border-radius: var(--radius-lg);
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 0.45rem;
  text-align: center;
}

#list-state .empty-state {
  min-height: 8.25rem;
  padding: 0.85rem 1rem;
}

.empty-state.empty-state-compact {
  min-height: 8.5rem;
}

.empty-state-eyebrow,
.empty-state-title,
.empty-state-body {
  margin: 0;
}

.empty-state-eyebrow {
  font-size: var(--font-size-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.empty-state-title {
  max-width: 28rem;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  line-height: var(--line-height-tight);
}

.empty-state-body {
  max-width: 32rem;
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  line-height: var(--line-height-normal);
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

#post-form .form-actions {
  justify-content: center;
  margin: 0;
}

.form-actions button {
  flex: 1;
  min-width: 140px;
}

#post-form .form-actions #post-submit-btn {
  flex: 0 0 auto;
  min-width: 204px;
  min-height: 2.1rem;
  padding-top: 0.42rem;
  padding-bottom: 0.42rem;
  padding-left: 1rem;
  padding-right: 1rem;
  border-radius: 999px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1.1;
}

#post-form .form-actions #post-submit-btn.load-more-btn {
  min-width: auto;
  min-height: 2.1rem;
  padding: 0.42rem 0.82rem;
  border: 1px solid transparent;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--text-muted);
  font-weight: var(--font-weight-medium);
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast);
}

#post-form .form-actions #post-submit-btn.load-more-btn:hover,
#post-form .form-actions #post-submit-btn.load-more-btn:focus-visible,
#post-form .form-actions #post-submit-btn.load-more-btn:active {
  border-color: var(--accent-primary);
  background: transparent;
  color: var(--accent-primary);
}

.form-actions.stacked {
  flex-direction: column;
}

.account-panel button {
  width: 100%;
}

.toast-stack {
  position: fixed;
  top: 1rem;
  right: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  z-index: 150;
}

.toast {
  min-width: 240px;
  max-width: 320px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  box-shadow: 0 10px 25px var(--shadow-lg);
  color: #fff;
  font-size: 0.95rem;
  animation: toast-enter 150ms ease-out;
}

.toast-info {
  background: var(--toast-info);
}

.toast-success {
  background: var(--toast-success);
}

.toast-error {
  background: var(--toast-error);
}

.toast-action {
  border: none;
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
  border-radius: 999px;
  padding: 0.35rem 0.75rem;
  cursor: pointer;
  font-weight: 600;
}

.toast-close {
  border: none;
  background: transparent;
  color: inherit;
  font-size: 1.1rem;
  cursor: pointer;
  padding: 0.25rem;
}

@keyframes toast-enter {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.toast-leave {
  animation: toast-leave 150ms ease-in forwards;
}

.sort-controls {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
}

.sort-controls.feed-sort-filter {
  width: calc(100% - 2.4rem);
  max-width: 100%;
  min-width: 0;
}

.feed-card {
  position: relative;
}

.discussion-card {
  position: relative;
}

.feed-refresh-btn,
.discussion-header-icon-btn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 1.45rem;
  min-width: 1.45rem;
  min-height: 1.45rem;
  padding: 0.1rem;
  border: none;
  background: transparent;
  color: color-mix(in srgb, var(--accent-hover) 88%, #fff 12%);
  transition:
    transform 180ms ease,
    color var(--transition-fast),
    opacity var(--transition-fast);
}

.feed-refresh-btn {
  position: absolute;
}

.discussion-header-icon-btn {
  position: relative;
  top: auto;
  right: auto;
}

.feed-refresh-btn:hover,
.feed-refresh-btn:focus-visible,
.discussion-header-icon-btn:hover,
.discussion-header-icon-btn:focus-visible,
.discussion-header-icon-btn[aria-expanded="true"] {
  opacity: 1;
  color: var(--text-primary);
}

.feed-refresh-btn[aria-disabled="true"],
.discussion-header-icon-btn[aria-disabled="true"] {
  cursor: default;
}

.feed-refresh-btn svg,
.discussion-header-icon-btn svg {
  width: 0.82rem;
  height: 0.82rem;
  display: block;
}

.feed-refresh-btn[data-refresh-state="loading"] svg,
.discussion-refresh-btn[data-refresh-state="loading"] svg {
  animation: feed-refresh-spin 720ms linear infinite;
}

.feed-refresh-btn[data-refresh-state="updated"],
.discussion-refresh-btn[data-refresh-state="updated"] {
  color: var(--text-primary);
}

.feed-refresh-btn[data-refresh-state="updated"] svg,
.discussion-refresh-btn[data-refresh-state="updated"] svg {
  transform: rotate(180deg);
}

.feed-refresh-btn[data-refresh-state="unchanged"],
.discussion-refresh-btn[data-refresh-state="unchanged"] {
  color: var(--text-secondary);
}

@keyframes feed-refresh-spin {
  to {
    transform: rotate(360deg);
  }
}

.feed-master-filter {
  display: flex;
  position: relative;
  margin-bottom: 0.75rem;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  --feed-search-gap: 0.4rem;
  --feed-search-compact-width: 3.75rem;
}

.feed-master-filter .master-filter-group {
  display: inline-flex;
  flex: 1 1 auto;
  gap: 0.4rem;
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  flex-wrap: nowrap;
  padding-right: calc(
    var(--feed-search-compact-width) + var(--feed-search-gap)
  );
  padding-bottom: 0.2rem;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}

.feed-master-filter .master-filter-group::-webkit-scrollbar {
  display: none;
}

.feed-master-filter .master-filter-option.sort-btn,
.feed-sort-filter .sort-btn[data-sort],
.master-filter-option.sort-btn.is-dragging,
.sort-btn[data-sort].is-dragging {
  flex: 0 0 auto;
  white-space: nowrap;
  border-radius: var(--radius-md);
  --feed-category-drag-x: 0px;
  --feed-category-drag-y: 0px;
  --feed-category-drag-scale: 1;
  transform: translate3d(
      var(--feed-category-drag-x),
      var(--feed-category-drag-y),
      0
    )
    scale(var(--feed-category-drag-scale));
  transform-origin: center center;
  transition:
    transform 140ms ease,
    opacity var(--transition-fast),
    box-shadow 140ms ease;
}

.feed-sort-filter .feed-sort-group {
  display: inline-flex;
  flex: 1 1 auto;
  gap: 0.5rem;
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  flex-wrap: nowrap;
  padding-bottom: 0.2rem;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}

.feed-sort-filter .feed-sort-group::-webkit-scrollbar {
  display: none;
}

.feed-master-filter .master-filter-option.sort-btn[data-reorderable="true"],
.feed-sort-filter .sort-btn[data-sort][data-reorderable="true"] {
  user-select: none;
}

.feed-master-filter
  .master-filter-group.is-reorder-armed
  .master-filter-option.sort-btn[data-reorderable="true"],
.feed-sort-filter
  .feed-sort-group.is-reorder-armed
  .sort-btn[data-sort][data-reorderable="true"] {
  cursor: grab;
}

.feed-master-filter.is-disabled
  .master-filter-option.sort-btn[data-reorderable="true"] {
  cursor: default;
}

.feed-master-filter .master-filter-group.is-reordering,
.feed-sort-filter .feed-sort-group.is-reordering {
  cursor: grabbing;
}

.feed-master-filter
  .master-filter-group.is-reordering
  .master-filter-option.sort-btn:not(.is-dragging),
.feed-sort-filter
  .feed-sort-group.is-reordering
  .sort-btn[data-sort]:not(.is-dragging) {
  opacity: 0.8;
}

.master-filter-option.sort-btn.is-dragging,
.sort-btn[data-sort].is-dragging {
  --feed-category-drag-scale: 1.06;
  position: fixed;
  left: 0;
  top: 0;
  margin: 0;
  opacity: 0.94;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.28);
  cursor: grabbing;
  z-index: 1200;
  transition:
    transform 28ms linear,
    opacity var(--transition-fast),
    box-shadow 140ms ease;
}

.feed-master-filter .feed-master-filter-placeholder,
.feed-sort-filter .feed-master-filter-placeholder {
  display: inline-flex;
  flex: 0 0 auto;
  box-sizing: border-box;
  border-radius: var(--radius-md);
  border: 1px dashed
    color-mix(in srgb, var(--accent-primary) 42%, transparent 58%);
  background: color-mix(in srgb, var(--accent-light) 58%, transparent 42%);
  opacity: 0.92;
}

.feed-master-filter .master-filter-option.sort-btn,
.feed-master-filter .feed-search-bar input.feed-search-input {
  min-height: 34px;
  padding: 0.08rem 0.48rem;
  font-size: 0.78rem;
  line-height: 1;
}

.sort-controls .search-bar {
  margin-bottom: 0;
}

.sort-controls .search-bar input {
  width: 140px;
  padding: 0.4rem 0.75rem;
  font-size: var(--font-size-sm);
}

.search-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin-bottom: 0.75rem;
}
.search-bar label {
  font-weight: 600;
}
.search-bar input {
  flex: 1;
  min-width: 200px;
}

.feed-master-filter:not(.feed-master-filter-inline-search) .feed-search-bar {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 0;
  gap: 0;
  min-width: 0;
  width: var(--feed-search-compact-width);
  overflow: hidden;
  transition: width 260ms cubic-bezier(0.22, 1, 0.36, 1);
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-focused
  .feed-search-bar {
  width: 100%;
}

.feed-master-filter .feed-search-bar input.feed-search-input {
  appearance: none;
  -webkit-appearance: none;
  box-sizing: border-box;
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  border-color: transparent;
  background: var(--accent-light);
  color: var(--accent-hover);
  font-style: normal;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  position: relative;
  transition:
    opacity var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast);
}

.feed-master-filter-inline-search .master-filter-group {
  padding-right: 0;
  align-items: center;
}

.feed-master-filter-inline-search .feed-search-bar {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0;
  margin-bottom: 0;
  min-width: 0;
  overflow: clip;
  border-radius: var(--radius-md);
  background: var(--accent-light);
  color: var(--accent-hover);
  transition:
    opacity 180ms ease,
    background 220ms cubic-bezier(0.22, 1, 0.36, 1),
    color 220ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.feed-master-filter-inline-search .feed-search-bar:hover {
  opacity: 0.85;
}

.feed-master-filter-inline-search .feed-search-bar:focus-within {
  opacity: 1;
}

.feed-master-filter-inline-search .feed-search-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  min-width: 34px;
  min-height: 34px;
  padding: 0;
  border: none;
  background: transparent;
  color: inherit;
  box-shadow: none;
  cursor: pointer;
  transition:
    opacity 160ms ease,
    color 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.feed-master-filter-inline-search .feed-search-toggle svg {
  width: 21px;
  height: 21px;
}

.feed-master-filter-inline-search .feed-search-toggle:hover,
.feed-master-filter-inline-search .feed-search-toggle:focus-visible {
  opacity: 1;
}

.feed-master-filter-inline-search .feed-search-toggle:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 1px;
}

.feed-master-filter-inline-search .feed-search-toggle:focus {
  outline: none;
}

.feed-master-filter-inline-search .feed-search-bar input.feed-search-input {
  width: 0;
  min-width: 0;
  max-width: none;
  padding-inline: 0;
  opacity: 0;
  pointer-events: none;
  background: transparent;
  color: inherit;
  cursor: text;
  transform: translateX(-0.22rem);
  transform-origin: left center;
  will-change: width, opacity, transform;
  transition:
    width 280ms cubic-bezier(0.22, 1, 0.36, 1),
    padding-inline 280ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 140ms ease,
    transform 240ms cubic-bezier(0.22, 1, 0.36, 1),
    color 180ms ease,
    background 180ms ease;
}

.feed-master-filter-inline-search.is-search-active .feed-search-bar {
  background: var(--accent-hover);
  color: #fff;
  opacity: 1;
}

.feed-master-filter-inline-search.is-search-active .feed-search-toggle {
  color: #fff;
  background: transparent;
}

.feed-master-filter-inline-search.is-search-active
  .feed-search-bar
  input.feed-search-input {
  width: clamp(7.5rem, 24vw, 11rem);
  padding-inline: 0.18rem 0.48rem;
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

.feed-master-filter-inline-search.is-search-active
  .feed-search-bar
  input.feed-search-input::placeholder {
  color: rgba(255, 255, 255, 0.82);
}

.feed-master-filter-inline-search.is-search-focused
  .feed-search-bar
  input.feed-search-input {
  width: clamp(9rem, 28vw, 12.5rem);
}

.feed-master-filter .feed-search-bar input.feed-search-input::placeholder {
  font-size: inherit;
  color: currentColor;
  font-style: normal;
  font-weight: inherit;
  opacity: 1;
}

.feed-master-filter:not(.feed-master-filter-inline-search)
  .feed-search-bar
  input.feed-search-input:placeholder-shown:not(:focus) {
  text-align: center;
}

.feed-master-filter .feed-search-bar input.feed-search-input:focus {
  opacity: 1;
  border-color: transparent;
  background: color-mix(in srgb, var(--accent-light) 82%, #fff 18%);
  cursor: text;
}

.feed-master-filter-inline-search
  .feed-search-bar
  input.feed-search-input:focus {
  background: transparent;
  color: inherit;
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-focused
  .feed-search-bar
  input.feed-search-input::placeholder {
  font-style: normal;
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-active
  .feed-search-bar
  input.feed-search-input {
  border-color: transparent;
  background: var(--accent-hover);
  color: #fff;
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-active
  .feed-search-bar
  input.feed-search-input::placeholder {
  color: rgba(255, 255, 255, 0.82);
  opacity: 1;
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-active
  .feed-search-bar
  input.feed-search-input:focus {
  background: var(--accent-hover);
  border-color: transparent;
  color: #fff;
}

[data-route-view="feed"] .sort-btn,
[data-route-view="feed"] .feed-search-bar input.feed-search-input,
.command-palette-category-filter .sort-btn,
.command-palette-category-filter .feed-search-bar input.feed-search-input {
  border-radius: var(--radius-md);
}

.feed-master-filter .master-filter-option.sort-btn {
  transition:
    opacity 180ms ease,
    transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-focused
  .master-filter-option.sort-btn {
  opacity: 0;
  transform: translateX(0.45rem);
  pointer-events: none;
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-focused
  .master-filter-option.sort-btn:nth-child(5) {
  transition-delay: 0ms;
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-focused
  .master-filter-option.sort-btn:nth-child(4) {
  transition-delay: 28ms;
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-focused
  .master-filter-option.sort-btn:nth-child(3) {
  transition-delay: 56ms;
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-focused
  .master-filter-option.sort-btn:nth-child(2) {
  transition-delay: 84ms;
}

.feed-master-filter:not(.feed-master-filter-inline-search).is-search-focused
  .master-filter-option.sort-btn:nth-child(1) {
  transition-delay: 112ms;
}

.sort-buttons {
  display: inline-flex;
  gap: 0.5rem;
}

.sort-btn {
  border: 1px solid transparent;
  background: var(--accent-light);
  color: var(--accent-hover);
  padding: 0.35rem 0.75rem;
  font-size: 0.85rem;
  transition: opacity var(--transition-fast);
}

.sort-btn:hover {
  opacity: 0.85;
}

.sort-btn.active {
  background: var(--accent-hover);
  color: #fff;
}

.sort-btn.active:hover {
  opacity: 1;
}

@keyframes toast-leave {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-10px);
  }
}

.feed-actions {
  display: flex;
  justify-content: center;
}

.feed-actions:has(button:not([hidden])) {
  margin-top: 1rem;
}

.feed-actions button[hidden] {
  display: none;
}

.skeleton-row {
  opacity: 0.85;
}

.skeleton-line,
.skeleton-block {
  background: var(--skeleton-bg);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.5s ease-in-out infinite;
  border-radius: 999px;
}

.skeleton-line {
  display: block;
  height: 10px;
  margin: 0.2rem 0;
}

.skeleton-line.short {
  width: 60%;
}

.skeleton-line.tiny {
  height: 8px;
  width: 40%;
}

.skeleton-block {
  width: 32px;
  height: 32px;
}

.skeleton-meta {
  width: 100%;
}

.post-skeleton,
.profile-activity-skeleton,
.moderator-queue-skeleton {
  pointer-events: none;
}

.post-skeleton-avatar,
.profile-activity-skeleton-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  flex-shrink: 0;
}

.post-skeleton-content,
.profile-activity-skeleton-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.post-skeleton .skeleton-line,
.profile-activity-skeleton .skeleton-line,
.moderator-queue-skeleton .skeleton-line {
  margin: 0;
}

.post-skeleton-meta,
.profile-activity-skeleton-meta,
.moderator-skeleton-meta {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.moderator-skeleton-pill {
  width: 72px;
  height: 18px;
  border-radius: var(--radius-full);
}

.moderator-skeleton-title {
  width: 190px;
  max-width: 60%;
}

.moderator-skeleton-actions {
  min-width: 120px;
  flex-direction: column;
  align-items: flex-end;
}

.moderator-skeleton-actions .skeleton-line {
  width: 96px;
}

@keyframes skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

textarea {
  border-radius: 0.75rem;
  border: 1.5px solid var(--textarea-border);
  padding: 0.85rem 1rem;
  font-family: inherit;
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
  resize: none;
  overflow: hidden;
  background: var(--textarea-bg);
  color: var(--text-primary);
  box-shadow: var(--textarea-shadow);
  transition:
    border-color var(--transition-normal),
    box-shadow var(--transition-normal);
}

textarea::placeholder {
  color: var(--text-muted);
  opacity: 0.6;
  font-style: italic;
}

#post-body::placeholder {
  font-style: normal;
}

textarea:focus {
  outline: none;
}

#post-body {
  box-sizing: border-box;
  display: block;
  width: 100%;
  border: 0;
  border-radius: calc(var(--radius-md) - 1px);
  background: transparent;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-tight);
  box-shadow: none;
}

.discussion-post-input-shell {
  border: 1px solid
    color-mix(in srgb, var(--accent-primary) 8%, var(--border-secondary) 92%);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--bg-input) 96%, var(--accent-primary) 4%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 4%, transparent 96%),
    0 12px 28px rgba(2, 6, 23, 0.1);
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast);
}

.discussion-post-input-shell:focus-within {
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 12%,
    var(--border-secondary) 88%
  );
  background: color-mix(in srgb, var(--bg-input) 90%, var(--bg-panel) 10%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 10%, transparent 90%),
    0 12px 28px rgba(2, 6, 23, 0.12);
}

.char-counter {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  text-align: right;
  margin-top: 0.14rem;
  transition: color var(--transition-normal);
}

#post-form {
  --post-body-width: min(67%, 31rem);
  --post-form-stack-gap: 0.18rem;
  --post-form-action-gap: var(--space-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--post-form-stack-gap);
}

#post-form.is-login-prompt {
  --post-form-stack-gap: 0;
  margin-top: -0.6rem;
}

#post-form > #replying-to,
#post-form > #editing-post,
#post-form > #pending-post-banner {
  width: var(--post-body-width);
}

#post-form > .discussion-post-input-shell {
  width: var(--post-body-width);
}

#post-form > .post-form-footer {
  width: var(--post-body-width);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}

#post-form > .post-form-footer > .form-actions {
  grid-column: 2;
  justify-self: center;
  margin-top: calc(var(--post-form-action-gap) - var(--post-form-stack-gap));
}

#post-form.is-login-prompt > .post-form-footer > .form-actions {
  margin-top: 0;
}

#post-form > .post-form-footer > #post-char-counter {
  grid-column: 3;
  justify-self: end;
  align-self: start;
  margin-top: -0.06rem;
}

.char-counter.near-limit {
  color: var(--danger-primary);
  font-weight: var(--font-weight-medium);
}

.discussion-header {
  display: flex;
  flex-direction: column;
  padding-bottom: calc(var(--space-md) - 1px);
  border-bottom: 1px solid var(--border-secondary);
  margin-bottom: 0.82rem;
}

.discussion-header-controls {
  position: absolute;
  top: 1rem;
  right: 1rem;
  display: inline-flex;
  align-items: flex-start;
  gap: 0.4rem;
  z-index: 3;
}

.discussion-header-menu {
  position: relative;
  display: inline-flex;
}

.discussion-moderator-dropdown {
  box-sizing: border-box;
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  width: max-content;
  max-width: calc(100vw - 2rem);
  padding: 0.72rem;
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-md);
  background: var(--bg-panel);
  box-shadow: 0 12px 32px var(--shadow-md);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.65rem;
  z-index: 30;
}

.discussion-moderator-dropdown[hidden] {
  display: none;
}

.discussion-moderator-dropdown-title {
  margin: 0;
  color: var(--text-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.discussion-moderator-dropdown-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.6rem;
}

.discussion-header .card-link-actions {
  margin-top: 0.2rem;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.discussion-header h1 {
  margin: 0;
  font-size: var(--font-size-lg) !important;
  font-weight: var(--font-weight-medium);
  letter-spacing: -0.01em;
  word-break: break-word;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-sm);
}

.discussion-header h1 .star-btn {
  flex-shrink: 0;
  align-self: flex-start;
  margin-top: 0;
  padding-top: 0;
}

.discussion-header h1 .discussion-star-spacer {
  visibility: hidden;
  pointer-events: none;
  cursor: default;
}

.discussion-title-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  flex: 1;
  min-width: 0;
}

.discussion-back-row {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  min-height: 1.45rem;
  padding-right: 4rem;
  margin-bottom: 0.55rem;
}

.discussion-back-btn {
  border: none;
  background: transparent;
  font-size: var(--font-size-xl);
  line-height: 1;
  padding: var(--space-xs);
  margin: calc(-1 * var(--space-xs));
  color: var(--text-primary);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: opacity var(--transition-fast);
}

.discussion-back-btn:hover,
.discussion-back-btn:focus-visible {
  opacity: 0.7;
}

.discussion-title-link {
  color: var(--text-link);
  text-decoration: none;
  word-break: break-word;
  display: block;
  transition: color var(--transition-fast);
}

.discussion-title-link:hover {
  color: var(--text-primary);
}

.discussion-label {
  text-transform: uppercase;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.1em;
  color: var(--text-muted);
  margin: 0;
}

.discussion-title-wrap h3 {
  margin: 0;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-tight);
}

.discussion-title-wrap p {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.7rem;
}

.posts {
  list-style: none;
  padding-left: 0;
  margin: var(--space-md) 0 calc(var(--space-xl) - 34px);
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.load-more-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin: 0.35rem auto 0.6rem;
  min-height: 2rem;
  padding: 0.2rem 0.75rem;
  border: none;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--text-muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition:
    color var(--transition-fast),
    background var(--transition-fast);
}

.load-more-btn:hover,
.load-more-btn:focus-visible {
  color: var(--text-secondary);
  background: var(--bg-tertiary);
}

.load-more-btn[hidden] {
  display: none;
}

#load-more-btn,
#profile-load-more-btn,
.load-more-replies-btn,
#load-more-posts-btn {
  min-height: 2.1rem;
  padding: 0.42rem 0.82rem;
  border: 1px solid transparent;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast);
}

#load-more-btn,
#profile-load-more-btn,
.load-more-replies-btn {
  border-radius: var(--radius-full);
}

#load-more-posts-btn {
  border-radius: var(--radius-md);
}

.post-reply-controls .load-more-replies-btn {
  margin: 0;
}

#load-more-btn:hover,
#load-more-btn:focus-visible,
#load-more-btn:active,
#profile-load-more-btn:hover,
#profile-load-more-btn:focus-visible,
#profile-load-more-btn:active,
.load-more-replies-btn:hover,
.load-more-replies-btn:focus-visible,
.load-more-replies-btn:active,
#load-more-posts-btn:hover,
#load-more-posts-btn:focus-visible,
#load-more-posts-btn:active {
  border-color: var(--accent-primary);
  background: transparent;
  color: var(--accent-primary);
}

.post {
  display: flex;
  gap: var(--space-sm);
  padding: 0.65rem 0.85rem 0.7rem;
  border-radius: var(--radius-md);
  background: transparent;
  transition: background var(--transition-fast);
  position: relative;
}

.post:hover {
  background: transparent;
}

/* Star button sizing in posts (same as .card .star-btn) */
.post .star-btn {
  padding: 2px 6px;
  font-size: 0.825rem;
  min-height: 0;
  line-height: 1;
}

.post[data-depth="1"] {
  margin-left: var(--space-lg);
  padding-left: var(--space-md);
  border-left: 1px solid var(--border-secondary);
  border-radius: 0;
}

.post[data-depth="2"] {
  margin-left: var(--space-2xl);
  padding-left: var(--space-md);
  border-left: 1px solid var(--border-secondary);
  border-radius: 0;
}

.post .card-content {
  justify-content: flex-start;
}

.post .card-body {
  margin: 0;
  margin-top: 0.4rem;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-tight);
  word-break: break-word;
}

.post .card-body::after {
  content: "";
  display: block;
  clear: both;
}

.post .card-body .card-time-inline-body {
  float: right;
  clear: right;
  width: max-content;
  text-align: right;
  margin-left: 0.55rem;
  margin-right: 0.375rem;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  min-height: calc(var(--font-size-sm) * var(--line-height-tight));
  line-height: var(--line-height-tight);
}

.link-flag-badge {
  background: var(--flag-badge-bg);
  color: var(--flag-badge-text);
}

.post-actions {
  display: flex;
  width: 100%;
  justify-content: flex-start;
  gap: 0.45rem;
  flex-wrap: wrap;
  align-items: center;
  min-width: 0;
}

.post .post-actions {
  min-height: 1.75rem;
  width: 100%;
}

body[data-route="discussion"] .post .post-actions {
  margin-top: 0.58rem;
  min-height: 1.45rem;
}

.post .post-actions .card-time-inline {
  margin-left: auto;
  min-height: 1.75rem;
  display: inline-flex;
  align-items: center;
}

.post-actions > .card-actions {
  margin-left: 0;
  width: 100%;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.post-context {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.post-reply-controls {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 0.25rem;
  min-height: 0;
}

/* Post action buttons - muted, small, with opacity hover */
.post-actions .ghost-btn {
  color: var(--text-muted);
  font-size: var(--font-size-xs);
  padding: 0.35rem 0.55rem;
  min-height: var(--hit-target-min);
  transition: opacity var(--transition-fast);
}

body[data-route="discussion"]
  .post
  .card-actions[data-has-reply-toggle="true"] {
  position: relative;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

body[data-route="discussion"]
  .post
  .card-actions[data-has-reply-toggle="true"]
  > .card-actions-hover {
  position: absolute;
  top: 50%;
  left: calc(1.45rem + var(--space-sm));
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: nowrap;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-50%);
  transition:
    opacity 420ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0s linear 420ms;
}

body[data-route="discussion"]
  .post:hover
  .card-actions[data-has-reply-toggle="true"]
  > .card-actions-hover,
body[data-route="discussion"]
  .post:focus-within
  .card-actions[data-has-reply-toggle="true"]
  > .card-actions-hover,
body[data-route="discussion"]
  .post[data-action-hold="true"]
  .card-actions[data-has-reply-toggle="true"]
  > .card-actions-hover {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0s, 0s;
}

body[data-route="discussion"]
  .post
  .card-actions[data-has-reply-toggle="true"]
  > .reply-tree-toggle-btn {
  width: 1.45rem;
  min-width: 1.45rem;
  min-height: 1.45rem;
  padding: 0;
  border-radius: var(--radius-sm);
  color: var(--accent-primary);
  font-size: 0.8rem;
  font-weight: var(--font-weight-bold);
  line-height: 1;
  transition:
    color var(--transition-fast),
    background-color var(--transition-fast),
    opacity var(--transition-fast);
}

body[data-route="discussion"]
  .post
  .card-actions[data-has-reply-toggle="true"]
  > .reply-tree-toggle-btn:hover,
body[data-route="discussion"]
  .post
  .card-actions[data-has-reply-toggle="true"]
  > .reply-tree-toggle-btn:focus-visible {
  opacity: 1;
  color: color-mix(in srgb, var(--accent-hover) 88%, #fff 12%);
  background: color-mix(in srgb, var(--accent-primary) 12%, transparent 88%);
}

body[data-route="discussion"]
  .post
  .card-actions[data-has-reply-toggle="true"]
  > .reply-tree-toggle-btn[aria-expanded="true"] {
  opacity: 1;
  color: color-mix(in srgb, var(--accent-hover) 88%, #fff 12%);
  background: transparent;
}

body[data-route="discussion"]
  .post
  .card-actions[data-has-reply-toggle="true"]
  > .reply-tree-toggle-btn[aria-expanded="true"]:hover,
body[data-route="discussion"]
  .post
  .card-actions[data-has-reply-toggle="true"]
  > .reply-tree-toggle-btn[aria-expanded="true"]:focus-visible {
  background: color-mix(in srgb, var(--accent-primary) 12%, transparent 88%);
}

body[data-route="discussion"]
  .post[data-action-hold="true"]
  .card-actions[data-has-reply-toggle="true"]
  > .reply-tree-toggle-btn {
  opacity: 1;
  color: color-mix(in srgb, var(--accent-hover) 88%, #fff 12%);
  background: color-mix(in srgb, var(--accent-primary) 12%, transparent 88%);
}

.post-reply-controls .ghost-btn {
  color: var(--text-secondary);
  font-size: var(--font-size-xs);
  padding: 0.35rem 0.55rem;
  min-height: var(--hit-target-min);
  transition: opacity var(--transition-fast);
}

.post-actions .ghost-btn:hover {
  opacity: 0.7;
}

.post-reply-controls .ghost-btn:hover,
.post-reply-controls .load-more-replies-btn:hover {
  opacity: 0.7;
}

/* Card author as header row */
.card-author {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.author-reply-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--inline-action);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  line-height: 1.2;
  min-height: 0;
  padding: 0.05rem 0.3rem;
  cursor: pointer;
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.author-reply-btn:hover,
.author-reply-btn:focus-visible {
  opacity: 0.7;
}

.first-post-badge {
  margin-right: 0.25rem;
}

/* Profile links in card author - no underline */
.card-author .profile-link,
.card-author .profile-link:hover,
.card-author .profile-link:visited {
  text-decoration: none;
}

/* Star button styles */
.star-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.4rem 0.6rem;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--star-vote);
  font-size: 0.935rem;
  border-radius: var(--radius-sm);
  transition:
    color var(--transition-fast),
    background var(--transition-fast);
  min-height: var(--hit-target-min);
}

.star-btn:hover {
  color: var(--star-vote-hover);
}

.star-btn:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

.star-btn.starred {
  color: var(--star-vote-active);
}

.star-btn.starred:hover {
  color: var(--star-vote-active-hover);
}

.star-icon {
  flex-shrink: 0;
  pointer-events: none;
  display: block;
  margin-top: -2px;
}

.star-btn.starred .star-icon {
  fill: currentColor;
}

.star-count {
  pointer-events: none;
}

.star-count {
  font-variant-numeric: tabular-nums;
  min-width: 1ch;
}

.replying-to {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: nowrap;
  gap: 0;
  padding: 0.32rem var(--space-md);
  border-radius: var(--radius-md);
  background: var(--accent-light);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-tight);
  text-align: left;
  margin-bottom: var(--space-sm);
  overflow: hidden;
}

.replying-to-copy {
  display: inline-flex;
  align-items: center;
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
}

#replying-to-target,
#editing-post-target {
  display: inline-block;
  margin-left: 0.25rem;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.replying-to .ghost-btn {
  margin-left: auto;
  flex-shrink: 0;
  min-height: 0;
  padding: 0.05rem 0.28rem;
  line-height: 1.1;
  font-weight: var(--font-weight-medium);
}

.replying-to[hidden] {
  display: none !important;
}

.editing-banner {
  background: var(--editing-banner-bg);
}

.editing-banner .ghost-btn {
  color: var(--editing-banner-text);
}

.pending-post-banner {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.45rem;
  padding: 0.32rem var(--space-md);
  border-radius: var(--radius-md);
  background: var(--accent-light);
  margin-bottom: var(--space-sm);
  text-align: left;
}

.pending-post-banner .pending-post-banner-text {
  display: inline-flex;
  align-items: center;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  line-height: 1.15;
  position: relative;
  top: 0.02rem;
}

.pending-post-banner .ghost-btn {
  margin-left: auto;
  flex-shrink: 0;
  min-height: 0;
  padding: 0.05rem 0.28rem;
  line-height: 1.1;
  font-weight: var(--font-weight-medium);
}

.pending-post-banner[hidden] {
  display: none !important;
}

.moderator-panel {
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-top: var(--space-lg);
}

.moderator-panel h2 {
  margin-top: 0;
  margin-bottom: var(--space-md);
}

.moderator-console-state.list-state:not(:empty) {
  padding: 1.1rem var(--space-lg) 1.2rem;
  text-align: left;
  color: var(--text-secondary);
}

.moderator-console-unauthorized {
  padding: 1.1rem var(--space-lg) 1.2rem;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
}

.moderator-console-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.moderator-tabs {
  display: inline-flex;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.moderator-tab-btn {
  flex: 0 0 auto;
  min-width: 8.75rem;
}

.moderator-toolbar-actions {
  display: inline-flex;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.moderator-pill-btn,
.moderator-inline-btn {
  min-height: 2.6rem;
  padding: 0.62rem 1.2rem;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  white-space: nowrap;
}

.moderator-filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: var(--space-sm);
  margin-top: 0;
}

.moderator-search-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-top: 0;
}

.moderator-filter-grid .field {
  margin: 0;
}

.moderator-filter-grid .field span,
.moderator-search-grid .field span {
  display: block;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.045em;
  color: var(--text-secondary);
  margin-bottom: 0.35rem;
}

.moderator-filter-grid select,
.moderator-search-grid input {
  width: 100%;
  max-width: none;
}

.moderator-filter-select,
#moderator-console-view
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
  appearance: none;
  -webkit-appearance: none;
  min-height: calc(var(--hit-target-min) + 2px);
  padding: 0.6rem 1rem;
  border: 1px solid var(--border-secondary);
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 8%,
    var(--border-secondary) 92%
  );
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--bg-input) 90%, var(--bg-panel) 10%);
  color: var(--text-primary);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 12px 28px rgba(2, 6, 23, 0.1);
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast),
    opacity var(--transition-fast);
}

.moderator-filter-select {
  padding-right: 2.15rem;
  font-size: var(--font-size-sm);
  line-height: 1.1;
  cursor: pointer;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--text-secondary) 50%),
    linear-gradient(135deg, var(--text-secondary) 50%, transparent 50%);
  background-position:
    calc(100% - 1.05rem) 50%,
    calc(100% - 0.73rem) 50%;
  background-size:
    0.38rem 0.38rem,
    0.38rem 0.38rem;
  background-repeat: no-repeat;
}

.moderator-filter-select:hover,
#moderator-console-view
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
.moderator-filter-select:focus,
#moderator-console-view
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus {
  opacity: 1;
}

.moderator-filter-select:focus,
#moderator-console-view
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus {
  outline: none;
  border-color: var(--border-primary);
  background: color-mix(in srgb, var(--bg-input) 94%, var(--color-ink) 6%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 18%, transparent 82%),
    0 16px 34px rgba(2, 6, 23, 0.14);
}

.moderator-subsection {
  margin-top: 0;
}

.moderator-console-card {
  position: relative;
}

.moderator-refresh-btn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
}

.moderator-subsection h3 {
  margin: 0 0 0.45rem;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

.moderator-filter-actions {
  margin-top: var(--space-sm);
}

.moderator-empty {
  margin: 0.65rem 0 0;
  color: var(--text-muted);
  font-size: var(--font-size-sm);
}

#moderator-alerts-summary {
  display: grid;
  gap: 0.55rem;
  margin: 0 0 var(--space-sm);
}

.moderator-alert-summary-item {
  margin: 0;
  padding: 0.7rem 0.8rem;
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in srgb, var(--danger-primary) 22%, transparent);
  background: color-mix(
    in srgb,
    var(--danger-primary) 10%,
    var(--bg-panel) 90%
  );
  color: var(--text-primary);
  font-size: var(--font-size-sm);
}

.flags-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.flags-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--border-secondary);
}

.flags-list li:last-child {
  border-bottom: none;
}

.moderator-flag-item,
.security-alert-item {
  align-items: flex-start !important;
}

.security-alert-main {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
  flex: 1;
}

.security-alert-header {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
}

.security-severity {
  display: inline-block;
  border-radius: 999px;
  padding: 0.1rem 0.45rem;
  font-size: 0.7rem;
  line-height: 1.1;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.security-severity-medium {
  background: var(--accent-light);
  color: var(--accent-primary);
}

.security-severity-high {
  background: color-mix(
    in srgb,
    var(--danger-primary) 16%,
    var(--bg-panel) 84%
  );
  color: var(--danger-primary);
}

.security-severity-critical {
  background: var(--danger-primary);
  color: #fff;
}

.moderator-target-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  padding: 0.22rem 0.62rem;
  font-size: 0.7rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background: color-mix(
    in srgb,
    var(--accent-primary) 14%,
    var(--bg-panel) 86%
  );
  color: var(--accent-primary);
}

.security-alert-meta {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

.security-alert-summary {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

.moderator-flag-details {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  margin-top: 0.15rem;
}

.moderator-flag-row {
  display: grid;
  grid-template-columns: minmax(4.9rem, auto) minmax(0, 1fr);
  gap: 0.75rem;
  align-items: start;
}

.moderator-flag-row-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-secondary);
  padding-top: 0.15rem;
}

.moderator-flag-row-value {
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  align-items: flex-start;
  color: var(--text-primary);
}

.moderator-flag-row-value a {
  color: var(--text-primary);
  text-decoration: none;
}

.moderator-flag-row-value a:hover,
.moderator-profile-link:hover {
  color: var(--accent-primary);
}

.moderator-flag-content {
  width: 100%;
  margin: 0;
  padding: 0.85rem 1rem;
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--bg-tertiary) 72%, var(--bg-panel) 28%);
  color: var(--text-primary);
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.55;
}

.moderator-flag-content-wrap {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.moderator-flag-content-status {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

.moderator-flag-open-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.moderator-flag-open-actions .moderator-inline-btn,
.moderator-flag-row-value .moderator-inline-btn {
  min-width: 0;
}

.security-alert-actions {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.moderator-queue-card {
  display: flex !important;
  flex-direction: column;
  align-items: stretch !important;
  gap: 0.8rem;
  padding: 0.95rem 1rem !important;
  border-bottom: none !important;
  border: 1px solid
    color-mix(in srgb, var(--accent-primary) 10%, var(--border-secondary) 90%);
  border-radius: calc(var(--radius-md) + 2px);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg-panel) 92%, #fff 8%),
    color-mix(in srgb, var(--bg-panel) 98%, #000 2%)
  );
  box-shadow:
    0 14px 34px rgba(2, 6, 23, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.moderator-queue-card + .moderator-queue-card {
  margin-top: 0.1rem;
}

.moderator-queue-card .security-alert-main {
  gap: 0.75rem;
}

.moderator-card-topbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.moderator-card-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.moderator-meta-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.7rem;
  padding: 0.28rem 0.62rem;
  border-radius: var(--radius-full);
  border: 1px solid transparent;
  font-size: 0.68rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.045em;
  text-transform: uppercase;
}

.moderator-meta-pill-neutral {
  background: color-mix(in srgb, var(--bg-tertiary) 72%, var(--bg-panel) 28%);
  border-color: color-mix(in srgb, var(--border-secondary) 70%, transparent);
  color: var(--text-secondary);
}

.moderator-meta-pill-accent {
  background: color-mix(
    in srgb,
    var(--accent-primary) 12%,
    var(--bg-panel) 88%
  );
  border-color: color-mix(in srgb, var(--accent-primary) 22%, transparent);
  color: var(--accent-primary);
}

.moderator-meta-pill-warning {
  background: color-mix(in srgb, #e6a23c 16%, var(--bg-panel) 84%);
  border-color: color-mix(in srgb, #e6a23c 30%, transparent);
  color: color-mix(in srgb, #f0b55e 88%, #fff 12%);
}

.moderator-meta-pill-danger {
  background: color-mix(
    in srgb,
    var(--danger-primary) 16%,
    var(--bg-panel) 84%
  );
  border-color: color-mix(in srgb, var(--danger-primary) 32%, transparent);
  color: var(--danger-primary);
}

.moderator-meta-pill-success {
  background: color-mix(in srgb, #15a46b 18%, var(--bg-panel) 82%);
  border-color: color-mix(in srgb, #15a46b 28%, transparent);
  color: color-mix(in srgb, #37c88b 86%, #fff 14%);
}

.moderator-card-title-block {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 0;
}

.moderator-card-title {
  font-size: clamp(1rem, 0.95rem + 0.5vw, 1.32rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  word-break: break-word;
}

.moderator-card-subtitle {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
  color: var(--text-muted);
  font-size: var(--font-size-xs);
  line-height: 1.45;
}

.moderator-card-subtitle a {
  color: var(--text-primary);
  text-decoration: none;
}

.moderator-card-subtitle a:hover {
  color: var(--accent-primary);
}

.moderator-card-layout {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.moderator-card-section {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  min-width: 0;
  padding: 0.85rem 0.95rem;
  border: 1px solid color-mix(in srgb, var(--border-secondary) 88%, #fff 12%);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--bg-tertiary) 64%, var(--bg-panel) 36%);
}

.moderator-card-section-title {
  margin: 0;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.moderator-card-section-body {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  min-width: 0;
}

.moderator-card-summary,
.moderator-card-note {
  margin: 0;
}

.moderator-card-summary {
  color: var(--text-primary);
  font-size: var(--font-size-sm);
  line-height: 1.55;
}

.moderator-card-note {
  color: var(--text-secondary);
  font-size: var(--font-size-xs);
  line-height: 1.45;
}

.moderator-card-fact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
  gap: 0.65rem;
}

.moderator-card-fact {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 0;
  padding: 0.72rem 0.8rem;
  border: 1px solid color-mix(in srgb, var(--border-secondary) 84%, #fff 16%);
  border-radius: calc(var(--radius-md) - 2px);
  background: color-mix(in srgb, var(--bg-panel) 74%, var(--bg-tertiary) 26%);
}

.moderator-card-fact-wide {
  grid-column: 1 / -1;
}

.moderator-card-fact-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.moderator-card-fact-value {
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: flex-start;
  color: var(--text-primary);
  font-size: var(--font-size-sm);
  line-height: 1.45;
}

.moderator-card-fact-value a {
  color: var(--text-primary);
  text-decoration: none;
}

.moderator-card-fact-value a:hover {
  color: var(--accent-primary);
}

.moderator-card-footer {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: 0.65rem;
  padding-top: 0.8rem;
  border-top: 1px solid
    color-mix(in srgb, var(--border-secondary) 86%, #fff 14%);
  justify-content: stretch;
}

.moderator-action-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 0;
  padding: 0.72rem 0.8rem;
  border: 1px solid color-mix(in srgb, var(--border-secondary) 84%, #fff 16%);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--bg-panel) 74%, var(--bg-tertiary) 26%);
}

.moderator-action-group-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.moderator-action-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.moderator-action-buttons .moderator-inline-btn {
  min-width: 0;
  min-height: 2.15rem;
  padding: 0.42rem 0.78rem;
  border-radius: 0.8rem;
  font-size: var(--font-size-xs);
}

.moderator-action-buttons .ghost-btn.moderator-inline-btn,
.moderator-action-buttons .button-secondary.moderator-inline-btn {
  border: 1px solid color-mix(in srgb, var(--accent-primary) 36%, transparent);
  background: color-mix(in srgb, var(--accent-primary) 8%, transparent);
}

.moderator-action-buttons .ghost-btn.moderator-inline-btn.danger {
  border-color: color-mix(in srgb, var(--danger-primary) 34%, transparent);
  background: color-mix(in srgb, var(--danger-primary) 9%, transparent);
}

@media (max-width: 640px) {
  .moderator-card-topbar {
    flex-direction: column;
  }

  .moderator-card-footer {
    grid-template-columns: 1fr;
  }

  .moderator-card-fact-grid {
    grid-template-columns: 1fr;
  }

  .moderator-action-buttons .moderator-inline-btn {
    min-width: 0;
    flex: 1 1 calc(50% - 0.45rem);
  }
}

.moderator-profile-link {
  text-decoration: none;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.app-tooltip {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 220;
  max-width: min(18rem, calc(100vw - 24px));
  padding: 0.32rem 0.55rem;
  border: 1px solid var(--tooltip-border);
  border-radius: var(--radius-sm);
  background: var(--tooltip-bg);
  color: var(--tooltip-text);
  box-shadow:
    0 10px 28px rgba(15, 23, 42, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
  backdrop-filter: blur(14px);
  font-size: calc(var(--font-size-xs) * 0.92);
  font-weight: var(--font-weight-medium);
  line-height: 1.15;
  letter-spacing: 0.01em;
  text-align: center;
  white-space: normal;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transform: translate3d(0, 6px, 0) scale(0.98);
  transform-origin: center;
  transition:
    opacity 120ms ease,
    transform 160ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0s linear 160ms;
}

.app-tooltip[data-state="open"] {
  opacity: 1;
  visibility: visible;
  transform: translate3d(0, 0, 0) scale(1);
  transition-delay: 0s;
}

.app-tooltip[data-side="top"] {
  transform-origin: center bottom;
}

.app-tooltip[data-side="bottom"] {
  transform-origin: center top;
}

@supports not (backdrop-filter: blur(1px)) {
  .app-tooltip {
    background: color-mix(in srgb, var(--tooltip-bg) 96%, #fff 4%);
  }
}

.button-secondary {
  background: transparent;
  color: var(--accent-primary);
  border: 1px solid var(--accent-primary);
}

.button-danger {
  background: var(--danger-primary);
  color: #fff;
  border: none;
}

.button-danger:hover {
  background: var(--danger-hover);
}

.button-danger:disabled {
  background: var(--text-muted);
  cursor: not-allowed;
}

.password-block {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.profile-block {
  margin-top: 1.5rem;
  padding: 1.25rem;
  border: 1px solid var(--border-secondary);
  border-radius: 1rem;
  background: var(--bg-tertiary);
}

.profile-block h3 {
  margin: 0 0 0.25rem;
}

.profile-block p {
  margin-top: 0;
}

.field-hint {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin: -0.25rem 0 0;
}

.profile-actions {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

/* Compact card layout */
.profile-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-md);
  overflow: hidden;
  isolation: isolate;
}

/* ============================================================================
   Settings Page
   ============================================================================ */
.settings-card {
  --settings-compact-control-width: 16.5rem;
  background: var(--bg-panel);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.settings-title {
  font-size: 1.25rem;
  font-weight: var(--font-weight-bold);
  margin: 0;
  padding: calc(var(--space-lg) - 1px) var(--space-lg) var(--space-md);
  border-bottom: 1px solid var(--border-secondary);
}

.settings-section {
  padding: 1.1rem var(--space-lg) 1.2rem;
  border-bottom: 1px solid var(--border-secondary);
}

.settings-section:last-child {
  border-bottom: none;
}

.settings-section-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.045em;
  color: var(--text-secondary);
  margin: 0 0 0.45rem;
}

.settings-status {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  margin: 0 0 0.6rem;
  min-height: 1.2em;
}

#settings-tab-account .button-primary + .settings-status,
#settings-tab-account .button-secondary + .settings-status,
#settings-tab-account .button-danger + .settings-status {
  margin: var(--space-sm) 0 0;
}

.settings-status:empty {
  display: none;
}

.settings-password-fields {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.settings-password-fields .input {
  width: 100%;
}

#settings-current-password-field:not([hidden]) {
  margin-bottom: var(--space-sm);
}

.settings-signin-text {
  margin: 0;
  color: var(--text-secondary);
}

.settings-section-desc {
  color: var(--text-muted);
  font-size: var(--font-size-sm);
  margin: 0 0 0.75rem;
  line-height: 1.45;
  max-width: 56ch;
}

.settings-coming-soon {
  color: var(--text-muted);
  font-size: var(--font-size-sm);
  font-style: italic;
  margin: 0;
}

.settings-toggles {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.settings-section .input {
  width: 100%;
  max-width: 200px;
}

#settings-tab-account .settings-password-fields {
  width: 100%;
  max-width: var(--settings-compact-control-width);
}

#settings-tab-account .input,
#settings-tab-account .button-primary,
#settings-tab-account .button-secondary,
#settings-tab-account .button-danger {
  box-sizing: border-box;
}

#settings-tab-account .input {
  width: 100%;
  max-width: var(--settings-compact-control-width);
}

#settings-tab-account .button-primary,
#settings-tab-account .button-secondary,
#settings-tab-account .button-danger {
  width: auto;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

#settings-email-section .input,
#settings-username-section .input {
  display: block;
}

.settings-keybindings-list {
  list-style: none;
  margin: 0 0 var(--space-md);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.settings-keybinding-item {
  display: flex;
  justify-content: space-between;
  gap: var(--space-sm);
  align-items: center;
  padding: var(--space-xs) 0;
  border-bottom: 1px solid var(--border-secondary);
}

.settings-keybinding-item:last-child {
  border-bottom: none;
}

.settings-keybinding-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.settings-keybinding-label {
  font-size: var(--font-size-sm);
  color: var(--text-primary);
}

.settings-keybinding-context {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

.settings-keybinding-keys {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 88px;
  padding: 0.2rem 0.55rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-secondary);
  background: var(--bg-tertiary);
  color: var(--text-secondary);
  font-size: var(--font-size-xs);
  white-space: nowrap;
}

.settings-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 0.35rem 0;
  border: none;
  border-radius: 0;
  border-bottom: 1px solid var(--border-secondary);
  background: transparent;
  cursor: pointer;
  font-size: var(--font-size-sm);
  color: var(--text-primary);
}

.settings-toggle:last-child {
  border-bottom: none;
}

.settings-toggle input {
  order: 2;
  accent-color: var(--accent-primary);
  width: 16px;
  height: 16px;
  margin-left: auto;
  flex-shrink: 0;
  cursor: pointer;
}

.settings-toggle span {
  order: 1;
  flex: 1;
  color: var(--text-primary);
}

#settings-change-email-btn,
#settings-change-username-btn {
  margin-top: var(--space-sm);
}

#settings-edit-keybindings-btn {
  width: fit-content;
  max-width: 100%;
  box-sizing: border-box;
}

.settings-tabs {
  display: flex;
  gap: var(--space-xs);
  margin-bottom: var(--space-lg);
  border-bottom: 1px solid var(--border);
  padding-bottom: var(--space-sm);
}

.settings-tab {
  padding: var(--space-xs) var(--space-sm);
  background: none;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  font-weight: 500;
  cursor: pointer;
  transition:
    color 0.15s,
    background 0.15s;
}

.settings-tab:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.settings-tab.active {
  color: var(--accent-primary);
  background: var(--bg-hover);
}

.settings-tab-content {
  /* Tab content container */
}

/*
 * SECURITY: Defense-in-depth for settings auth.
 * Auth-required tab content is hidden by default and only shown when:
 * 1. Parent has .is-authenticated class (set by JS based on auth state)
 * 2. The specific tab is not hidden (controlled by switchSettingsTab)
 *
 * This ensures auth-required settings are never visible to unauthenticated users
 * even if JS auth checks fail.
 *
 * Note: General tab (#settings-tab-general) is accessible to all users.
 */
#settings-view:not(.is-authenticated) #settings-tab-account,
#settings-view:not(.is-authenticated) #settings-tab-notifications {
  display: none !important;
}

/* Settings - Danger section */
.settings-section-danger {
  border-top: 1px solid var(--danger-primary);
  background: rgba(220, 38, 38, 0.03);
}

.settings-danger-text {
  color: var(--danger-primary);
  font-size: var(--font-size-sm);
  margin: 0 0 0.75rem;
  line-height: 1.45;
  max-width: 56ch;
}

.settings-current-value {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  margin: 0 0 var(--space-sm);
}

.settings-current-value:empty {
  display: none;
}

.settings-cooldown {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  margin: var(--space-sm) 0;
  font-style: italic;
}

.settings-cooldown:empty {
  display: none;
}

.settings-help-text {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin: var(--space-sm) 0 0;
  line-height: 1.45;
  max-width: 56ch;
}

.settings-select {
  width: 100%;
  max-width: 200px;
  padding: var(--space-sm) var(--space-md);
  font-size: var(--font-size-sm);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-md);
  background: var(--bg-input);
  color: var(--text-primary);
  cursor: pointer;
}

.settings-select:focus {
  outline: none;
  border-color: var(--accent-primary);
  box-shadow: 0 0 0 2px var(--accent-light);
}

/* Delete Account Modal */
.delete-account-modal-content {
  max-width: 420px;
}

.delete-account-title {
  color: var(--danger-primary);
  margin: 0 0 var(--space-md);
}

.delete-account-warning {
  color: var(--text-secondary);
  margin: 0 0 var(--space-sm);
  font-size: var(--font-size-sm);
}

.delete-account-list {
  margin: 0 0 var(--space-lg);
  padding-left: var(--space-lg);
  font-size: var(--font-size-sm);
  color: var(--text-muted);
}

.delete-account-list li {
  margin-bottom: var(--space-xs);
}

/* 2FA Settings Styles */
.settings-2fa-loading {
  color: var(--text-muted);
}

.settings-success-text {
  color: var(--toast-success);
}

.settings-2fa-info {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  margin: 0 0 var(--space-md);
}

/* TOTP Setup Modal */
.totp-setup-modal-content {
  max-width: 400px;
}

.totp-instructions {
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  margin: 0 0 var(--space-md);
}

.totp-qr-container {
  display: flex;
  justify-content: center;
  margin: var(--space-md) 0;
}

.totp-qr-container img {
  max-width: 180px;
  height: auto;
  border-radius: var(--radius-md);
  background: #fff;
  padding: var(--space-sm);
}

.totp-secret-label {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin: 0 0 var(--space-xs);
  text-align: center;
}

.totp-secret {
  display: block;
  text-align: center;
  font-family: monospace;
  font-size: var(--font-size-sm);
  background: var(--bg-tertiary);
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  margin: 0 0 var(--space-lg);
  word-break: break-all;
  user-select: all;
}

.totp-code-input {
  text-align: center;
  font-family: monospace;
  font-size: var(--font-size-lg);
  letter-spacing: 0.3em;
}

.profile-header {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  padding: var(--space-lg);
  align-items: flex-start;
}

.profile-label {
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  margin: 0 0 0.25rem;
  color: var(--inline-action);
}

.profile-header-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.profile-follow-btn.is-following {
  background: var(--accent-primary);
  color: #fff;
  border-color: var(--accent-primary);
  box-shadow: 0 1px 3px var(--shadow-md);
}

.profile-header .profile-follow-btn[disabled] {
  opacity: 0.7;
}

.profile-avatar-wrap {
  position: relative;
  width: 110px;
  height: 110px;
  border-radius: var(--radius-md);
  background: var(--border-secondary);
  display: grid;
  place-items: center;
  overflow: visible;
  flex-shrink: 0;
  z-index: 6;
}

.profile-avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

.profile-username {
  margin: 0;
  line-height: 1.2;
  color: var(--text-secondary);
}

.profile-bio {
  flex-basis: 100%;
  margin: 0;
  font-size: 0.95rem;
  color: var(--text-secondary);
  white-space: pre-wrap;
}

.profile-stats-row {
  flex-basis: 100%;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  margin: 0;
}

.profile-section {
  padding: var(--space-md) var(--space-lg);
  border-top: 1px solid var(--border-secondary);
}

.profile-section-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary);
  margin: 0 0 var(--space-sm);
}

.profile-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.profile-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-sm);
  padding: var(--space-xs) 0;
}

.profile-item a {
  color: var(--text-primary);
  text-decoration: none;
  min-height: var(--hit-target-min);
  display: inline-flex;
  align-items: center;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-item a:hover {
  color: var(--accent-primary);
}

.profile-item .meta {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  white-space: nowrap;
  flex-shrink: 0;
}

.profile-links,
.profile-posts {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  align-items: flex-start;
  width: 100%;
}

.profile-posts .post {
  width: 100%;
  text-align: left;
}

.profile-posts .card-avatar {
  display: none;
}

.profile-link-card,
.profile-post-card {
  padding: 0.75rem;
  border-radius: 0.75rem;
  border: 1px solid var(--border-secondary);
  background: var(--bg-tertiary);
}

.profile-link-card h4,
.profile-post-card h4 {
  margin: 0 0 0.25rem;
  font-size: 1rem;
}

.profile-link-card p,
.profile-post-card p {
  margin: 0.35rem 0 0;
  color: var(--text-secondary);
  font-size: 0.9rem;
}

.profile-meta {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  font-size: 0.85rem;
  color: var(--text-muted);
}

.profile-meta a,
.profile-link {
  color: var(--profile-link);
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.profile-link:hover {
  opacity: 0.7;
}

.profile-meta a:hover {
  color: var(--accent-hover);
}

/* Override visited link color */
.profile-link:visited {
  color: var(--profile-link);
}

.following-panel {
  max-width: 900px;
  margin: 0 auto 3rem;
}

/* Profile info within header */
.profile-header .profile-info {
  flex: 1;
  min-width: 0;
}

.profile-header .profile-name {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0;
  line-height: 1;
  color: var(--profile-link);
}

.profile-header .profile-follow-btn {
  flex-shrink: 0;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.6rem;
  padding: 0.62rem 1.2rem;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  white-space: nowrap;
  transition:
    color var(--transition-fast),
    background-color var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

.profile-header .profile-follow-btn:not(:disabled):not(.is-following):hover {
  color: var(--text-primary);
  background-color: color-mix(
    in srgb,
    var(--color-canvas) 60%,
    var(--color-accent) 40%
  );
}

.profile-header .profile-follow-btn.is-following:not(:disabled):hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.profile-header .profile-follow-btn:disabled,
.profile-header .profile-follow-btn:disabled:hover {
  cursor: default;
}

/* Following users chips */
.following-users {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
  padding: var(--space-md);
  background: var(--bg-tertiary);
  border-radius: 0.75rem;
  border: 1px solid var(--border-secondary);
}

.following-users-header {
  width: 100%;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: var(--space-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.following-user-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  min-height: var(--hit-target-min);
  padding: 0.25rem 0.7rem 0.25rem 0.25rem;
  background: var(--bg-panel);
  border-radius: 999px;
  border: 1px solid var(--border-secondary);
  text-decoration: none;
  color: var(--text-primary);
  font-size: 0.85rem;
  transition: border-color 0.15s ease;
}

.following-user-chip:hover {
  border-color: var(--accent-primary);
  text-decoration: none;
}

.following-user-chip img {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
}

.following-user-chip .no-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--border-secondary);
}

/* Mobile responsive - tablets and below */
@media (max-width: 768px) {
  :root {
    --panel-inline-padding: var(--space-sm);
  }

  .top-bar {
    padding-block: calc(0.5rem * var(--nav-scale));
    gap: calc(0.5rem * var(--nav-scale));
  }

  .brand span:not(.logo-dot) {
    display: none;
  }

  .nav-segment-shell {
    --nav-segment-inset: calc(0.07rem * var(--nav-scale));
    gap: calc(0.03rem * var(--nav-scale));
    --nav-active-inset-inline: calc(0.02rem * var(--nav-scale));
  }

  .nav-control-btn {
    padding: calc(0.3rem * var(--nav-scale)) calc(0.72rem * var(--nav-scale));
    font-size: calc(0.9rem * var(--nav-scale));
  }

  .main-nav .nav-control-btn {
    padding-inline-start: calc(0.18rem * var(--nav-scale));
    padding-inline-end: calc(0.18rem * var(--nav-scale));
  }

  .main-nav {
    --main-nav-outer-pad: calc(0.58rem * var(--nav-scale));
    --main-nav-inner-pad: calc(0.24rem * var(--nav-scale));
    --main-nav-active-edge-inset: calc(0.02rem * var(--nav-scale));
    --main-nav-active-inner-trim: calc(0.182rem * var(--nav-scale));
  }

  .signed-in-info {
    display: none;
  }

  .landing {
    padding: 1.5rem 0.75rem 3rem;
  }

  .static-card {
    padding: 1.25rem;
    border-radius: 0.75rem;
  }

  .hero h1 {
    font-size: clamp(1.75rem, 5vw, 2.5rem);
  }

  .static-panel {
    padding: var(--space-md) var(--panel-inline-padding)
      calc(var(--space-lg) + var(--space-sm));
  }

  .panel-title {
    margin-bottom: var(--space-md);
    font-size: clamp(1.5rem, 4vw, 1.75rem);
  }

  [data-route-view="share"] > .panel-title {
    font-size: clamp(1.72rem, 5.45vw, 1.98rem);
  }

  .profile-header {
    flex-wrap: wrap;
    gap: var(--space-sm);
  }

  .profile-header .profile-avatar-wrap {
    width: 60px;
    height: 60px;
  }

  .profile-header .profile-follow-btn {
    width: 100%;
    order: 3;
  }

  .following-users {
    gap: var(--space-xs);
  }

  .post[data-depth="1"] {
    margin-left: var(--space-sm);
  }

  .post[data-depth="2"] {
    margin-left: var(--space-md);
  }

  .toast-stack {
    left: 0.75rem;
    right: 0.75rem;
    top: auto;
    bottom: 1rem;
  }

  .toast {
    min-width: auto;
    max-width: none;
    width: 100%;
  }

  .search-bar {
    flex-direction: column;
    align-items: stretch;
  }

  .search-bar input {
    min-width: auto;
    width: 100%;
  }

  .sort-controls {
    flex-wrap: wrap;
  }
}

/* Mobile responsive - phones */
@media (max-width: 480px) {
  #post-form {
    --post-body-width: min(88%, 31rem);
  }

  .top-bar {
    padding-block: calc(0.5rem * var(--nav-scale));
  }

  .top-bar-settings-wrap {
    --floating-settings-corner-gap: 0.5rem;
  }

  .nav-segment-shell {
    --nav-segment-inset: calc(0.06rem * var(--nav-scale));
    gap: calc(0.025rem * var(--nav-scale));
    --nav-active-inset-inline: calc(0.018rem * var(--nav-scale));
  }

  .nav-control-btn {
    padding: calc(0.26rem * var(--nav-scale)) calc(0.62rem * var(--nav-scale));
    font-size: calc(0.85rem * var(--nav-scale));
  }

  .main-nav .nav-control-btn {
    padding-inline-start: calc(0.16rem * var(--nav-scale));
    padding-inline-end: calc(0.16rem * var(--nav-scale));
  }

  .main-nav {
    --main-nav-outer-pad: calc(0.51rem * var(--nav-scale));
    --main-nav-inner-pad: calc(0.2rem * var(--nav-scale));
    --main-nav-active-edge-inset: calc(0.018rem * var(--nav-scale));
    --main-nav-active-inner-trim: calc(0.148rem * var(--nav-scale));
  }

  .landing {
    padding: 1rem 0.5rem 2rem;
    gap: 1rem;
  }

  .panel {
    padding: 1rem;
  }

  .hero h1 {
    font-size: 1.5rem;
  }

  [data-route-view="share"] > .panel-title {
    font-size: 1.74rem;
  }

  .link-row {
    flex-direction: column;
    gap: 0.5rem;
  }

  .vote-stack {
    flex-direction: row;
    align-self: flex-start;
  }

  .link-body {
    width: 100%;
  }

  .meta {
    font-size: 0.75rem;
  }

  .link-meta-actions {
    margin-left: 0;
    margin-top: 0.25rem;
  }

  body[data-route="discussion"] .static-card {
    padding: var(--space-sm);
  }

  .discussion-title-wrap h3 {
    font-size: var(--font-size-lg);
  }

  .post {
    padding: var(--space-xs) var(--space-sm);
  }

  .post .card-actions {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .post .card-actions[data-has-reply-toggle="true"] > .card-actions-hover {
    position: static;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
    transition-delay: 0s, 0s;
  }

  .card .card-link-actions,
  .discussion-header .card-link-actions {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .post[data-depth="1"] {
    margin-left: var(--space-xs);
  }

  .post[data-depth="2"] {
    margin-left: var(--space-sm);
  }

  .post-actions {
    gap: var(--space-xs);
  }

  .profile-avatar-wrap {
    width: 60px;
    height: 60px;
  }

  .profile-block {
    padding: 1rem;
  }

  .form-actions button {
    min-width: auto;
  }

  .sort-buttons {
    flex-wrap: wrap;
  }

  .sort-btn {
    padding: 0.3rem 0.6rem;
    font-size: 0.8rem;
  }

  .feed-master-filter .master-filter-option.sort-btn {
    min-height: 30px;
    padding: 0.05rem 0.4rem;
    font-size: 0.72rem;
    line-height: 1;
  }

  button {
    padding: 0.6rem 1rem;
  }

  input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
  select {
    padding: 0.24rem 0.75rem;
    min-height: 1.85rem;
  }

  textarea {
    padding: 0.6rem 0.85rem;
  }

  .flags-list li {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.35rem;
  }

  .moderator-filter-grid,
  .moderator-search-grid {
    grid-template-columns: 1fr;
  }

  .moderator-flag-row {
    grid-template-columns: 1fr;
    gap: 0.3rem;
  }
}

/* ============================================================================
   Shared Modal Styles
   ============================================================================ */

/* Modal containers */
.keyboard-help-modal,
.auth-modal,
.avatar-picker-modal,
.discussants-modal,
.confirm-modal {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  padding: var(--space-md);
}

.keyboard-help-modal[hidden],
.auth-modal[hidden],
.avatar-picker-modal[hidden],
.discussants-modal[hidden],
.confirm-modal[hidden] {
  display: none;
}

/* Modal backdrops */
.keyboard-help-modal,
.auth-modal-backdrop,
.avatar-picker-backdrop,
.discussants-modal-backdrop,
.confirm-modal-backdrop,
.waitlist-modal-backdrop {
  background: rgba(0, 0, 0, 0.5);
}

.auth-modal-backdrop,
.avatar-picker-backdrop,
.discussants-modal-backdrop,
.confirm-modal-backdrop,
.waitlist-modal-backdrop {
  position: absolute;
  inset: 0;
}

/* Modal content boxes */
.keyboard-help-content,
.auth-modal-content,
.avatar-picker-content,
.discussants-modal-content,
.confirm-modal-content {
  position: relative;
  background: var(--bg-panel);
  border-radius: var(--radius-lg);
  width: 100%;
  box-shadow: 0 25px 50px var(--shadow-lg);
}

.auth-modal-content,
.avatar-picker-content,
.discussants-modal-content,
.confirm-modal-content {
  animation: modal-enter 200ms ease-out;
}

/* Modal close buttons */
.keyboard-help-close,
.auth-modal-close,
.avatar-picker-close,
.discussants-modal-close,
.confirm-modal-close {
  position: absolute;
  top: var(--space-sm);
  right: var(--space-sm);
  background: none;
  border: none;
  font-size: 1.5rem;
  color: var(--text-muted);
  cursor: pointer;
  padding: var(--space-xs);
  line-height: 1;
}

.keyboard-help-close:hover,
.auth-modal-close:hover,
.avatar-picker-close:hover,
.discussants-modal-close:hover,
.confirm-modal-close:hover {
  opacity: 0.7;
}

@keyframes modal-enter {
  from {
    opacity: 0;
    transform: scale(0.95) translateY(-10px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

/* ============================================================================
   Keyboard Help Modal (specific styles)
   ============================================================================ */
.keyboard-help-content {
  padding: var(--space-lg);
  max-width: 500px;
}

.keyboard-help-content {
  background: var(--bg-panel);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  max-width: 500px;
  width: 100%;
  position: relative;
  box-shadow: 0 25px 50px var(--shadow-lg);
}

.keyboard-help-content h3 {
  margin: 0 0 var(--space-md);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
}

#command-palette-modal {
  align-items: flex-start;
  overflow-y: auto;
  padding: var(--command-palette-top, var(--space-md)) var(--space-md)
    var(--space-md);
}

.command-palette-content {
  max-width: 600px;
  box-sizing: border-box;
  overflow: hidden;
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.command-palette-context {
  width: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.command-palette-context.is-discuss {
  --command-palette-discuss-control-height: 2.36rem;
  --inline-discuss-control-height: var(
    --command-palette-discuss-control-height
  );
  --inline-discuss-input-font-size: var(--font-size-base);
  --inline-discuss-submit-min-width: 6.2rem;
}

.command-palette-input {
  width: 100%;
  box-sizing: border-box;
  border-radius: calc(var(--radius-md) + 2px);
  border: 1px solid var(--border-primary);
  padding: 0.95rem 1.05rem;
  font-size: var(--font-size-lg);
  line-height: 1.2;
  background: color-mix(in srgb, var(--bg-secondary) 92%, white 8%);
  color: var(--text-primary);
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast);
}

.command-palette-input::placeholder {
  color: var(--text-muted);
}

.command-palette-input:focus {
  outline: none;
  border-color: var(--border-secondary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--focus-ring) 20%, transparent);
}

.command-palette-context.is-discuss .command-palette-input {
  padding: 0;
}

.command-palette-context.is-discuss .command-palette-input:focus {
  border-color: transparent;
  box-shadow: none;
}

.command-palette-category-filter {
  max-width: 100%;
  align-self: flex-start;
  margin-bottom: 0;
}

.command-palette-category-filter .master-filter-group {
  max-width: 100%;
}

.command-palette-category-option:focus-visible,
.command-palette-category-filter .feed-search-input:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 1px;
}

.command-palette-status {
  margin: 0;
  color: var(--text-muted);
  font-size: var(--font-size-xs);
}

.command-palette-status[data-variant="error"] {
  color: var(--danger-primary);
}

.command-palette-list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 320px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.command-palette-item {
  width: 100%;
  box-sizing: border-box;
  min-height: var(--hit-target-min);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-sm);
  padding: 0.7rem 0.8rem;
  cursor: pointer;
  text-align: left;
  transition:
    background var(--transition-fast),
    border-color var(--transition-fast);
}

.command-palette-item:hover,
.command-palette-item.active {
  background: var(--bg-tertiary);
  border-color: var(--border-secondary);
}

.command-palette-list.is-hover-suppressed
  .command-palette-item:hover:not(.active) {
  background: transparent;
  border-color: transparent;
}

.command-palette-item-context {
  width: 100%;
  box-sizing: border-box;
}

.command-palette-item-label {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
}

.command-palette-empty {
  margin: 0;
  color: var(--text-muted);
  font-size: var(--font-size-sm);
}

.command-palette-hint {
  margin: 0;
  color: var(--text-muted);
  font-size: var(--font-size-xs);
}

.keyboard-help-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.shortcut-group h4 {
  margin: 0 0 var(--space-sm);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.shortcut {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-xs) 0;
  font-size: var(--font-size-sm);
}

.shortcut kbd {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-sm);
  font-family: var(--font-family);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  min-width: 1.5rem;
  text-align: center;
}

.shortcut span {
  color: var(--text-secondary);
}

/* ============================================================================
   Auth Modal (specific styles)
   ============================================================================ */
.auth-modal-content {
  padding: var(--space-xl);
  max-width: 400px;
}

.auth-modal-content h2 {
  margin: 0 0 var(--space-lg);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
}

.auth-modal-content
  input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
  width: 100%;
  box-sizing: border-box;
}

.auth-modal-content
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
#settings-action-2fa-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
#settings-tab-account
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
  appearance: none;
  -webkit-appearance: none;
}

.auth-modal-content
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
#settings-action-2fa-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
#settings-tab-account
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
  min-height: calc(var(--hit-target-min) + 2px);
  padding: 0.6rem 1rem;
  border: 1px solid var(--border-secondary);
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 8%,
    var(--border-secondary) 92%
  );
  border-radius: var(--radius-full);
  font-size: var(--font-size-base);
  line-height: 1.1;
  background: color-mix(in srgb, var(--bg-input) 96%, var(--accent-primary) 4%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 4%, transparent 96%),
    0 12px 28px rgba(2, 6, 23, 0.1);
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast),
    opacity var(--transition-fast);
}

.auth-modal-content
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
.auth-modal-content
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus,
#settings-action-2fa-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
#settings-action-2fa-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus,
#settings-tab-account
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
#settings-tab-account
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus {
  opacity: 1;
}

.auth-modal-content
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus,
#settings-action-2fa-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus,
#settings-tab-account
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus {
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 12%,
    var(--border-secondary) 88%
  );
  background: color-mix(in srgb, var(--bg-input) 90%, var(--bg-panel) 10%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 10%, transparent 90%),
    0 12px 28px rgba(2, 6, 23, 0.12);
}

#settings-tab-account
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
  min-height: 2.4rem;
  padding: 0.48rem 0.9rem;
  font-size: 0.95rem;
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 8%,
    var(--border-secondary) 92%
  );
  background: color-mix(in srgb, var(--bg-input) 96%, var(--accent-primary) 4%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 4%, transparent 96%),
    0 12px 28px rgba(2, 6, 23, 0.1);
}

#settings-tab-account
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus {
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 12%,
    var(--border-secondary) 88%
  );
  background: color-mix(in srgb, var(--bg-input) 90%, var(--bg-panel) 10%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 10%, transparent 90%),
    0 12px 28px rgba(2, 6, 23, 0.12);
}

.button-modal-action,
#settings-edit-keybindings-btn {
  min-height: 2.6rem;
  padding: 0.62rem 1.2rem;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  white-space: nowrap;
}

#settings-tab-account .button-primary,
#settings-tab-account .button-secondary,
#settings-tab-account .button-danger {
  min-height: 2.25rem;
  padding: 0.45rem 0.95rem;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  white-space: nowrap;
}

.auth-tab {
  min-height: 48px;
  padding: 0.08rem 0.48rem;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: 600;
  line-height: 1;
}

.auth-modal-content .button-modal-action {
  width: 100%;
}

/* Waitlist back button */
.waitlist-back-row {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  margin-bottom: var(--space-sm);
}

.waitlist-back-btn {
  border: none;
  background: transparent;
  font-size: var(--font-size-xl);
  line-height: 1;
  padding: var(--space-xs);
  margin: calc(-1 * var(--space-xs));
  color: var(--text-primary);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: opacity var(--transition-fast);
}

.waitlist-back-btn:hover,
.waitlist-back-btn:focus-visible {
  opacity: 0.7;
}

.waitlist-back-label {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Auth Modal Tabs */
.auth-tabs {
  display: flex;
  gap: var(--space-xs);
  margin-bottom: var(--space-lg);
}

.auth-tab {
  flex: 1;
  background: var(--accent-light);
  border: 1px solid transparent;
  color: var(--accent-hover);
  cursor: pointer;
  transition: opacity var(--transition-fast);
}

.auth-tab:not(.active):hover {
  opacity: 0.85;
}

.auth-tab.active {
  background: var(--accent-hover);
  border-color: transparent;
  color: #fff;
}

.auth-tab.active:hover {
  opacity: 1;
}

/* Auth modal form - maintain consistent height between tabs */
#auth-modal-form {
  display: flex;
  flex-direction: column;
}

#auth-modal-form #modal-auth-status {
  min-height: 0;
}

#auth-modal-form #modal-auth-status:empty {
  display: none;
}

#auth-modal-form #modal-auth-status:not(:empty) {
  display: block;
}

#signup-only-fields {
  min-height: 3.5rem;
}

.form-actions[hidden] {
  display: none;
}

.auth-modal-content .form-actions {
  margin-bottom: var(--space-sm);
}

.auth-security-note {
  margin: 0 0 var(--space-sm);
  color: var(--text-muted);
  font-size: var(--font-size-xs);
  line-height: var(--line-height-relaxed);
}

.auth-security-note a {
  color: var(--accent-primary);
  text-decoration: underline;
}

.auth-modal-content .auth-oauth-divider {
  position: relative;
  margin: var(--space-xs) 0;
  text-align: center;
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

.auth-modal-content .auth-oauth-divider::before {
  content: "";
  position: absolute;
  inset: 50% 0 auto;
  border-top: 1px solid var(--border-secondary);
}

.auth-modal-content .auth-oauth-divider > span {
  position: relative;
  z-index: 1;
  padding: 0 var(--space-sm);
  background: var(--bg-panel);
}

.oauth-google-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ============================================================================
   Avatar Picker Modal (specific styles)
   ============================================================================ */
.avatar-picker-content {
  padding: var(--space-xl);
  max-width: 320px;
  text-align: center;
}

.avatar-picker-content h3 {
  margin: 0 0 var(--space-lg);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
}

.avatar-picker-content .avatar-color-picker {
  display: flex;
  justify-content: center;
  gap: var(--space-md);
}

.avatar-picker-content .avatar-color-btn {
  width: 48px;
  height: 48px;
}

/* Clickable avatar/cover (own profile) */
.profile-cover.editable,
.profile-avatar-wrap.editable {
  cursor: pointer;
  transition:
    transform var(--transition-fast),
    box-shadow var(--transition-fast),
    filter var(--transition-fast);
}

.profile-cover.editable:hover {
  transform: translateY(-2px) scale(1.01);
  box-shadow:
    inset 0 0 0 4px var(--bg-secondary),
    0 10px 24px var(--shadow-md);
  filter: saturate(1.04) brightness(1.02);
}

.profile-avatar-wrap.editable:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 12px var(--shadow-md);
}

.profile-cover.editable::after,
.profile-avatar-wrap.editable::after {
  content: "✎";
  position: absolute;
  bottom: -2px;
  right: -2px;
  width: 22px;
  height: 22px;
  background: var(--bg-panel);
  border: 2px solid var(--border-secondary);
  border-radius: 50%;
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-fast);
}

.profile-cover.editable::after {
  bottom: 10px;
  right: 10px;
}

.profile-avatar-wrap.editable::after {
  bottom: -2px;
  right: -2px;
}

.profile-cover.editable:hover::after,
.profile-avatar-wrap.editable:hover::after {
  opacity: 1;
}

/* Inline editable text */
.profile-name.editable,
.profile-bio.editable,
.profile-name.is-editing,
.profile-bio.is-editing {
  cursor: pointer;
  transition: background var(--transition-fast);
  border-radius: var(--radius-sm);
  padding: 0 var(--space-xs);
  margin: 0 calc(-1 * var(--space-xs));
}

.profile-name.is-editing,
.profile-bio.is-editing {
  cursor: text;
  background: transparent;
}

.profile-name.editable:hover,
.profile-bio.editable:hover {
  background: var(--bg-tertiary);
}

/* Inline edit input (high-specificity overrides against global input/textarea rules) */
input.profile-inline-edit:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ),
textarea.profile-inline-edit {
  width: 100%;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
  font: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  border: 0;
  border-radius: var(--radius-sm);
  background: transparent;
  color: inherit;
  padding: 0;
  margin: 0;
  min-height: 0;
}

input.profile-inline-edit:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
textarea.profile-inline-edit:hover {
  opacity: 1;
}

input.profile-inline-edit:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus,
textarea.profile-inline-edit:focus {
  outline: 2px solid var(--focus-ring);
  outline-offset: 1px;
  background: transparent;
  box-shadow: none;
}

.profile-name-edit {
  display: block;
  caret-color: currentColor;
}

.profile-name-edit::placeholder {
  color: var(--text-secondary);
}

textarea.profile-inline-edit.profile-bio-edit {
  display: block;
  font-size: 1rem;
  font-style: italic;
  line-height: 1.6;
  color: var(--text-secondary);
  resize: none;
  min-height: 1.6em;
  border: none;
  outline: none;
  box-shadow: none;
}

textarea.profile-inline-edit.profile-bio-edit:focus {
  outline: none;
  border: none;
  box-shadow: none;
}

.profile-bio-edit::placeholder {
  color: var(--text-tertiary);
  font-style: italic;
}

/* Avatar Color Picker */
.avatar-color-picker {
  display: flex;
  gap: var(--space-sm);
}

.avatar-color-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 3px solid transparent;
  cursor: pointer;
  transition:
    transform var(--transition-fast),
    border-color var(--transition-fast);
  padding: 0;
}

.avatar-color-btn:hover {
  transform: scale(1.1);
}

.avatar-color-btn.selected {
  border-color: var(--text-primary);
}

.avatar-color-blue {
  background: var(--avatar-blue);
}

.avatar-color-green {
  background: var(--avatar-green);
}

.avatar-color-purple {
  background: var(--avatar-purple);
}

.avatar-color-orange {
  background: var(--avatar-orange);
}

/* Avatar display colors */
.profile-avatar-wrap.avatar-blue {
  background: var(--avatar-blue);
}

.profile-avatar-wrap.avatar-green {
  background: var(--avatar-green);
}

.profile-avatar-wrap.avatar-purple {
  background: var(--avatar-purple);
}

.profile-avatar-wrap.avatar-orange {
  background: var(--avatar-orange);
}

/* Avatar initial letter */
.profile-avatar-initial {
  font-size: 2.5rem;
  font-weight: var(--font-weight-bold);
  color: white;
  text-transform: uppercase;
}

.profile-avatar-wrap.discussion-avatar {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  overflow: hidden;
  flex-shrink: 0;
  margin-top: -0.1rem;
}

.profile-avatar-wrap.discussion-avatar .profile-avatar-initial {
  font-size: 0.95rem;
  line-height: 1;
}

/* Card avatars */
.card-avatar {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-avatar.avatar-blue {
  background: var(--avatar-blue);
}

.card-avatar.avatar-green {
  background: var(--avatar-green);
}

.card-avatar.avatar-purple {
  background: var(--avatar-purple);
}

.card-avatar.avatar-orange {
  background: var(--avatar-orange);
}

.card-avatar-initial {
  font-size: 0.875rem;
  font-weight: var(--font-weight-bold);
  color: white;
  text-transform: uppercase;
  line-height: 1;
}

/* ============================================================================
   Site Footer
   ============================================================================ */
.site-footer {
  margin-top: auto;
  padding: var(--space-md) var(--space-md)
    calc(var(--space-lg) + var(--space-xs));
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}

.footer-links,
.footer-copyright {
  color: var(--text-muted);
}

.footer-links {
  font-size: var(--font-size-xs);
}

.footer-links {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.footer-links a {
  color: inherit;
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.footer-copyright a {
  color: inherit;
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.footer-links a:hover,
.footer-links a:focus-visible,
.footer-copyright a:hover,
.footer-copyright a:focus-visible {
  opacity: 0.7;
}

.footer-separator {
  color: var(--border-secondary);
}

.footer-copyright {
  margin: calc(var(--space-md) - 8px) 0 0;
  font-size: calc(var(--font-size-xs) * 0.85);
  color: color-mix(in srgb, var(--text-muted) 68%, var(--bg-body) 32%);
}

/* ============================================================================
   Static Card Styles (used by all pages)
   ============================================================================ */
.static-card {
  background: var(--bg-panel);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  box-shadow: 0 4px 24px var(--shadow-md);
}

.static-card h1 {
  margin: 0 0 var(--space-xs);
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  letter-spacing: -0.02em;
  color: var(--text-primary);
}

.static-tagline {
  margin: 0 0 var(--space-xl);
  font-size: var(--font-size-lg);
  color: var(--text-muted);
}

.static-updated {
  margin: 0 0 var(--space-xl);
  font-size: var(--font-size-sm);
  color: var(--text-muted);
}

.static-content {
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
}

.static-content h2 {
  margin: var(--space-lg) 0 var(--space-sm);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

.static-content p {
  margin: 0 0 var(--space-md);
}

.static-content a {
  color: var(--accent-primary);
  text-decoration: none;
}

.static-content a:hover {
  text-decoration: underline;
}

/* Pricing specific */
.about-pricing-section {
  margin-top: var(--space-xl);
  scroll-margin-top: 5rem;
}

.about-pricing-section h2 {
  margin-top: 0;
}

.pricing-tier {
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  text-align: center;
}

.pricing-price {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--font-weight-bold);
  color: var(--accent-primary);
  margin: var(--space-sm) 0;
}

.pricing-features {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0 0;
}

.pricing-features li {
  padding: var(--space-xs) 0;
  color: var(--text-secondary);
}

.pricing-features li::before {
  content: "✓ ";
  color: var(--accent-primary);
}

.pricing-note {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  text-align: center;
}

/* Extensions specific */
.extension-item {
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin: var(--space-lg) 0;
}

.extension-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.extension-header svg {
  color: var(--accent-primary);
  flex-shrink: 0;
}

.extension-header h2 {
  margin: 0;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

.extension-item p {
  margin: 0 0 var(--space-md);
}

.extension-meta {
  color: var(--text-secondary);
}

.extension-status {
  margin-bottom: 0;
  font-size: var(--font-size-sm);
  color: var(--text-muted);
}

.extension-item kbd {
  background: var(--bg-tertiary);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-sm);
  padding: 0.1rem 0.4rem;
  font-family: var(--font-mono);
  font-size: var(--font-size-xs);
}

.extension-link {
  color: var(--accent-primary);
  text-decoration: none;
  font-weight: var(--font-weight-medium);
}

.extension-link:hover {
  text-decoration: underline;
}

/* ============================================================================
   Legal Pages (Terms, Privacy)
   ============================================================================ */
.legal-page {
  max-width: 700px;
  margin: 0 auto;
  padding: var(--space-xl) var(--space-md) var(--space-2xl);
}

.legal-page[hidden] {
  display: none;
}

.legal-content {
  background: var(--bg-panel);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  box-shadow: 0 4px 24px var(--shadow-md);
}

.legal-content h1 {
  margin: 0 0 var(--space-xs);
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  letter-spacing: -0.02em;
  color: var(--text-primary);
}

.legal-updated {
  margin: 0 0 var(--space-xl);
  font-size: var(--font-size-sm);
  color: var(--text-muted);
}

.legal-content h2 {
  margin: var(--space-lg) 0 var(--space-sm);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

.legal-content h2:first-of-type {
  margin-top: 0;
}

.legal-content p {
  margin: 0 0 var(--space-md);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
}

.legal-content p:last-child {
  margin-bottom: 0;
}

/* ============================================================================
   Terms Checkbox (Auth Modal)
   ============================================================================ */
.field-checkbox {
  margin-top: var(--space-sm);
  text-align: center;
}

.checkbox-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  min-height: var(--hit-target-min);
  padding: 0.2rem 0.35rem;
  font-weight: var(--font-weight-normal);
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  cursor: pointer;
  white-space: nowrap;
}

.checkbox-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  accent-color: var(--accent-primary);
  cursor: pointer;
  margin: 0;
}

.checkbox-label input[type="checkbox"]:focus {
  outline: none;
}

.checkbox-label a {
  color: var(--text-link);
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.checkbox-label a:hover {
  opacity: 0.7;
}

.field-error {
  margin: var(--space-xs) 0 0;
  font-size: var(--font-size-sm);
  color: var(--color-error, #dc2626);
}

.field-error:empty {
  display: none;
}

/* ============================================================================
   Legal Pages Responsive
   ============================================================================ */
@media (max-width: 768px) {
  .legal-content {
    padding: var(--space-lg);
  }

  .legal-page {
    padding: var(--space-md) var(--space-sm) var(--space-xl);
  }
}

@media (max-width: 480px) {
  .legal-content {
    padding: var(--space-md);
    border-radius: var(--radius-md);
  }

  .site-footer {
    padding: var(--space-lg) var(--space-sm);
  }
}

/* ============================================================================
   Discussants Modal (specific styles)
   ============================================================================ */
.discussants-modal-content {
  padding: var(--space-xl);
  max-width: 360px;
}

.discussants-modal-title {
  margin: 0 0 var(--space-md);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
}

.discussants-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  max-height: 300px;
  overflow-y: auto;
}

.discussant-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
}

.discussant-item:hover {
  background: var(--bg-hover);
}

.discussant-item a {
  color: var(--profile-link);
  text-decoration: none;
  font-weight: var(--font-weight-normal);
  transition: opacity var(--transition-fast);
}

.discussant-item a:hover {
  opacity: 0.7;
}

.discussant-starter-marker {
  line-height: 1;
}

/* Card discussant button */
.card-discussant-btn {
  display: inline-flex;
  align-items: center;
  background: none;
  border: none;
  min-height: var(--hit-target-min);
  padding: 0.35rem 0.25rem;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  color: var(--discussant-link);
  cursor: pointer;
  text-decoration: none;
  transition:
    color var(--transition-fast),
    opacity var(--transition-fast);
}

.card-discussant-btn:hover {
  color: var(--accent-hover);
  opacity: 0.96;
}

.card-discussant-btn:focus-visible {
  color: var(--accent-hover);
  opacity: 0.96;
}

/* ============================================================================
   Confirm Modal (specific styles)
   ============================================================================ */
.confirm-modal-content {
  padding: var(--space-xl);
  max-width: 400px;
}

.confirm-modal-content h2 {
  margin: 0 0 var(--space-md);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
}

.confirm-modal-message {
  margin: 0 0 var(--space-lg);
  color: var(--text-secondary);
  line-height: 1.5;
  word-break: break-word;
}

.confirm-modal-actions {
  display: flex;
  gap: var(--space-sm);
  justify-content: flex-end;
}

.confirm-modal-actions button {
  min-width: 80px;
}

#delete-account-modal .confirm-modal-actions,
#disable-2fa-modal .confirm-modal-actions,
#settings-action-2fa-modal .confirm-modal-actions {
  margin-top: var(--space-md);
  justify-content: center;
}

#delete-account-modal .field + .field,
#disable-2fa-modal .field + .field,
#settings-action-2fa-modal .field + .field {
  margin-top: var(--space-md);
}

#delete-account-modal .confirm-modal-actions button,
#disable-2fa-modal .confirm-modal-actions button,
#settings-action-2fa-modal .confirm-modal-actions button {
  min-width: 0;
  min-height: 2.25rem;
  padding: 0.45rem 0.95rem;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  white-space: nowrap;
}

#report-reason-modal .confirm-modal-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8.75rem, 1fr));
  justify-content: stretch;
}

.moderator-action-modal-content {
  max-width: 32rem;
}

.moderator-action-modal-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.moderator-action-modal-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
}

.moderator-action-modal-textarea {
  min-height: 7.25rem;
  resize: vertical;
}

.moderator-action-modal-hint,
.moderator-action-modal-error {
  margin: 0;
  font-size: var(--font-size-xs);
  line-height: 1.45;
}

.moderator-action-modal-hint {
  color: var(--text-secondary);
}

.moderator-action-modal-error {
  color: var(--danger-primary);
}

#moderator-action-modal .confirm-modal-actions {
  margin-top: var(--space-md);
}

#report-reason-modal .report-reason-extra {
  margin: 0 0 var(--space-sm);
  text-align: left;
}

#report-reason-modal .report-reason-checkbox {
  justify-content: flex-start;
  width: 100%;
  white-space: normal;
  color: var(--text-primary);
}

#report-reason-modal .report-reason-hint {
  margin: 0;
  font-size: var(--font-size-xs);
  line-height: 1.45;
  color: var(--text-muted);
}

#report-reason-modal .confirm-modal-actions button {
  width: 100%;
  min-width: 0;
}

#report-reason-modal .report-reason-cancel-btn {
  grid-column: 1 / -1;
  justify-self: center;
  width: min(100%, 10.5rem);
  color: var(--text-secondary);
  border-color: var(--border-secondary);
}

/* ============================================================================
   Profile Activity Timeline
   ============================================================================ */
.profile-activity-section {
  padding: var(--space-md) var(--space-lg);
  border-top: 1px solid var(--border-secondary);
}

.profile-activity-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.profile-activity-list .empty-state {
  list-style: none;
}

.profile-activity-actions {
  display: flex;
  justify-content: center;
}

/* ============================================================================
   Unified Card Component (used by feed and profile activity)
   ============================================================================ */
.card {
  display: flex;
  gap: var(--space-sm);
  padding: 0.62rem var(--space-md) 0.38rem;
  border-radius: var(--radius-md);
  background: var(--link-row-bg);
  transition: background var(--transition-fast);
  align-items: stretch;
  cursor: pointer;
  position: relative;
}

.card.card-has-link-actions {
  padding-bottom: 0.58rem;
}

.card:hover {
  background: var(--bg-secondary);
}

.card.profile-activity-item,
.card.profile-activity-item:hover {
  background: transparent;
}

.profile-activity-post {
  cursor: pointer;
}

.profile-activity-post:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

.profile-activity-post .card-title {
  display: block;
  margin-left: 0.02rem;
  width: fit-content;
  max-width: calc(100% - var(--post-time-col-width) - var(--space-sm));
}

.profile-activity-post .card-body {
  padding-top: 0;
}

.profile-activity-post .card-body .card-time-inline-body {
  margin-top: 0;
  line-height: var(--line-height-tight);
}

.card:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

.card-content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0;
  flex: 1;
  min-width: 0;
}

.card-title {
  color: var(--text-link);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  line-height: var(--line-height-tight);
  margin-top: 0.1rem;
  margin-left: 0.15rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: color var(--transition-fast);
  width: fit-content;
  max-width: 100%;
}

.card-title:hover {
  color: var(--text-primary);
}

.card-meta {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0;
}

.card-post-count,
.card-category-label {
  display: inline-flex;
  align-items: center;
  min-height: var(--hit-target-min);
  padding: 0.35rem 0.25rem;
  color: var(--discussant-link);
  transition:
    color var(--transition-fast),
    opacity var(--transition-fast);
}

.card-meta-sep {
  color: var(--text-muted);
}

.card-preview {
  margin: 0;
  margin-left: 0.2rem;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-tight);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.card-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: space-between;
  gap: 4px;
  flex-shrink: 0;
}

.post .card-right {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  width: var(--post-time-col-width);
  min-width: var(--post-time-col-width);
  align-self: auto;
  justify-content: flex-start;
  gap: 0;
}

.post .card-right .star-btn {
  margin-left: auto;
}

.card-time {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  white-space: nowrap;
}

.post .card-time {
  min-height: 0;
  display: inline-flex;
  align-items: center;
}

/* Star button in cards */
.card .star-btn {
  padding: 2px 6px;
  font-size: 0.825rem;
  color: var(--star-vote);
}

.card .star-btn:hover {
  color: var(--star-vote-hover);
}

.card .star-btn.starred {
  color: var(--star-vote-active);
}

.card .star-btn.starred:hover {
  color: var(--star-vote-active-hover);
}

/* Card action buttons (report/delete) - inline in meta */
.card-actions {
  display: inline-flex;
  gap: var(--space-sm);
  margin-left: var(--space-sm);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  will-change: opacity;
  transition:
    opacity 420ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0s linear 420ms;
}

.card:hover .card-actions,
.card:focus-within .card-actions,
.post:hover .card-actions,
.post:focus-within .card-actions {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0s, 0s;
}

.post[data-action-hold="true"] .card-actions {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0s, 0s;
}

.post .card-actions {
  margin-left: 0;
}

.card-action {
  background: transparent;
  border: none;
  color: var(--inline-action);
  font-size: var(--font-size-xs);
  padding: 0.35rem 0.45rem;
  cursor: pointer;
  text-decoration: none;
  transition: opacity var(--transition-fast);
  min-height: var(--hit-target-min);
}

.card-action:hover,
.card-action:focus-visible {
  opacity: 0.7;
}

.card-action.danger {
  color: var(--danger-primary);
}

.card-action.danger:hover,
.card-action.danger:focus-visible {
  opacity: 0.7;
}

/* Link-level actions (Report / Delete) — hidden by default, shown on hover */
.card-link-actions {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity var(--transition-fast);
}

.card-link-actions-row {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.35rem;
  width: auto;
  max-width: 100%;
}

.discussion-category-editor {
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0.3rem;
}

.discussion-category-editor-label {
  font-size: var(--font-size-xs);
  color: var(--text-secondary);
}

.discussion-editor-control {
  box-sizing: border-box;
  width: 7rem;
  min-width: 7rem;
  max-width: 7rem;
  min-height: calc(var(--hit-target-min) * 0.88);
  border: 1px solid var(--border-primary);
  border-radius: 999px;
  background: var(--bg-input);
  color: var(--text-primary);
  font-size: var(--font-size-xs);
  padding: 0.35rem 0.6rem;
  transition:
    opacity var(--transition-fast),
    border-color var(--transition-fast),
    background var(--transition-fast);
}

.moderator-filter-grid select,
.discussion-category-select {
  appearance: none;
  -webkit-appearance: none;
  height: 1.72rem;
  min-height: 1.72rem;
  border-radius: var(--radius-sm);
  padding: 0 1.35rem 0 0.75rem;
  line-height: 1.1;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--text-secondary) 50%),
    linear-gradient(135deg, var(--text-secondary) 50%, transparent 50%);
  background-position:
    calc(100% - 0.9rem) 50%,
    calc(100% - 0.58rem) 50%;
  background-size:
    0.38rem 0.38rem,
    0.38rem 0.38rem;
  background-repeat: no-repeat;
}

.discussion-category-select {
  width: auto;
  min-width: 0;
  max-width: 100%;
}

.discussion-featured-rank-input.discussion-editor-control {
  width: auto;
  min-width: 0;
  max-width: 100%;
}

.discussion-editor-control:hover {
  opacity: 0.7;
}

.discussion-editor-control:focus {
  outline: none;
}

.discussion-editor-save-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: calc(var(--hit-target-min) * 0.88);
  min-width: 0;
  flex: 0 0 auto;
  width: fit-content;
  padding: 0.14rem 0.16rem 0.08rem;
  white-space: nowrap;
}

.discussion-featured-rank-editor {
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
}

.discussion-moderator-actions-row {
  align-items: center;
  flex-wrap: nowrap;
  width: fit-content;
  min-width: 0;
  max-width: 100%;
  flex: 0 0 auto;
  align-self: flex-start;
  overflow-x: auto;
  overflow-y: hidden;
}

.discussion-moderator-dropdown .discussion-moderator-actions-row {
  width: fit-content;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.45rem;
  overflow: visible;
}

.discussion-moderator-dropdown .discussion-category-editor,
.discussion-moderator-dropdown .discussion-featured-rank-editor {
  width: fit-content;
  min-width: 0;
  max-width: 100%;
}

.discussion-moderator-dropdown .discussion-category-editor-label {
  min-width: 4rem;
}

.discussion-moderator-dropdown .discussion-editor-control {
  flex: 0 0 auto;
  width: auto;
  max-width: 100%;
}

.discussion-moderator-dropdown .discussion-editor-save-btn {
  padding-inline: 0.45rem;
}

.discussion-moderator-dropdown .delete-link-btn {
  align-self: flex-start;
}

.discussion-moderator-actions-row
  input.discussion-featured-rank-input.discussion-editor-control:not(
    [type="checkbox"]
  ):not([type="radio"]):not([type="hidden"]) {
  appearance: none;
  -webkit-appearance: none;
  height: 1.72rem;
  min-height: 1.72rem;
  border-radius: var(--radius-sm);
  padding: 0 0.45rem 0 0.75rem;
  line-height: 1.1;
  font-size: var(--font-size-xs);
}

.draft-meta-category-control {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 1.5rem;
  color: var(--discussant-link);
}

.draft-meta-category-trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.14rem;
  min-height: 1.5rem;
  padding: 0.08rem 0.25rem;
  border: none;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
  transition:
    color var(--transition-fast),
    opacity var(--transition-fast);
}

.draft-meta-category-trigger:hover,
.draft-meta-category-trigger:focus-visible,
.draft-meta-category-control:focus-within .draft-meta-category-trigger {
  color: var(--accent-hover);
}

.draft-meta-category-trigger:focus {
  outline: none;
}

.draft-meta-category-menu {
  top: calc(100% + 8px);
  left: 0;
  min-width: max-content;
}

.draft-meta-category-item.is-active {
  background: var(--bg-tertiary);
  color: var(--accent-hover);
}

.draft-meta-category-item {
  justify-content: center;
  width: auto;
  min-width: 100%;
  padding-inline: 0.85rem;
}

.draft-meta-category-chevron {
  width: 0.6rem;
  height: 0.4rem;
  flex: 0 0 auto;
  opacity: 0.9;
  pointer-events: none;
  background-color: currentColor;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.card-link-row {
  display: flex;
  width: calc(100% + var(--post-time-col-width) + var(--space-sm));
  align-items: center;
  min-height: 1.5rem;
  margin-top: 0;
  gap: 0.25rem;
}

.card.card-has-link-actions .card-link-row {
  margin-top: -0.1rem;
}

.card-link-row .card-link-actions {
  margin-right: auto;
}

.card-link-row .card-time-inline {
  margin-left: auto;
  min-height: 1.5rem;
  display: inline-flex;
  align-items: center;
}

.card.card-has-link-actions .card-content {
  justify-content: flex-start;
}

.card.card-has-link-actions .card-meta {
  margin-top: 0.3rem;
  width: calc(100% + var(--post-time-col-width) + var(--space-sm));
  flex-wrap: nowrap;
}

.card.card-has-link-actions .card-title {
  margin-top: 0.3rem;
}

.card.card-has-link-actions .card-right {
  width: var(--post-time-col-width);
  align-self: flex-start;
  padding-top: 0.4rem;
}

.card.card-has-link-actions .star-btn {
  min-height: 1.25rem;
  padding-top: 0;
  padding-bottom: 0;
}

.card.card-has-link-actions .card-meta .card-time-inline {
  margin-left: auto;
  min-height: 1.5rem;
  display: inline-flex;
  align-items: center;
}

.card.card-has-link-actions:hover .card-meta .card-post-count,
.card.card-has-link-actions:focus-within .card-meta .card-post-count {
  color: var(--accent-hover);
  opacity: 0.96;
}

.card.card-has-link-actions:hover:has(.card-title:hover)
  .card-meta
  .card-post-count,
.card.card-has-link-actions:hover:has(.card-discussant-btn:hover)
  .card-meta
  .card-post-count,
.card.card-has-link-actions:focus-within:has(.card-title:focus-visible)
  .card-meta
  .card-post-count,
.card.card-has-link-actions:focus-within:has(.card-discussant-btn:focus-visible)
  .card-meta
  .card-post-count {
  color: var(--discussant-link);
  opacity: 1;
}

.card .card-content > .card-link-actions {
  margin-top: 0.3rem;
  min-height: 1.75rem;
}

.card-link-actions .card-action {
  min-height: 1.5rem;
  padding: 0.14rem 0.35rem 0.08rem;
  line-height: 1.1;
}

.card.card-has-link-actions .card-meta .card-discussant-btn,
.card.card-has-link-actions .card-meta .card-post-count,
.card.card-has-link-actions .card-meta .card-category-label,
#discussion-meta .card-discussant-btn,
#discussion-meta .card-post-count,
#discussion-meta .card-category-label,
#discussion-meta .draft-meta-category-trigger {
  min-height: 1.5rem;
  padding-top: 0.08rem;
  padding-bottom: 0.08rem;
}

#discussion-meta {
  width: 100%;
  flex-wrap: nowrap;
  margin-top: -0.2rem;
}

#discussion-meta .card-meta-time {
  margin-left: auto;
  margin-right: 0.6rem;
  min-height: 1.5rem;
  display: inline-flex;
  align-items: center;
  padding-top: 0.08rem;
  padding-bottom: 0.08rem;
}

.post-actions .card-action {
  min-height: 1.75rem;
  padding: 0.2rem 0.45rem;
}

.card:hover .card-link-actions,
.card:focus-within .card-link-actions,
.discussion-header:hover .card-link-actions,
.discussion-header:focus-within .card-link-actions {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.discussion-header .card-link-actions {
  width: 100%;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.discussion-header .card-link-actions .card-link-actions-row {
  width: auto;
  max-width: 100%;
}

/* Legacy aliases - keep .link-row working during transition */
.link-row {
  display: flex;
  gap: 0.68rem;
  padding: 0.72rem 0.95rem 0.76rem;
  border-radius: var(--radius-md);
  background: var(--link-row-bg);
  transition: background var(--transition-fast);
  align-items: flex-start;
  cursor: pointer;
  position: relative;
}

.link-row:hover {
  background: var(--bg-secondary);
}

.link-row:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

/* ============================================================================
   Profile Visual Polish
   ============================================================================ */
.profile-header {
  display: flex;
  gap: var(--space-lg);
  padding: calc(var(--space-xl) - 2px) var(--space-lg) var(--space-lg);
  align-items: flex-start;
}

.profile-header .profile-name {
  font-size: 1.5rem;
  font-weight: var(--font-weight-bold);
  margin: 0;
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--profile-link);
}

.profile-stats-row {
  display: flex;
  gap: 0.85rem;
}

/* ============================================================================
   Profile Cover Banner
   ============================================================================ */
.profile-cover {
  position: relative;
  z-index: 0;
  height: 120px;
  box-sizing: border-box;
  border-radius: var(--radius-md);
  box-shadow:
    inset 0 0 0 4px var(--bg-secondary),
    0 2px 8px rgba(0, 0, 0, 0.15);
  overflow: hidden;
  background: linear-gradient(
    135deg,
    var(--cover-start) 0%,
    var(--cover-end) 100%
  );
}

/* Cover color variants */
.cover-blue {
  --cover-start: color-mix(
    in srgb,
    var(--accent-primary) 88%,
    var(--bg-panel) 12%
  );
  --cover-end: color-mix(
    in srgb,
    var(--accent-primary) 64%,
    var(--text-primary) 36%
  );
}

.cover-green {
  --cover-start: color-mix(
    in srgb,
    var(--accent-primary) 72%,
    var(--bg-panel) 28%
  );
  --cover-end: color-mix(
    in srgb,
    var(--accent-primary) 84%,
    var(--text-primary) 16%
  );
}

.cover-purple {
  --cover-start: color-mix(
    in srgb,
    var(--text-primary) 54%,
    var(--bg-panel) 46%
  );
  --cover-end: color-mix(
    in srgb,
    var(--text-primary) 68%,
    var(--accent-primary) 32%
  );
}

.cover-orange {
  --cover-start: color-mix(
    in srgb,
    var(--accent-primary) 58%,
    var(--text-primary) 42%
  );
  --cover-end: color-mix(
    in srgb,
    var(--accent-primary) 82%,
    var(--text-primary) 18%
  );
}

/* Avatar overlaps cover, info stays below */
.profile-card .profile-header {
  position: relative;
  margin-top: -40px;
  padding-top: var(--space-md);
  flex-wrap: wrap;
  z-index: 5;
  pointer-events: none;
}

.profile-card .profile-avatar-wrap {
  border: 4px solid var(--bg-secondary);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  align-self: flex-end;
  margin-left: calc(-1 * var(--space-md));
  z-index: 7;
}

.profile-card .profile-header > * {
  pointer-events: auto;
}

.profile-card .profile-info {
  padding-top: 44px;
  pointer-events: none;
}

.profile-card .profile-info > * {
  pointer-events: auto;
}

.profile-card .profile-follow-btn {
  margin-top: 44px;
  align-self: flex-start;
}

/* ============================================================================
   Profile Bio Styling
   ============================================================================ */
.profile-bio.has-bio,
.profile-bio.no-bio {
  font-style: italic;
  font-size: 1rem;
  line-height: 1.6;
  border-left: none;
  padding-left: var(--space-md);
  position: relative;
  margin-top: var(--space-sm);
}

.profile-bio.has-bio::before,
.profile-bio.no-bio::before {
  content: '"';
  position: absolute;
  left: var(--space-xs);
  top: -4px;
  font-size: 1.5rem;
  color: var(--accent-primary);
  opacity: 0.4;
  font-family: Georgia, serif;
  line-height: 1;
}

.profile-bio.no-bio {
  color: var(--text-tertiary);
  min-height: 1.6em;
}

.profile-bio.own-empty-bio,
.profile-bio.is-editing[data-editor-bio-empty="true"] {
  color: var(--text-secondary);
}

.profile-bio.own-empty-bio::after,
.profile-bio.is-editing[data-editor-bio-empty="true"]::after {
  content: attr(data-empty-bio-placeholder);
  position: absolute;
  left: var(--space-md);
  top: 0;
  color: currentColor;
  font-family: inherit;
  font-size: inherit;
  font-style: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  pointer-events: none;
  text-align: inherit;
  white-space: pre-wrap;
}

.profile-bio.is-editing[data-editor-bio-empty="true"]::after {
  content: attr(data-editor-bio-placeholder);
}

/* ============================================================================
   Profile Stats Pills
   ============================================================================ */
.profile-stat-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  white-space: nowrap;
}

.profile-stat-pill .stat-icon {
  flex-shrink: 0;
  opacity: 0.7;
}

.profile-stat-pill .stat-count {
  font-weight: normal;
}

/* ============================================================================
   Profile Mobile Responsive
   ============================================================================ */
@media (max-width: 480px) {
  .profile-cover {
    height: 80px;
  }

  .profile-card .profile-header {
    margin-top: -30px;
  }

  .profile-card .profile-info {
    padding-top: 34px;
  }

  .profile-card .profile-follow-btn {
    margin-top: 0;
    width: 100%;
  }

  .profile-bio.has-bio {
    text-align: left;
  }

  .profile-header {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--space-lg) var(--space-md);
    gap: var(--space-md);
  }

  .profile-header .profile-info {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .profile-header .profile-avatar-wrap {
    width: 88px;
    height: 88px;
  }

  .profile-header .profile-name {
    font-size: 1.25rem;
  }

  .profile-header .profile-follow-btn {
    width: 100%;
    margin-top: var(--space-sm);
  }

  .profile-stats-row {
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-sm);
  }

  .profile-bio {
    text-align: center;
  }

  .profile-activity-section {
    padding: var(--space-sm) var(--space-md);
  }

  /* Card mobile styles */
  .card {
    padding: var(--space-sm);
    gap: var(--space-sm);
  }

  .card-title {
    font-size: var(--font-size-sm);
  }

  .card-actions {
    margin-left: var(--space-xs);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .profile-section {
    padding: var(--space-sm) var(--space-md);
  }

  .profile-section-title {
    font-size: var(--font-size-xs);
  }
}

.moderator-action-modal-content {
  max-width: 32rem;
}

.moderator-action-modal-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.moderator-action-modal-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
}

.moderator-action-modal-textarea {
  min-height: 7.25rem;
  resize: vertical;
}

.moderator-action-modal-hint,
.moderator-action-modal-error {
  margin: 0;
  font-size: var(--font-size-xs);
  line-height: 1.45;
}

.moderator-action-modal-hint {
  color: var(--text-secondary);
}

.moderator-action-modal-error {
  color: var(--danger-primary);
}

#moderator-action-modal .confirm-modal-actions {
  margin-top: var(--space-md);
}
