/* Prevent double-tap zoom on mobile — app-like behavior */
html {
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

/*
 * Inter — variable font, served locally to guarantee consistent typography
 * across platforms (the OS fallback chain below is kept as a safety net but
 * should rarely activate). Source: rsms/inter v4.0, SIL OFL. File lives at
 * apps/web/public/fonts/. font-display: swap renders system text first then
 * upgrades to Inter when the font arrives, avoiding FOIT.
 */
@font-face {
  font-family: "Inter";
  src: url("/fonts/InterVariable.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  /* Keep in sync with packages/shared/src/theme.ts */
  /* Typography */
  --font-family:
    "Inter", -apple-system, BsiteMacSystemFont, "Segoe UI", sans-serif;
  --desktop-ui-font-size: 17.6px;
  --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-semibold: 600;
  --font-weight-bold: 700;
  --line-height-tight: 1.25;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.75;
  --button-font-size: var(--font-size-sm);
  --button-font-weight-subtle: var(--font-weight-normal);
  --button-font-weight: var(--font-weight-medium);
  --button-font-weight-emphasis: var(--font-weight-semibold);
  --button-line-height: 1;
  --label-font-weight: var(--font-weight-semibold);

  /* 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);
  --nav-deactivate-transition: 700ms cubic-bezier(0.22, 1, 0.36, 1);

  font-family: var(--font-family);
  font-size: 16px;
  line-height: var(--line-height-normal);

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

  /* Palette source. Blue is the baseline theme; other schemes map through the same tokens. */
  --color-ink: #e8edf5;
  --color-success: #22c55e;
  --color-error: #ef4444;

  --palette-blue-canvas: #13203a;
  --palette-blue-accent: #6db3ff;
  --palette-blue-page-bg-0: #01040a;
  --palette-blue-share-bg-0: #010309;
  --palette-blue-feed-bg-0: #000205;
  --palette-blue-page-bg-1: #060d19;
  --palette-blue-share-bg-1: #050b15;
  --palette-blue-feed-bg-1: #030812;
  --palette-blue-page-bg-2: #13203a;
  --palette-blue-share-bg-2: #111c34;
  --palette-blue-feed-bg-2: #0d192b;
  --palette-blue-page-bg-3: #203452;
  --palette-blue-share-bg-3: #1f3150;
  --palette-blue-feed-bg-3: #1a2b47;
  --palette-blue-page-bg-4: #2a405f;
  --palette-blue-share-bg-4: #28405f;
  --palette-blue-feed-bg-4: #233856;

  --palette-red-canvas: #2f1e23;
  --palette-red-accent: #e18b99;
  --palette-red-page-bg-0: #070204;
  --palette-red-share-bg-0: #050103;
  --palette-red-feed-bg-0: #030102;
  --palette-red-page-bg-1: #140a0d;
  --palette-red-share-bg-1: #12080b;
  --palette-red-feed-bg-1: #0d0608;
  --palette-red-page-bg-2: #2f1e23;
  --palette-red-share-bg-2: #2a1b1f;
  --palette-red-feed-bg-2: #221619;
  --palette-red-page-bg-3: #442f34;
  --palette-red-share-bg-3: #422d33;
  --palette-red-feed-bg-3: #3a272c;
  --palette-red-page-bg-4: #50393f;
  --palette-red-share-bg-4: #4f383e;
  --palette-red-feed-bg-4: #473238;

  --palette-green-canvas: #11231d;
  --palette-green-accent: #75d39f;
  --palette-green-page-bg-0: #010503;
  --palette-green-share-bg-0: #000402;
  --palette-green-feed-bg-0: #000302;
  --palette-green-page-bg-1: #050f0b;
  --palette-green-share-bg-1: #050d0a;
  --palette-green-feed-bg-1: #030907;
  --palette-green-page-bg-2: #11231d;
  --palette-green-share-bg-2: #0f1f19;
  --palette-green-feed-bg-2: #0c1813;
  --palette-green-page-bg-3: #20392f;
  --palette-green-share-bg-3: #1e362d;
  --palette-green-feed-bg-3: #192e26;
  --palette-green-page-bg-4: #294639;
  --palette-green-share-bg-4: #274337;
  --palette-green-feed-bg-4: #213a30;

  --palette-yellow-canvas: #241f12;
  --palette-yellow-accent: #d7b85a;
  --palette-yellow-page-bg-0: #050400;
  --palette-yellow-share-bg-0: #040300;
  --palette-yellow-feed-bg-0: #030200;
  --palette-yellow-page-bg-1: #100c05;
  --palette-yellow-share-bg-1: #0e0b04;
  --palette-yellow-feed-bg-1: #090803;
  --palette-yellow-page-bg-2: #241f12;
  --palette-yellow-share-bg-2: #201b0f;
  --palette-yellow-feed-bg-2: #19150b;
  --palette-yellow-page-bg-3: #392f19;
  --palette-yellow-share-bg-3: #362d17;
  --palette-yellow-feed-bg-3: #2f2613;
  --palette-yellow-page-bg-4: #463b20;
  --palette-yellow-share-bg-4: #44381e;
  --palette-yellow-feed-bg-4: #3c3119;

  --palette-black-canvas: #07080a;
  --palette-black-accent: #8e98a6;
  --palette-black-page-bg-0: #000102;
  --palette-black-share-bg-0: #000102;
  --palette-black-feed-bg-0: #000001;
  --palette-black-page-bg-1: #030405;
  --palette-black-share-bg-1: #020304;
  --palette-black-feed-bg-1: #010203;
  --palette-black-page-bg-2: #07080a;
  --palette-black-share-bg-2: #060709;
  --palette-black-feed-bg-2: #040506;
  --palette-black-page-bg-3: #111316;
  --palette-black-share-bg-3: #0f1114;
  --palette-black-feed-bg-3: #0c0e11;
  --palette-black-page-bg-4: #1a1d22;
  --palette-black-share-bg-4: #181b20;
  --palette-black-feed-bg-4: #14171c;

  --theme-canvas: var(--palette-blue-canvas);
  --theme-accent: var(--palette-blue-accent);
  --theme-page-bg-0: var(--palette-blue-page-bg-0);
  --theme-share-bg-0: var(--palette-blue-share-bg-0);
  --theme-feed-bg-0: var(--palette-blue-feed-bg-0);
  --theme-page-bg-1: var(--palette-blue-page-bg-1);
  --theme-share-bg-1: var(--palette-blue-share-bg-1);
  --theme-feed-bg-1: var(--palette-blue-feed-bg-1);
  --theme-page-bg-2: var(--palette-blue-page-bg-2);
  --theme-share-bg-2: var(--palette-blue-share-bg-2);
  --theme-feed-bg-2: var(--palette-blue-feed-bg-2);
  --theme-page-bg-3: var(--palette-blue-page-bg-3);
  --theme-share-bg-3: var(--palette-blue-share-bg-3);
  --theme-feed-bg-3: var(--palette-blue-feed-bg-3);
  --theme-page-bg-4: var(--palette-blue-page-bg-4);
  --theme-share-bg-4: var(--palette-blue-share-bg-4);
  --theme-feed-bg-4: var(--palette-blue-feed-bg-4);

  --color-canvas: var(--theme-canvas);
  --color-accent: var(--theme-accent);
  --page-bg-body: var(--theme-page-bg-2);
  --route-bg-share: var(--theme-share-bg-2);
  --route-bg-feed: var(--theme-feed-bg-2);
  --neon-text-intensity: 1;
  --neon-surface-intensity: 1;
  --neon-background-intensity: 1;

  --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%
  );
  /* Match regular field placeholders, including select-based placeholders. */
  --text-placeholder: rgb(117, 117, 117);
  --meta-primary: var(--text-secondary);
  --meta-muted: color-mix(
    in srgb,
    var(--color-ink) 66%,
    var(--color-canvas) 34%
  );
  --meta-accent: color-mix(
    in srgb,
    var(--color-accent) 82%,
    var(--text-muted) 18%
  );
  --meta-connection: color-mix(in srgb, #be8e9a 80%, var(--color-ink) 20%);
  --meta-submitter: color-mix(in srgb, #78b0a8 80%, var(--color-ink) 20%);
  --meta-pending: color-mix(in srgb, #d8bd64 80%, var(--color-ink) 20%);
  --text-site: var(--color-accent);
  --external-site-link: color-mix(
    in srgb,
    var(--color-accent) 54%,
    var(--color-ink) 46%
  );
  --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);
  --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%
  );
  --site-row-bg: var(--bg-secondary);
  --focus-ring: color-mix(
    in srgb,
    var(--color-accent) 85%,
    white 15%
  );
  --nav-surface: color-mix(
    in srgb,
    var(--color-accent) 14%,
    var(--color-canvas) 86%
  );
  --profile-site: var(--accent-primary);
  --discussant-site: var(--meta-accent);
  --poster-connection: var(--meta-connection);
  --poster-submitter: var(--meta-submitter);
  --pending-release: var(--meta-pending);
  --star-star: var(--accent-primary);
  --star-star-hover: #d4aa45;
  --star-star-active: #d4aa45;
  --star-star-active-hover: #e0b650;
  --hit-target-min: 2.75rem;
  --app-input-default-min-height: calc(var(--hit-target-min) + 0.125rem);
  --app-input-default-padding: 0.6rem 1rem;
  --app-input-default-font-size: var(--font-size-base);
  --app-input-compact-min-height: 2.4rem;
  --app-input-compact-padding: 0.48rem 0.9rem;
  --app-input-compact-font-size: 0.95rem;
  --app-input-dense-min-height: calc(2.18rem + 0.125rem);
  --app-input-dense-padding: 0.38rem 0.72rem;
  --app-input-dense-font-size: 0.86rem;
  --app-input-line-height: 1.1;
  --nav-scale: 0.8;
  --nav-hit-target: calc(var(--hit-target-min) * var(--nav-scale));
  --post-time-col-width: 5.75rem;
  --content-shell-width: 45rem;
  --policy-shell-width: 54.375rem;
  --panel-inline-padding: var(--space-md);
  --analytics-consent-footer-offset: 0px;
  /* Stable viewport sizing keeps mobile keyboard animation from moving core UI. */
  --stable-vh: 1vh;
  --stable-viewport-height: calc(var(--stable-vh) * 100);
  --visual-viewport-height: var(--stable-viewport-height);
  --visual-viewport-offset-top: 0px;
  --keyboard-inset-bottom: 0px;
  --keyboard-safe-viewport-height: var(--stable-viewport-height);
  --fixed-ui-viewport-height: var(--stable-viewport-height);
  --small-viewport-height: 100vh;
  --modal-account-max-width: 23.75rem;
  --modal-account-padding: var(--space-xl) var(--space-lg) var(--space-lg);
  --modal-confirm-max-width: 21.5rem;
  --modal-confirm-padding: var(--space-lg);
  --modal-compact-max-width: var(--modal-confirm-max-width);
  --modal-compact-padding: var(--modal-confirm-padding);
  --modal-list-max-width: 22.5rem;
  --modal-list-max-height: 18.75rem;
  --modal-verification-max-width: 25rem;
  --modal-form-max-width: 32rem;
  --modal-title-gap: var(--space-xs);
  --modal-section-gap: var(--space-md);
  --modal-form-action-gap: var(--space-sm);
  --modal-quiet-action-gap: var(--space-md);
  --breathing-background-duration: 33s;
  --breathing-background-easing: ease-in-out;
  --home-trending-breath-delay: 0ms;

  /* 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%
  );
}

@supports (height: 100lvh) {
  :root {
    --stable-vh: 1lvh;
  }
}

@supports (height: 100svh) {
  :root {
    --small-viewport-height: 100svh;
  }
}

html[data-color-scheme="blue"] {
  --theme-canvas: var(--palette-blue-canvas);
  --theme-accent: var(--palette-blue-accent);
  --theme-page-bg-0: var(--palette-blue-page-bg-0);
  --theme-share-bg-0: var(--palette-blue-share-bg-0);
  --theme-feed-bg-0: var(--palette-blue-feed-bg-0);
  --theme-page-bg-1: var(--palette-blue-page-bg-1);
  --theme-share-bg-1: var(--palette-blue-share-bg-1);
  --theme-feed-bg-1: var(--palette-blue-feed-bg-1);
  --theme-page-bg-2: var(--palette-blue-page-bg-2);
  --theme-share-bg-2: var(--palette-blue-share-bg-2);
  --theme-feed-bg-2: var(--palette-blue-feed-bg-2);
  --theme-page-bg-3: var(--palette-blue-page-bg-3);
  --theme-share-bg-3: var(--palette-blue-share-bg-3);
  --theme-feed-bg-3: var(--palette-blue-feed-bg-3);
  --theme-page-bg-4: var(--palette-blue-page-bg-4);
  --theme-share-bg-4: var(--palette-blue-share-bg-4);
  --theme-feed-bg-4: var(--palette-blue-feed-bg-4);
}

html[data-color-scheme="red"] {
  --theme-canvas: var(--palette-red-canvas);
  --theme-accent: var(--palette-red-accent);
  --theme-page-bg-0: var(--palette-red-page-bg-0);
  --theme-share-bg-0: var(--palette-red-share-bg-0);
  --theme-feed-bg-0: var(--palette-red-feed-bg-0);
  --theme-page-bg-1: var(--palette-red-page-bg-1);
  --theme-share-bg-1: var(--palette-red-share-bg-1);
  --theme-feed-bg-1: var(--palette-red-feed-bg-1);
  --theme-page-bg-2: var(--palette-red-page-bg-2);
  --theme-share-bg-2: var(--palette-red-share-bg-2);
  --theme-feed-bg-2: var(--palette-red-feed-bg-2);
  --theme-page-bg-3: var(--palette-red-page-bg-3);
  --theme-share-bg-3: var(--palette-red-share-bg-3);
  --theme-feed-bg-3: var(--palette-red-feed-bg-3);
  --theme-page-bg-4: var(--palette-red-page-bg-4);
  --theme-share-bg-4: var(--palette-red-share-bg-4);
  --theme-feed-bg-4: var(--palette-red-feed-bg-4);
}

html[data-color-scheme="green"] {
  --theme-canvas: var(--palette-green-canvas);
  --theme-accent: var(--palette-green-accent);
  --theme-page-bg-0: var(--palette-green-page-bg-0);
  --theme-share-bg-0: var(--palette-green-share-bg-0);
  --theme-feed-bg-0: var(--palette-green-feed-bg-0);
  --theme-page-bg-1: var(--palette-green-page-bg-1);
  --theme-share-bg-1: var(--palette-green-share-bg-1);
  --theme-feed-bg-1: var(--palette-green-feed-bg-1);
  --theme-page-bg-2: var(--palette-green-page-bg-2);
  --theme-share-bg-2: var(--palette-green-share-bg-2);
  --theme-feed-bg-2: var(--palette-green-feed-bg-2);
  --theme-page-bg-3: var(--palette-green-page-bg-3);
  --theme-share-bg-3: var(--palette-green-share-bg-3);
  --theme-feed-bg-3: var(--palette-green-feed-bg-3);
  --theme-page-bg-4: var(--palette-green-page-bg-4);
  --theme-share-bg-4: var(--palette-green-share-bg-4);
  --theme-feed-bg-4: var(--palette-green-feed-bg-4);
}

html[data-color-scheme="yellow"] {
  --theme-canvas: var(--palette-yellow-canvas);
  --theme-accent: var(--palette-yellow-accent);
  --theme-page-bg-0: var(--palette-yellow-page-bg-0);
  --theme-share-bg-0: var(--palette-yellow-share-bg-0);
  --theme-feed-bg-0: var(--palette-yellow-feed-bg-0);
  --theme-page-bg-1: var(--palette-yellow-page-bg-1);
  --theme-share-bg-1: var(--palette-yellow-share-bg-1);
  --theme-feed-bg-1: var(--palette-yellow-feed-bg-1);
  --theme-page-bg-2: var(--palette-yellow-page-bg-2);
  --theme-share-bg-2: var(--palette-yellow-share-bg-2);
  --theme-feed-bg-2: var(--palette-yellow-feed-bg-2);
  --theme-page-bg-3: var(--palette-yellow-page-bg-3);
  --theme-share-bg-3: var(--palette-yellow-share-bg-3);
  --theme-feed-bg-3: var(--palette-yellow-feed-bg-3);
  --theme-page-bg-4: var(--palette-yellow-page-bg-4);
  --theme-share-bg-4: var(--palette-yellow-share-bg-4);
  --theme-feed-bg-4: var(--palette-yellow-feed-bg-4);
}

html[data-color-scheme="black"] {
  --theme-canvas: var(--palette-black-canvas);
  --theme-accent: var(--palette-black-accent);
  --theme-page-bg-0: var(--palette-black-page-bg-0);
  --theme-share-bg-0: var(--palette-black-share-bg-0);
  --theme-feed-bg-0: var(--palette-black-feed-bg-0);
  --theme-page-bg-1: var(--palette-black-page-bg-1);
  --theme-share-bg-1: var(--palette-black-share-bg-1);
  --theme-feed-bg-1: var(--palette-black-feed-bg-1);
  --theme-page-bg-2: var(--palette-black-page-bg-2);
  --theme-share-bg-2: var(--palette-black-share-bg-2);
  --theme-feed-bg-2: var(--palette-black-feed-bg-2);
  --theme-page-bg-3: var(--palette-black-page-bg-3);
  --theme-share-bg-3: var(--palette-black-share-bg-3);
  --theme-feed-bg-3: var(--palette-black-feed-bg-3);
  --theme-page-bg-4: var(--palette-black-page-bg-4);
  --theme-share-bg-4: var(--palette-black-share-bg-4);
  --theme-feed-bg-4: var(--palette-black-feed-bg-4);
}

html[data-bg-brightness="0"] {
  --page-bg-body: var(--theme-page-bg-0);
  --route-bg-share: var(--theme-share-bg-0);
  --route-bg-feed: var(--theme-feed-bg-0);
}

html[data-bg-brightness="1"] {
  --page-bg-body: var(--theme-page-bg-1);
  --route-bg-share: var(--theme-share-bg-1);
  --route-bg-feed: var(--theme-feed-bg-1);
}

html[data-bg-brightness="2"] {
  --page-bg-body: var(--theme-page-bg-2);
  --route-bg-share: var(--theme-share-bg-2);
  --route-bg-feed: var(--theme-feed-bg-2);
}

html[data-bg-brightness="3"] {
  --page-bg-body: var(--theme-page-bg-3);
  --route-bg-share: var(--theme-share-bg-3);
  --route-bg-feed: var(--theme-feed-bg-3);
}

html[data-bg-brightness="4"] {
  --page-bg-body: var(--theme-page-bg-4);
  --route-bg-share: var(--theme-share-bg-4);
  --route-bg-feed: var(--theme-feed-bg-4);
}

html[data-neon-intensity="0"] {
  --neon-text-intensity: 0;
  --neon-surface-intensity: 0;
  --neon-background-intensity: 0;
}

html[data-neon-intensity="1"] {
  --neon-text-intensity: 0.45;
  --neon-surface-intensity: 0.42;
  --neon-background-intensity: 0.4;
}

html[data-neon-intensity="2"] {
  --neon-text-intensity: 1;
  --neon-surface-intensity: 1;
  --neon-background-intensity: 1;
}

html[data-neon-intensity="3"] {
  --neon-text-intensity: 1.36;
  --neon-surface-intensity: 1.27;
  --neon-background-intensity: 1.23;
}

html[data-neon-intensity="4"] {
  --neon-text-intensity: 1.72;
  --neon-surface-intensity: 1.56;
  --neon-background-intensity: 1.48;
}

/* Canonical desktop UI scale: desktop-class screens get the user's preferred
   110% feel through root tokens, not browser zoom or wrapper transforms. */
@media (min-width: 1024px) and (hover: hover) and (pointer: fine) {
  :root {
    font-size: var(--desktop-ui-font-size);
  }
}

html {
  background-color: var(--page-bg-body);
  transition: background-color 600ms ease;
  background-image:
    /* Darken the upper-right corner where the 3D dots recede into depth */
    radial-gradient(
      ellipse 60% 50% at 85% 10%,
      rgba(0, 0, 0, 0.35) 0%,
      transparent 70%
    ),
    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) calc(3% * var(--neon-background-intensity)),
          transparent
        )
        0,
      transparent 24rem
    ),
    radial-gradient(
      circle,
      color-mix(in srgb, var(--color-ink) 10%, transparent) 0.75px,
      transparent 1.3px
    );
  background-position:
    right top,
    center top,
    center top,
    center top;
  background-size:
    100% 100%,
    100% 28rem,
    100% 24rem,
    22px 22px;
  background-repeat: no-repeat, no-repeat, no-repeat, repeat;
}

body {
  margin: 0;
  min-height: 100vh;
  min-height: var(--stable-viewport-height);
  display: flex;
  flex-direction: column;
  position: relative;
  isolation: isolate;
  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) calc(3% * var(--neon-background-intensity)),
          transparent
        )
        0,
      transparent 24rem
    ),
    radial-gradient(
      circle,
      color-mix(in srgb, var(--color-ink) 10%, transparent) 0.75px,
      transparent 1.3px
    );
  background-position:
    center top,
    center top,
    center top;
  background-size:
    100% 28rem,
    100% 24rem,
    22px 22px;
  background-repeat: no-repeat, no-repeat, repeat;
  color: var(--text-primary);
}

body[data-route="share"] {
  min-height: min(var(--stable-viewport-height), var(--small-viewport-height));
}

input,
select,
textarea {
  scroll-margin-block: 1rem calc(var(--keyboard-inset-bottom) + 1rem);
}

@media (max-width: 900px) {
  html {
    background-position:
      center top,
      center top,
      center top;
    background-size:
      100% 22rem,
      100% 20rem,
      20px 20px;
  }

  body {
    background-position:
      center top,
      center top,
      center top;
    background-size:
      100% 22rem,
      100% 20rem,
      20px 20px;
  }

  #breathing-background {
    /* Tighter perspective on small screens - less dramatic but still 3D */
    transform: perspective(400px) rotateX(35deg) rotateY(18deg);
  }
}

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

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

.static-panel {
  box-sizing: border-box;
  width: var(--content-shell-width);
  max-width: 100%;
  min-width: 0;
  margin: 0 auto;
  padding: var(--space-xl) var(--panel-inline-padding)
    calc(var(--space-lg) + var(--space-sm));
}

body[data-analytics-consent-visible="true"] .static-panel {
  padding-bottom: calc(
    var(--space-lg) + var(--space-sm) +
      var(--analytics-consent-banner-height, 0px) + var(--space-md)
  );
}

/* Policy pages: wider shell for readability on large screens */
.static-panel[data-route-view="terms"],
.static-panel[data-route-view="privacy"],
.static-panel[data-route-view="protocol"] {
  width: var(--policy-shell-width);
}

/* Legal pages: smaller text for a legal-document feel */
.static-panel[data-route-view="terms"],
.static-panel[data-route-view="privacy"],
.static-panel[data-route-view="protocol"] {
  font-size: var(--font-size-sm);
}

/* Discussion page: slightly wider shell */
.static-panel[data-route-view="site"] {
  width: 48.75rem;
}

/* Profile page: slightly wider shell */
.static-panel[data-route-view="profile"] {
  width: 47.5rem;
}

@media (min-width: 769px) {
  /* Settings: slightly wider shell so longer labels breathe a bit more. */
  .static-panel[data-route-view="settings"] {
    width: 45.625rem;
  }

  /* Profile: give the desktop shell a touch more room. */
  .static-panel[data-route-view="profile"] {
    width: 48.125rem;
  }
}

/* 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);
  width: min(72rem, 94vw);
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  justify-content: start;
  min-height: 0;
  padding-top: clamp(3.65rem, calc(var(--stable-vh) * 13), 8rem);
  padding-bottom: max(1rem, env(safe-area-inset-bottom, 0px));
}

body[data-route="share"][data-analytics-consent-visible="true"]
  .static-panel[data-route-view="share"] {
  padding-bottom: max(1rem, env(safe-area-inset-bottom, 0px));
}

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

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

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

.share-alpha-note {
  --share-alpha-accent: var(--accent-primary);
  position: relative;
  isolation: isolate;
  width: fit-content;
  max-width: min(100%, 39rem);
  margin: clamp(1.5rem, calc(var(--stable-vh) * 4), 2.5rem) auto 0;
  padding: 0.42rem 0.68rem;
  min-height: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.44rem;
  flex-wrap: wrap;
  border: 1px solid
    color-mix(in srgb, var(--accent-primary) 14%, var(--border-secondary) 86%);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--bg-panel) 44%, transparent);
  color: color-mix(in srgb, var(--text-secondary) 86%, var(--text-muted) 14%);
  box-shadow:
    0 5px 16px color-mix(in srgb, #000 14%, transparent),
    inset 0 1px 0 color-mix(in srgb, var(--color-ink) 5%, transparent);
  font-size: clamp(0.7rem, 1.05vw, 0.78rem);
  font-family: inherit;
  font-style: normal;
  font-weight: var(--font-weight-bold);
  line-height: 1;
  text-align: center;
  appearance: none;
  cursor: pointer;
}

.share-alpha-note:disabled,
.share-alpha-note:disabled:hover {
  opacity: 1;
  cursor: default;
}

.share-alpha-note::before {
  content: "";
  width: 0.34rem;
  height: 0.34rem;
  flex: 0 0 auto;
  border-radius: var(--radius-full);
  background: var(--share-alpha-accent);
  opacity: 0.82;
  box-shadow: 0 0 7px
    color-mix(in srgb, var(--share-alpha-accent) 34%, transparent);
  animation: share-alpha-dot-pulse 1.9s ease-in-out infinite;
}

@keyframes share-alpha-dot-pulse {
  0%,
  100% {
    opacity: 0.82;
    transform: scale(0.98);
    box-shadow: 0 0 6px
      color-mix(in srgb, var(--share-alpha-accent) 28%, transparent);
  }

  48% {
    opacity: 0.96;
    transform: scale(1.16);
    box-shadow:
      0 0 0 0.1rem
        color-mix(in srgb, var(--share-alpha-accent) 10%, transparent),
      0 0 11px
        color-mix(in srgb, var(--share-alpha-accent) 40%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .share-alpha-note::before {
    animation: none;
  }
}

.share-alpha-note-kicker {
  color: color-mix(
    in srgb,
    var(--share-alpha-accent) 78%,
    var(--text-secondary) 22%
  );
  font-size: 0.78em;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.03em;
  line-height: inherit;
  text-transform: uppercase;
}

.share-alpha-note-detail {
  position: relative;
  font-style: inherit;
  line-height: inherit;
}

.home-trending {
  --home-trending-gap: 0.66rem;
  --home-trending-card-width: clamp(18.1rem, 25.5vw, 20.75rem);
  --home-trending-side-peek: clamp(3rem, 6vw, 4.2rem);
  --home-trending-edge-fade: var(--home-trending-side-peek);
  --home-trending-edge-soft-stop: 4%;
  --home-trending-edge-mid-stop: 8%;
  --home-trending-edge-right-mid-stop: 92%;
  --home-trending-edge-right-soft-stop: 96%;
  --home-trending-auto-offset: 0px;
  --home-trending-visible-width: var(--home-trending-card-width);
  --home-trending-window-width: calc(
    var(--home-trending-visible-width) +
      (var(--home-trending-side-peek) * 2)
  );
  position: relative;
  isolation: isolate;
  width: min(100%, 58rem);
  margin: clamp(2.2rem, calc(var(--stable-vh) * 7), 4.25rem) auto 0;
}

.home-trending::before {
  content: "";
  position: absolute;
  inset: -2.4rem -1.4rem -1.6rem;
  z-index: -1;
  background-image: radial-gradient(
    circle,
    color-mix(
        in srgb,
        var(--color-ink) calc(20% * var(--neon-background-intensity)),
        transparent
      )
      1px,
    transparent 2px
  );
  background-size: 22px 22px;
  mask-image: linear-gradient(
    180deg,
    transparent 0,
    black 28%,
    black 72%,
    transparent 100%
  );
  opacity: 0.22;
  transform: perspective(500px) rotateX(42deg) rotateY(24deg) scale(0.96);
  transform-origin: 50% 85%;
  pointer-events: none;
}

.home-trending::after {
  content: "";
  position: absolute;
  inset: -0.9rem calc(var(--home-trending-side-peek) * 0.32) -0.95rem;
  z-index: -1;
  background:
    radial-gradient(
      ellipse 46% 92% at 50% 47%,
      color-mix(
          in srgb,
          var(--accent-primary) calc(15% * var(--neon-background-intensity)),
          transparent
        )
        0%,
      color-mix(
          in srgb,
          var(--accent-primary) calc(9% * var(--neon-background-intensity)),
          transparent
        )
        42%,
      transparent 74%
    ),
    linear-gradient(
      90deg,
      transparent 0%,
      color-mix(
          in srgb,
          var(--accent-primary) calc(7% * var(--neon-background-intensity)),
          transparent
        )
        22%,
      color-mix(
          in srgb,
          var(--accent-primary) calc(10% * var(--neon-background-intensity)),
          transparent
        )
        52%,
      color-mix(
          in srgb,
          var(--accent-primary) calc(6% * var(--neon-background-intensity)),
          transparent
        )
        78%,
      transparent 100%
    ),
    linear-gradient(
      180deg,
      transparent 0%,
      color-mix(in srgb, var(--color-ink) 8%, transparent) 44%,
      transparent 100%
  );
  filter: blur(12px);
  opacity: 0.62;
  pointer-events: none;
  transform: translateZ(0);
}

@media (min-width: 769px) {
  .home-trending {
    position: absolute;
    top: clamp(31.4rem, calc(var(--stable-vh) * 52), 40rem);
    left: 50%;
    width: min(var(--home-trending-window-width), 88vw);
    margin: 0;
    transform: translateX(-50%);
  }
}

@media (min-width: 769px) and (max-height: 820px),
  (min-width: 769px) and (max-width: 1024px) {
  body[data-route="share"] .home-trending {
    top: calc(var(--stable-vh) * 64);
    width: min(var(--home-trending-window-width), 88vw);
  }

  body[data-route="share"] .home-trending-card {
    box-sizing: border-box;
    height: 6.15rem;
    min-height: 0;
    max-height: 6.15rem;
    padding: 0.46rem 0.58rem;
  }

  body[data-route="share"] .home-trending-card .card-title {
    font-size: 0.84rem;
  }

  body[data-route="share"] .home-trending-card .card-meta {
    margin-top: 0.02rem;
    font-size: 0.68rem;
  }

  body[data-route="share"] .home-trending-card .card-post-count,
  body[data-route="share"] .home-trending-card .card-category-label,
  body[data-route="share"] .home-trending-card .card-last-poster {
    min-height: 1.08rem;
    padding-block: 0.04rem;
  }

  body[data-route="share"] .home-trending-card .card-last-poster,
  body[data-route="share"] .home-trending-card .card-meta-item-last-poster {
    display: none;
  }

  body[data-route="share"] .home-trending-discussions {
    gap: 0.28rem;
    margin-top: 0.34rem;
    padding-top: 0.32rem;
    max-height: 2.68rem;
  }

  body[data-route="share"] .home-trending-discussion-author {
    font-size: 0.66rem;
  }

  body[data-route="share"] .home-trending-discussion-body {
    font-size: 0.7rem;
    line-height: 1.2;
  }

  body[data-route="share"] .home-trending-discussion-body {
    -webkit-line-clamp: 1;
  }
}

.home-trending-list {
  --home-trending-left-edge-start-color: black;
  --home-trending-left-edge-soft-color: black;
  --home-trending-left-edge-mid-color: black;
  --home-trending-right-edge-start-color: black;
  --home-trending-right-edge-soft-color: black;
  --home-trending-right-edge-mid-color: black;
  --home-trending-focus-falloff-opacity: 0;
  box-sizing: border-box;
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  gap: var(--home-trending-gap);
  width: 100%;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scroll-padding-inline: 0.08rem;
  scroll-snap-type: none;
  margin: 0;
  padding: 0 0 0.12rem;
  list-style: none;
  -webkit-overflow-scrolling: touch;
  -webkit-mask-image: linear-gradient(
    90deg,
    var(--home-trending-left-edge-start-color) 0,
    var(--home-trending-left-edge-soft-color)
      var(--home-trending-edge-soft-stop),
    var(--home-trending-left-edge-mid-color)
      var(--home-trending-edge-mid-stop),
    black var(--home-trending-edge-fade),
    black calc(100% - var(--home-trending-edge-fade)),
    var(--home-trending-right-edge-mid-color)
      var(--home-trending-edge-right-mid-stop),
    var(--home-trending-right-edge-soft-color)
      var(--home-trending-edge-right-soft-stop),
    var(--home-trending-right-edge-start-color) 100%
  );
  mask-image: linear-gradient(
    90deg,
    var(--home-trending-left-edge-start-color) 0,
    var(--home-trending-left-edge-soft-color)
      var(--home-trending-edge-soft-stop),
    var(--home-trending-left-edge-mid-color)
      var(--home-trending-edge-mid-stop),
    black var(--home-trending-edge-fade),
    black calc(100% - var(--home-trending-edge-fade)),
    var(--home-trending-right-edge-mid-color)
      var(--home-trending-edge-right-mid-stop),
    var(--home-trending-right-edge-soft-color)
      var(--home-trending-edge-right-soft-stop),
    var(--home-trending-right-edge-start-color) 100%
  );
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.home-trending-list::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: radial-gradient(
    ellipse 62% 112% at 50% 48%,
    transparent 58%,
    color-mix(in srgb, var(--color-canvas) 3%, transparent) 76%,
    color-mix(in srgb, var(--color-canvas) 9%, transparent) 100%
  );
  opacity: var(--home-trending-focus-falloff-opacity);
  pointer-events: none;
}

.home-trending-list[data-overflow-left="true"],
.home-trending-list[data-overflow-right="true"] {
  --home-trending-focus-falloff-opacity: 1;
}

.home-trending-list[data-overflow-left="true"] {
  --home-trending-left-edge-start-color: rgb(0 0 0 / 5%);
  --home-trending-left-edge-soft-color: rgb(0 0 0 / 20%);
  --home-trending-left-edge-mid-color: rgb(0 0 0 / 60%);
}

.home-trending-list[data-overflow-right="true"] {
  --home-trending-right-edge-start-color: rgb(0 0 0 / 5%);
  --home-trending-right-edge-soft-color: rgb(0 0 0 / 20%);
  --home-trending-right-edge-mid-color: rgb(0 0 0 / 60%);
}

.home-trending-list[data-auto-scrolling="true"] {
  scroll-snap-type: none;
  scroll-behavior: auto;
}

.home-trending-list[data-auto-scrolling="true"] .home-trending-card {
  transform: translate3d(
    calc(var(--home-trending-auto-offset, 0px) * -1),
    0,
    0
  );
  will-change: transform;
}

.home-trending-card {
  box-sizing: border-box;
  flex: 0 0 var(--home-trending-card-width);
  min-height: 7.65rem;
  padding: 0.58rem 0.66rem;
  scroll-snap-align: start;
  outline: 1px solid
    color-mix(
      in srgb,
      var(--color-accent) calc(13% * var(--neon-surface-intensity)),
      transparent
    );
  outline-offset: -1px;
  isolation: isolate;
  overflow: hidden;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  background: linear-gradient(
    180deg,
    color-mix(
        in srgb,
        var(--site-row-bg) calc(100% - (5% * var(--neon-surface-intensity))),
        var(--color-accent) calc(5% * var(--neon-surface-intensity))
      )
      0%,
    var(--site-row-bg) 58%
  );
  box-shadow:
    0 0 13px -6px
      color-mix(
        in srgb,
        var(--color-accent) calc(20% * var(--neon-surface-intensity)),
        transparent
      ),
    0 2px 6px -2px color-mix(in srgb, #000 45%, transparent);
  transition:
    background var(--transition-fast),
    box-shadow var(--transition-fast),
    outline-color var(--transition-fast);
}

.home-trending[data-entering="true"] .home-trending-card {
  animation: home-trending-card-enter 760ms ease-out both;
}

.home-trending-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background: radial-gradient(
    ellipse 84% 46% at 50% 0%,
    color-mix(
        in srgb,
        var(--color-accent) calc(13% * var(--neon-surface-intensity)),
        transparent
      )
      0%,
    transparent 68%
  );
  box-shadow:
    inset 0 0 0 1px
      color-mix(
        in srgb,
        var(--accent-primary) calc(12% * var(--neon-surface-intensity)),
        transparent
      ),
    inset 0 1px 0 color-mix(in srgb, white 5%, transparent);
  opacity: 0.09;
  pointer-events: none;
  animation: home-trending-card-glow-breathe var(--breathing-background-duration)
    var(--breathing-background-easing) infinite;
  animation-delay: var(--home-trending-breath-delay);
  animation-play-state: paused;
}

.home-trending-card > * {
  position: relative;
  z-index: 1;
}

.home-trending-card:hover {
  outline-color: color-mix(
    in srgb,
    var(--color-accent) calc(20% * var(--neon-surface-intensity)),
    transparent
  );
  box-shadow:
    0 0 16px -5px
      color-mix(
        in srgb,
        var(--color-accent) calc(25% * var(--neon-surface-intensity)),
        transparent
      ),
    0 4px 10px -3px color-mix(in srgb, #000 55%, transparent);
}

.home-trending-card:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: -2px;
}

.home-trending-card .card-content {
  justify-content: flex-start;
  gap: 0;
}

.home-trending-card .card-title {
  display: block;
  flex: 0 0 auto;
  margin-left: 0;
  padding-right: 0.2rem;
  font-size: 0.86rem;
}

.home-trending-card .card-meta {
  flex: 0 0 auto;
  flex-wrap: nowrap;
  margin-top: 0.07rem;
  overflow: hidden;
  font-size: 0.7rem;
  line-height: var(--line-height-tight);
  row-gap: 0.02rem;
}

.home-trending-card .card-post-count,
.home-trending-card .card-category-label,
.home-trending-card .card-last-poster {
  min-height: 1.22rem;
  padding-block: 0.08rem;
  font-size: inherit;
  font-weight: var(--font-weight-medium);
  line-height: inherit;
}

.home-trending-card .card-time {
  color: var(--text-muted);
  font-size: 0.66rem;
  line-height: var(--line-height-tight);
  white-space: nowrap;
}

.home-trending-discussions {
  flex: 0 0 auto;
  display: grid;
  gap: 0.36rem;
  margin-top: 0.42rem;
  padding-top: 0.42rem;
  max-height: 4.85rem;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior-x: none;
  overscroll-behavior-y: contain;
  border-top: 1px solid
    color-mix(in srgb, var(--border-secondary) 62%, transparent);
}

.home-trending-discussions:has(.home-trending-discussion:nth-child(3)) {
  padding-right: 0.14rem;
  -webkit-mask-image: linear-gradient(
    180deg,
    black 0,
    black calc(100% - 0.7rem),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    black 0,
    black calc(100% - 0.7rem),
    transparent 100%
  );
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.home-trending-discussion {
  min-width: 0;
}

.home-trending-discussion-author {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  color: var(--discussant-site);
  font-size: 0.68rem;
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
}

.home-trending-discussion-author .profile-site {
  max-width: 100%;
  overflow: hidden;
  color: inherit;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.home-trending-discussion-body {
  margin: 0.16rem 0 0;
  color: color-mix(in srgb, var(--text-secondary) 88%, var(--text-muted) 12%);
  font-size: 0.74rem;
  line-height: 1.28;
}

.home-trending-discussion-time {
  flex: 0 0 auto;
  margin-left: 0.25rem;
  color: var(--meta-muted);
  font-size: 0.64rem;
  font-weight: var(--font-weight-normal);
  white-space: nowrap;
}

@keyframes home-trending-card-glow-breathe {
  0%,
  100% {
    opacity: 0.075;
  }

  50% {
    opacity: 0.17;
  }
}

@keyframes home-trending-card-enter {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

.home-trending-discussion-body {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.home-trending-state {
  width: fit-content;
  max-width: 100%;
  margin: 0.2rem auto 0;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  font-style: italic;
  line-height: var(--line-height-normal);
  text-align: center;
}

.share-alpha-signups-link {
  display: inline;
  min-width: 0;
  min-height: 0;
  height: auto;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: color-mix(
    in srgb,
    var(--share-alpha-accent) 76%,
    var(--text-secondary) 24%
  );
  appearance: none;
  font: inherit;
  font-style: inherit;
  line-height: inherit;
  text-decoration: none;
  vertical-align: baseline;
  cursor: pointer;
}

.share-alpha-signups-link:hover,
.share-alpha-signups-link:focus-visible {
  color: color-mix(
    in srgb,
    var(--share-alpha-accent) 84%,
    var(--color-ink) 16%
  );
  text-shadow: none;
}

.share-alpha-signups-link:hover {
  text-decoration: underline;
  text-decoration-thickness: 0.07em;
  text-underline-offset: 0.14em;
}

.share-alpha-signups-link:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--focus-ring) 48%, transparent);
  outline-offset: 0.18rem;
  border-radius: var(--radius-sm);
}

.static-panel[data-route-view="share"] .inline-discuss-field,
.command-console-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-console-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-console-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-console-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-console-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-console-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-console-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-console-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-console-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: var(--button-font-size);
  font-weight: var(--button-font-weight);
  line-height: var(--button-line-height);
  white-space: nowrap;
  background: var(--accent-primary);
  color: #fff;
  transition:
    background var(--transition-fast),
    box-shadow 0.3s ease,
    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-console-context.is-discuss .inline-discuss-field > button:hover,
.command-console-context.is-discuss
  .inline-discuss-field
  > button:focus-visible {
  opacity: 1;
  background: var(--accent-hover);
  box-shadow:
    0 0 14px
      color-mix(
        in srgb,
        var(--accent-primary) calc(27% * var(--neon-surface-intensity)),
        transparent
      ),
    0 0 5px
      color-mix(
        in srgb,
        var(--accent-primary) calc(18% * var(--neon-surface-intensity)),
        transparent
      );
}

.static-panel[data-route-view="share"]
  .inline-discuss-field
  > button:focus-visible,
.command-console-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: 90%;
    min-width: 0;
    margin-inline: auto;
  }

  .static-panel[data-route-view="feed"] {
    width: 100%;
  }

  .static-panel[data-route-view="share"] {
    width: 94%;
  }

  .home-trending {
    --home-trending-mobile-card-width: min(35rem, 76vw);
    --home-trending-side-peek: 0rem;
    width: 100vw;
    max-width: none;
    margin: clamp(2.7rem, calc(var(--stable-vh) * 7.2), 4rem) 0 0 50%;
    transform: translateX(-50%);
  }

  .home-trending-list {
    --home-trending-edge-fade: 2.25rem;
    gap: 0.62rem;
    padding: 0
      calc((100vw - var(--home-trending-mobile-card-width)) / 2) 0.12rem;
    scroll-padding-inline: calc(
      (100vw - var(--home-trending-mobile-card-width)) / 2
    );
    scroll-snap-type: x mandatory;
  }

  .static-panel[data-route-view="about"],
  .static-panel[data-route-view="extensions"] {
    width: 54.375rem;
  }

  .home-trending-card {
    flex-basis: var(--home-trending-mobile-card-width);
    min-height: 9.4rem;
    scroll-snap-align: center;
  }
}

@media (min-width: 769px) {
  .static-panel[data-route-view="feed"] {
    width: min(49.375rem, 90%);
  }
}

.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.92rem, 4vw, 2.58rem);
  letter-spacing: -0.035em;
  text-shadow:
    0 0 10px
      color-mix(
        in srgb,
        var(--color-accent) calc(22% * var(--neon-text-intensity)),
        transparent
      ),
    0 0 44px
      color-mix(
        in srgb,
        var(--color-accent) calc(27% * var(--neon-text-intensity)),
        transparent
      ),
    0 0 88px
      color-mix(
        in srgb,
        var(--color-accent) calc(22% * var(--neon-text-intensity)),
        transparent
      );
}

[data-route-view="feed"] > .panel-title {
  margin-bottom: calc(var(--space-lg) + 0.3rem);
  opacity: var(--feed-title-opacity, 1);
  transition: opacity 260ms cubic-bezier(0.22, 1, 0.36, 1);
  text-shadow:
    0 0 10px
      color-mix(
        in srgb,
        var(--color-accent) calc(22% * var(--neon-text-intensity)),
        transparent
      ),
    0 0 44px
      color-mix(
        in srgb,
        var(--color-accent) calc(27% * var(--neon-text-intensity)),
        transparent
      ),
    0 0 88px
      color-mix(
        in srgb,
        var(--color-accent) calc(22% * var(--neon-text-intensity)),
        transparent
      );
}

[data-route-view="feed"] > .panel-title > .feed-title-copy {
  display: inline-block;
  transition:
    opacity 140ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 180ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

[data-route-view="feed"]
  > .panel-title[data-title-phase="out"]
  > .feed-title-copy {
  opacity: 0;
  transform: translateY(0.18rem);
}

.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)))
  );
  max-width: 100%;
  min-width: 0;
  margin: 0 auto;
  align-items: center;
  gap: calc(0.45rem * var(--nav-scale));
  padding-block: calc(0.62rem * var(--nav-scale) + 0.625rem)
    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 {
  box-sizing: border-box;
  position: absolute;
  top: calc(100% + 0.75rem);
  min-width: min(8.75rem, calc(100vw - 1.5rem));
  max-width: min(18rem, calc(100vw - 1.5rem));
  padding: 0.25rem;
  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;
  gap: 0.125rem;
  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) + 0.375rem);
  min-height: calc(var(--hit-target-min) + 0.375rem);
  padding: 0 0.75rem;
  border: none;
  border-radius: calc(var(--radius-md) - 0.125rem);
  background: none;
  appearance: none;
  color: var(--text-primary);
  text-align: center;
  white-space: normal;
  word-break: break-word;
  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:focus {
  outline: none;
}

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

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

.nav-dropdown-item:focus-visible {
  background: var(--bg-tertiary);
  outline: 2px solid transparent;
  box-shadow: inset 0 0 0 2px var(--focus-ring);
}

.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;
}

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

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

.user-menu-trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(
    --floating-settings-control-size,
    calc(var(--nav-hit-target) + 0.375rem)
  );
  height: var(
    --floating-settings-control-size,
    calc(var(--nav-hit-target) + 0.375rem)
  );
  padding: 0;
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text-secondary);
  box-shadow: none;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  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((1.25rem * var(--nav-scale)) + 0.1875rem);
  height: calc((1.25rem * var(--nav-scale)) + 0.1875rem);
}

.notifications-btn svg {
  width: calc((1.25rem * var(--nav-scale)) + 0.1875rem);
  height: calc((1.25rem * var(--nav-scale)) + 0.1875rem);
}

.user-menu-dropdown {
  right: 0;
  top: auto;
  bottom: calc(100% + 0.75rem);
  width: max-content;
}

.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) + 0.375rem);
  height: calc(var(--nav-hit-target) + 0.375rem);
  padding: 0;
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text-secondary);
  box-shadow: none;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  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: 1rem;
  height: 1rem;
  padding: 0 0.25rem;
  background: color-mix(in srgb, var(--accent-primary) 88%, var(--color-ink) 12%);
  color: #fff;
  font-size: 0.625rem;
  font-weight: var(--font-weight-bold);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--color-canvas) 72%, transparent),
    0 0 10px color-mix(in srgb, var(--accent-primary) 32%, transparent);
}

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

.notifications-dropdown {
  box-sizing: border-box;
  position: absolute;
  top: calc(100% + 0.75rem);
  right: 0;
  width: min(20rem, calc(100vw - 1.5rem));
  max-width: calc(100vw - 1.5rem);
  max-height: 25rem;
  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;
}

@media (min-width: 769px) {
  .notifications-dropdown {
    width: min(19.3rem, calc(100vw - 1.5rem));
  }
}

.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-semibold);
  font-size: var(--font-size-sm);
}

.notifications-actions {
  display: flex;
  gap: var(--space-xs);
  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: 21.25rem;
}

.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: 2.25rem;
  height: 2.25rem;
  border-radius: 0.75rem;
  overflow: hidden;
}

.profile-avatar-wrap.notification-avatar .profile-avatar-initial {
  font-size: 0.9rem;
  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);
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  overflow-wrap: anywhere;
}

.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: 2.25rem;
  height: 2.25rem;
  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-error {
  padding: var(--space-lg);
  text-align: center;
  color: var(--text-muted);
  font-size: var(--font-size-sm);
}

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

.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);
  overflow: hidden;
  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 {
  display: flex;
  align-items: center;
  margin: 0;
  grid-column: 1;
  justify-self: start;
  padding: 0;
  gap: calc(0.35rem * var(--nav-scale));
}

.main-nav-button-shell {
  --nav-active-inset-block: 0;
  padding: 0;
}

.main-nav .nav-control-btn {
  z-index: 0;
  transition:
    color var(--nav-control-color-transition),
    background-color var(--nav-control-surface-transition),
    box-shadow var(--nav-control-surface-transition);
}

.main-nav .main-nav-site-btn {
  min-width: calc(2.2rem * var(--nav-scale));
}

.account-nav-shell {
  --nav-active-inset-block: 0;
  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 {
  opacity: var(--top-bar-controls-opacity, 1);
  transition: opacity 260ms cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: auto;
}

.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"] [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 {
  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 {
  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);
  --floating-settings-control-size: calc(var(--nav-hit-target) + 0.375rem);
  --floating-settings-gap: 0.25rem;
  --floating-settings-block-size: calc(
    (var(--floating-settings-control-size) * 2) +
      var(--floating-settings-gap)
  );
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--floating-settings-gap);
  position: fixed;
  right: calc(
    env(safe-area-inset-right, 0px) + var(--floating-settings-corner-gap) +
      var(--floating-settings-corner-nudge)
  );
  top: max(
    env(safe-area-inset-top, 0px),
    calc(
      var(--fixed-ui-viewport-height) - env(safe-area-inset-bottom, 0px) -
        var(--floating-settings-corner-gap) -
        var(--floating-settings-corner-nudge) -
        var(--floating-settings-block-size)
    )
  );
  bottom: auto;
  z-index: 20;
}

.command-console-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(
    --floating-settings-control-size,
    calc(var(--nav-hit-target) + 0.375rem)
  );
  height: var(
    --floating-settings-control-size,
    calc(var(--nav-hit-target) + 0.375rem)
  );
  padding: 0;
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text-secondary);
  box-shadow: none;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition:
    color var(--nav-control-color-transition),
    background-color var(--nav-control-surface-transition),
    box-shadow var(--nav-control-surface-transition);
}

.command-console-btn:hover {
  color: var(--text-primary);
  background-color: var(--bg-tertiary);
}

.top-bar-settings-wrap:has(.user-menu-trigger[aria-expanded="true"])
  .command-console-btn {
  pointer-events: none;
  opacity: 0;
}

.command-console-btn svg {
  width: calc((1.25rem * var(--nav-scale)) + 0.1875rem);
  height: calc((1.25rem * var(--nav-scale)) + 0.1875rem);
}

.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(--button-font-weight);
  font-size: calc(var(--font-size-base) * var(--nav-scale));
  color: var(--nav-inactive);
  background: transparent;
  border: none;
  box-shadow: none;
  text-shadow: none;
  padding: calc(0.36rem * var(--nav-scale)) calc(0.86rem * var(--nav-scale));
  line-height: 1;
  border-radius: var(--nav-capsule-radius);
  -webkit-tap-highlight-color: transparent;
  gap: calc(0.4rem * var(--nav-scale));
  transition:
    color var(--nav-deactivate-transition),
    background-color var(--transition-fast),
    box-shadow var(--transition-fast),
    text-shadow var(--nav-deactivate-transition);
}

.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-deactivate-transition),
    box-shadow var(--nav-deactivate-transition);
  z-index: -1;
}

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

/* Immediate press feedback. Without this, mousedown has no visible
   effect — the click event only fires on mouseup, so a held click
   feels like "lag" between the press and the navigation. A subtle
   background tint on :active acknowledges the press instantly with
   a fast 50ms fade-in, while the base rule's 150ms fade handles the
   release (asymmetric timing makes the press feel snappier). */
.nav-control-btn:active {
  background-color: color-mix(in srgb, var(--accent-primary) 14%, transparent);
  transition:
    color var(--nav-deactivate-transition),
    background-color 50ms ease-out,
    box-shadow var(--transition-fast);
}

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

  /* ── Text glow: uncomment ONE variant ─────────────────────── */

  /* Variant A: blue accent glow */
  /* text-shadow:
    0 0 5px color-mix(in srgb, var(--color-accent) 30%, transparent),
    0 0 12px color-mix(in srgb, var(--color-accent) 16%, transparent); */

  /* Variant B: white neon glow */
  text-shadow:
    0 0 4px rgba(255, 255, 255, calc(0.33 * var(--neon-text-intensity))),
    0 0 10px rgba(255, 255, 255, calc(0.1 * var(--neon-text-intensity)));

  /* ─────────────────────────────────────────────────────────── */

  transition:
    color var(--nav-control-surface-transition),
    background-color var(--transition-fast),
    box-shadow var(--transition-fast),
    text-shadow var(--nav-control-surface-transition);
}

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

.nav-control-btn.active::before {
  opacity: 1;
  transition:
    opacity var(--nav-control-surface-transition),
    box-shadow var(--nav-control-surface-transition);
}

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

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

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

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

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

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);
}

.inline-feedback,
.field-error {
  font-size: var(--font-size-xs);
  font-style: italic;
  line-height: 1.42;
  color: var(--text-secondary);
}

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

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

.field-error:empty,
.status-message:empty {
  display: none;
  min-height: 0;
}

label {
  font-weight: var(--label-font-weight);
}

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[type="email"].input {
  font-kerning: none;
  font-variant-ligatures: none;
  font-feature-settings:
    "kern" 0,
    "liga" 0,
    "calt" 0;
}

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 {
  /* Placeholders inherit field typography; color/style carries the hint state. */
  font-family: inherit;
  font-size: inherit;
  color: var(--text-placeholder);
  opacity: 1;
}

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

@media (max-width: 520px) {
  .home-trending {
    margin-top: clamp(2.6rem, calc(var(--stable-vh) * 6.4), 3.6rem);
  }

  .home-trending-card {
    min-height: 8.8rem;
    padding: 0.68rem 0.74rem;
  }

  .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-family: inherit;
  font-size: var(--button-font-size);
  font-weight: var(--button-font-weight);
  line-height: var(--button-line-height);
  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="protocol"]
  body[data-startup-pending="true"]
  [data-route-view="protocol"][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-site-btn,
#post-submit-btn:not(.load-more-btn),
#waitlist-submit-btn {
  transition: background var(--transition-fast);
}

#submit-site-btn {
  transition:
    background var(--transition-fast),
    box-shadow 0.3s ease;
}

#submit-site-btn:hover,
#post-submit-btn:not(.load-more-btn):hover,
#waitlist-submit-btn:hover,
#modal-signin-btn:hover,
#modal-signup-btn:hover {
  opacity: 1;
  background: var(--accent-hover);
}

#submit-site-btn:hover {
  box-shadow:
    0 0 14px
      color-mix(
        in srgb,
        var(--accent-primary) calc(27% * var(--neon-surface-intensity)),
        transparent
      ),
    0 0 5px
      color-mix(
        in srgb,
        var(--accent-primary) calc(18% * var(--neon-surface-intensity)),
        transparent
      );
}

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: var(--button-font-weight);
  text-decoration: none;
  cursor: pointer;
}

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

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

.sites:empty {
  display: none;
}

.site-row {
  background: var(--site-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;
  /* Perf: skip layout/paint for cards that are scrolled off-screen.
     `contain-intrinsic-size: auto 120px` uses 120px on first paint, then
     remembers each card's actual height for subsequent scrolls \u2014 so
     scrollbar stays stable even when cards vary in height. Firefox
     ignores this gracefully (no fallback needed). Huge win on long
     feeds where most cards are off-screen at any moment. */
  content-visibility: auto;
  contain-intrinsic-size: auto 120px;
}

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

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

.site-url {
  font-weight: var(--font-weight-semibold);
  text-decoration: none;
  color: var(--external-site-link);
  align-self: flex-start;
  display: inline-flex;
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.site-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}

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

.post-count {
  color: var(--meta-primary);
}

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

.site-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);
}

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

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

.site-inline-action.danger:hover,
.site-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: 4rem;
  padding: 0.75rem 1rem;
}

.empty-state-compact .empty-state-title {
  font-size: var(--font-size-sm);
  font-weight: normal;
  color: var(--text-muted);
}

.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);
}

.empty-state-actions {
  display: flex;
  gap: 0.45rem;
  margin-top: 0.15rem;
}

.empty-state-action-btn {
  min-height: 2rem;
  padding: 0.34rem 0.78rem;
  font-size: 0.8rem;
  font-weight: var(--button-font-weight-subtle);
  line-height: var(--button-line-height);
  color: color-mix(
    in srgb,
    var(--accent-primary) 38%,
    var(--text-muted) 62%
  );
  background: transparent;
  border: 1px solid
    color-mix(in srgb, var(--accent-primary) 28%, var(--border-secondary) 72%);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast);
}

.empty-state-action-btn:hover,
.empty-state-action-btn:focus-visible,
.empty-state-action-btn:active {
  opacity: 1;
  background: transparent;
  border-color: var(--accent-primary);
  color: var(--accent-primary);
}

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

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

.form-actions button:not(.load-more-btn) {
  flex: 1;
  min-width: 8.75rem;
}

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

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

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

.toast-stack {
  position: fixed;
  top: 1rem;
  right: 1rem;
  left: 1rem;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.75rem;
  z-index: 150;
  pointer-events: none;
}

.toast {
  box-sizing: border-box;
  max-width: min(36rem, 100%);
  width: fit-content;
  min-width: 0;
  position: relative;
  display: inline-grid;
  align-self: flex-end;
  justify-items: center;
  gap: 0.625rem;
  padding: 1rem 1.6rem 1rem 1.125rem;
  border-radius: var(--radius-md);
  background: var(--bg-panel);
  border: 1px solid var(--border-secondary);
  box-shadow: 0 4px 12px var(--shadow-md);
  color: var(--text-primary);
  font-size: var(--font-size-sm);
  pointer-events: auto;
  animation: toast-enter 150ms ease-out;
}

.toast-content {
  display: grid;
  justify-items: center;
  gap: 0.625rem;
  max-width: 100%;
  min-width: 0;
  text-align: center;
}

.toast-message {
  display: block;
  max-width: 100%;
  overflow-wrap: anywhere;
  white-space: normal;
}

.toast-action {
  min-height: 1.75rem;
  max-width: 100%;
  border: 1px solid var(--border-secondary);
  background: transparent;
  color: var(--text-primary);
  border-radius: var(--radius-sm);
  padding: 0.18rem 0.5rem;
  font-size: var(--font-size-xs);
  line-height: var(--button-line-height);
  cursor: pointer;
  font-weight: var(--button-font-weight);
  white-space: normal;
  overflow-wrap: anywhere;
}

.toast-close {
  position: absolute;
  top: 0;
  right: 0;
  border: none;
  background: none;
  color: var(--text-muted);
  font-size: 1.1rem;
  cursor: pointer;
  padding: 0.25rem;
  line-height: 1;
  transform: translate(-0.1rem, -0.3rem);
  z-index: 1;
}

@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: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.static-card.feed-card {
  position: relative;
  background: none;
  box-shadow: none;
  border-radius: 0;
  padding: 0;
}

.static-card.feed-card .feed-refresh-btn {
  top: -2rem;
  right: 0.25rem;
}

#breathing-background {
  position: fixed;
  /* Oversized so 3D tilt doesn't expose edges */
  top: calc(var(--stable-viewport-height) * -1.2);
  left: -60%;
  width: 220%;
  height: calc(var(--stable-viewport-height) * 3.4);
  background-image:
    /* Dots - same grid rhythm (22px) but 2x larger and brighter so
       perspective distortion is clearly visible */
    radial-gradient(
      circle,
      color-mix(in srgb, var(--color-ink) 40%, transparent) 1.4px,
      transparent 2.2px
    ),
    /* Atmospheric glow toward the vanishing direction (upper-right) */
    radial-gradient(
        ellipse at 38% 36%,
        color-mix(
            in srgb,
            var(--color-accent) calc(6% * var(--neon-background-intensity)),
            transparent
          )
          0%,
        transparent 50%
      );
  background-size:
    22px 22px,
    100% 100%;
  /* 3D tilt - recedes diagonally toward upper-right */
  transform: perspective(500px) rotateX(42deg) rotateY(24deg) translate3d(0, 0, 0)
    scale(1);
  transform-origin: 50% 50%;
  /* Wide elliptical mask - fades 3D grid into the flat background */
  -webkit-mask-image: radial-gradient(
    ellipse 70% 62% at 52% 44%,
    black 0%,
    black 18%,
    transparent 68%
  );
  mask-image: radial-gradient(
    ellipse 70% 62% at 52% 44%,
    black 0%,
    black 18%,
    transparent 68%
  );
  contain: layout paint style;
  opacity: 0;
  transition: opacity 1500ms ease;
  /* Animation is declared on the base rule (not the share rule) so the
     animation instance stays attached across all route changes.
     `paused` is the default play-state — the share rule overrides to
     `running` while on /. Leaving / pauses the animation at its
     current internal clock; returning resumes from that same clock,
     preserving continuous breathing state across navigations. */
  animation: bg-breathe var(--breathing-background-duration)
    var(--breathing-background-easing) infinite paused;
  pointer-events: none;
  z-index: -1;
  backface-visibility: hidden;
  will-change: transform, opacity;
}

@keyframes bg-breathe {
  0%,
  100% {
    transform: perspective(500px) rotateX(42deg) rotateY(24deg)
      translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: perspective(500px) rotateX(42deg) rotateY(24deg)
      translate3d(0, 0, 0) scale(1.18);
  }
}

@media (prefers-reduced-motion: reduce) {
  #breathing-background,
  .home-trending-card,
  .home-trending-card::after {
    animation: none;
  }
}

body[data-route="share"] #breathing-background {
  opacity: 1;
  transition: opacity 1800ms ease 200ms;
  animation-play-state: running;
}

body[data-route="share"] .home-trending-card::after {
  animation-play-state: running;
}

/* Instant dots on initial page load */
body[data-startup-pending="true"][data-route="share"] #breathing-background {
  transition: none;
}

/* Homepage uses a midpoint brightness — slower fade when arriving from feed */
html[data-route="share"] {
  background-color: var(--route-bg-share);
  transition: background-color 2000ms ease;
}

/* Feed uses slightly darker background than other pages */
html[data-route="feed"] {
  background-color: var(--route-bg-feed);
  transition: background-color 600ms ease;
}

.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);
}

/* Inset ring instead of outline because the picker rows are overflow:hidden
   scroll containers that would clip any outline extending beyond the button. */
.feed-sort-filter .sort-btn[data-sort]:focus-visible,
.feed-master-filter [data-master-category]:focus-visible {
  outline: 2px solid transparent; /* visible in Windows forced-colors mode */
  box-shadow: inset 0 0 0 2px var(--focus-ring);
}

.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"] {
  touch-action: pan-y;
  -webkit-touch-callout: none;
  -webkit-user-drag: none;
  user-select: none;
}

.feed-master-filter .master-filter-option.sort-btn,
.feed-sort-filter .sort-btn[data-sort],
.feed-master-filter .master-filter-group,
.feed-sort-filter .feed-sort-group {
  -webkit-user-select: none;
  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: 2.125rem;
  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: 8.75rem;
  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: var(--label-font-weight);
}
.search-bar input {
  flex: 1;
  min-width: 12.5rem;
}

.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: var(--button-font-weight-emphasis);
  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-direction: row;
  flex: 0 0 auto;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0;
  margin-bottom: 0;
  min-width: 0;
  overflow: clip;
  border: 1px solid var(--border-primary);
  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),
    border-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: 2.125rem;
  min-width: 2.125rem;
  min-height: 2.125rem;
  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: 1.3125rem;
  height: 1.3125rem;
}

.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 {
  flex: 0 0 auto;
  width: 0;
  min-width: 0;
  max-width: none;
  padding: 0;
  opacity: 0;
  pointer-events: none;
  background: transparent;
  color: inherit;
  cursor: text;
  transform: translateX(-0.22rem);
  transform-origin: center;
  will-change: width, opacity, transform;
  transition:
    width 280ms cubic-bezier(0.22, 1, 0.36, 1),
    padding 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-console-category-filter .sort-btn,
.command-console-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 var(--border-primary);
  background: var(--accent-light);
  color: var(--accent-hover);
  padding: 0.35rem 0.75rem;
  font-size: var(--button-font-size);
  transition:
    opacity var(--transition-fast),
    border-color 0.15s ease;
}

.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: 0.625rem;
  margin: 0.2rem 0;
}

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

.skeleton-line.tiny {
  height: 0.5rem;
  width: 40%;
}

.skeleton-block {
  width: 2rem;
  height: 2rem;
}

.skeleton-meta {
  width: 100%;
}

.profile-activity-skeleton {
  pointer-events: none;
}

.profile-activity-skeleton-avatar {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  flex-shrink: 0;
}

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

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

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

.moderator-skeleton-actions .skeleton-line {
  width: 6rem;
}

@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;
  white-space: nowrap;
  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.is-login-prompt.is-empty-discussion {
  margin-top: 1.15rem;
}

#post-form > #replying-to,
#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;
  column-gap: var(--space-sm);
}

#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: min(19rem, calc(100vw - 0.75rem));
  max-width: calc(100vw - 2rem);
  padding: 0.72rem 0.82rem 0.78rem;
  border: 1px solid var(--border-secondary);
  border-radius: calc(var(--radius-md) + 0.125rem);
  background: color-mix(in srgb, var(--bg-panel) 94%, #000 6%);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.1),
    0 8px 20px var(--shadow-md),
    0 20px 36px var(--shadow-lg);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5rem;
  z-index: 30;
}

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

.discussion-moderator-dropdown-title {
  margin: 0;
  color: var(--text-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0;
  text-transform: none;
}

.discussion-moderator-dropdown-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  width: 100%;
}

.discussion-header .card-site-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;
  position: relative;
  top: -2px;
  margin-top: 0;
  padding-top: 0;
}

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

.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-site {
  color: var(--external-site-link);
  text-decoration: none;
  word-break: break-word;
  display: block;
  transition: color var(--transition-fast);
}

.discussion-title-site: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(--meta-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(--meta-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);
}

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

.posts-entering > .post {
  animation: post-enter 200ms ease both;
}

/* Applied to #postsList during site navigation: dims previous content instead
 * of wiping it to innerHTML = "". The .posts-entering class removes this in
 * the same paint when new content is ready, so the swap feels continuous. */
.posts-loading {
  opacity: 0.4;
  pointer-events: none;
  transition: opacity 100ms ease;
}

@media (prefers-reduced-motion: reduce) {
  .posts-entering > .post {
    animation: none;
  }

  .posts-loading {
    transition: none;
  }
}

.load-more-btn {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin: 0.35rem auto 0.6rem;
  min-width: auto;
  min-height: 2rem;
  padding: 0.34rem 0.78rem;
  border: 1px solid transparent;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--text-muted);
  font-size: 0.8rem;
  font-weight: var(--button-font-weight-subtle);
  line-height: var(--button-line-height);
  cursor: pointer;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast);
}

.load-more-btn:hover,
.load-more-btn:focus-visible,
.load-more-btn:active {
  opacity: 1;
  border-color: var(--accent-primary);
  background: transparent;
  color: var(--accent-primary);
}

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

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

/*
 * Retry button in the posts error state (see renderPostsErrorState in
 * discussion-posts.ts). Inline with the error message so the user's eye
 * naturally lands on the recovery action. Borrows visual language from
 * load-more-btn for consistency.
 */
.posts-state__retry {
  display: inline-flex;
  align-items: center;
  min-height: 1.8rem;
  padding: 0.2rem 0.6rem;
  border: 1px solid var(--accent-primary);
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--accent-primary);
  font-size: inherit;
  cursor: pointer;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast);
}
.posts-state__retry:hover,
.posts-state__retry:focus-visible {
  background: var(--accent-primary);
  color: var(--color-surface);
}

.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: 0.125rem 0.375rem;
  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.25rem;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-tight);
  white-space: pre-wrap;
  word-break: break-word;
}

.post .card-body-muted {
  color: var(--text-secondary);
  font-style: italic;
}

.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;
  position: relative;
  top: -2px;
  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);
}

/* @mention sites in post bodies */
.user-mention {
  color: var(--accent);
  font-weight: 500;
  text-decoration: none;
}
.user-mention:hover {
  text-decoration: underline;
}

/* Mention autocomplete dropdown */
.mention-autocomplete {
  box-sizing: border-box;
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(100% + 0.5rem);
  background: var(--bg-panel);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-md);
  box-shadow: 0 4px 12px var(--shadow-md);
  max-height: 17.5rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  z-index: 100;
}
.mention-autocomplete[hidden] {
  display: none;
}
.mention-autocomplete-list {
  overflow-y: auto;
  max-height: 15rem;
}
.mention-autocomplete-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  cursor: pointer;
  transition: background var(--transition-fast);
}
.mention-autocomplete-item:hover,
.mention-autocomplete-item.active {
  background: var(--bg-tertiary);
}
.mention-autocomplete-avatar {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: var(--font-weight-semibold);
  flex-shrink: 0;
}
.mention-autocomplete-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.mention-autocomplete-username {
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--text-primary);
}
.mention-autocomplete-name {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.site-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="site"] .post .post-actions {
  margin-top: 0.3rem;
  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="site"] .post .card-actions[data-has-reply-toggle="true"] {
  position: relative;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

body[data-route="site"]
  .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="site"]
  .post:hover
  .card-actions[data-has-reply-toggle="true"]
  > .card-actions-hover,
body[data-route="site"]
  .post:focus-within
  .card-actions[data-has-reply-toggle="true"]
  > .card-actions-hover,
body[data-route="site"]
  .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="site"]
  .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(--button-font-weight-emphasis);
  line-height: var(--button-line-height);
  transition:
    color var(--transition-fast),
    background-color var(--transition-fast),
    opacity var(--transition-fast);
}

body[data-route="site"]
  .post
  .card-actions[data-has-reply-toggle="true"]
  > .reply-tree-toggle-btn:hover,
body[data-route="site"]
  .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="site"]
  .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="site"]
  .post
  .card-actions[data-has-reply-toggle="true"]
  > .reply-tree-toggle-btn[aria-expanded="true"]:hover,
body[data-route="site"]
  .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="site"]
  .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: baseline;
  gap: 0.35rem;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.post .card-author {
  min-height: 1.75rem;
  min-width: 0;
}

@media (max-width: 480px) {
  .post .card-author {
    min-height: 0;
  }

  .post .card-body {
    margin-top: 0.15rem;
  }
}

.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(--button-font-weight-subtle);
  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 sites in card author - no underline */
.card-author .profile-site,
.card-author .profile-site:hover,
.card-author .profile-site:visited {
  text-decoration: none;
}

.card-author.card-author--connection .profile-site,
.card-author.card-author--connection .profile-site:visited {
  color: var(--poster-connection);
}

.card-author.card-author--connection .profile-site:hover {
  color: color-mix(in srgb, var(--poster-connection) 70%, #fff 30%);
}

.card-author.card-author--submitter .profile-site,
.card-author.card-author--submitter .profile-site:visited {
  color: var(--poster-submitter);
}

.card-author.card-author--submitter .profile-site:hover {
  color: color-mix(in srgb, var(--poster-submitter) 70%, #fff 30%);
}

.card-author .card-time-author {
  font-size: var(--font-size-xs);
  color: var(--meta-muted);
  white-space: nowrap;
  font-weight: var(--font-weight-normal);
  margin-left: 0.25rem;
}

/* 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-star);
  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-star-hover);
}

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

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

.star-btn.starred:hover {
  color: var(--star-star-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 {
  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(--button-font-weight);
}

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

.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(--button-font-weight);
}

.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-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-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) + 0.125rem);
  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-console-view
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
#moderator-console-view
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus {
  opacity: 1;
}

#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-console-card {
  position: relative;
}

.moderator-redirect-note {
  font-size: var(--font-size-sm);
}

.moderator-redirect-link {
  color: var(--accent-primary);
  text-decoration: underline;
}

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

#moderator-alerts-summary {
  display: grid;
  gap: 0.55rem;
  margin: 0 0 var(--space-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;
}

.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: var(--font-weight-semibold);
  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;
}

.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-row-value a {
  color: var(--text-primary);
  text-decoration: none;
}

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

.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 + .moderator-queue-card {
  margin-top: 0.1rem;
}

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

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

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

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

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

.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-action-buttons .moderator-inline-btn {
    min-width: 0;
    flex: 1 1 calc(50% - 0.45rem);
  }
}

.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 - 1.5rem));
  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:
    opacity 120ms ease,
    transform 160ms cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0s linear;
}

.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;
}

.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;
}

/* 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-action-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(11.5rem, 13rem);
  gap: var(--space-lg);
  align-items: start;
}

.settings-account-copy {
  min-width: 0;
}

.settings-account-controls {
  width: min(100%, 13rem);
  min-width: 0;
  justify-self: end;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.settings-action-card {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.settings-action-card-danger {
  border: none;
  background: transparent;
}

.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-subsection + .settings-subsection {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid
    color-mix(in srgb, var(--border-secondary) 72%, transparent);
}

.settings-subsection > .settings-section-desc:last-child {
  margin-bottom: 0;
}

.settings-coming-soon {
  display: flex;
  width: fit-content;
  align-items: center;
  margin: 0.35rem 0 0;
  padding: 0.035rem 0.3rem;
  border: 1px solid color-mix(in srgb, var(--border-secondary) 54%, transparent);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--bg-tertiary) 34%, transparent);
  color: color-mix(in srgb, var(--text-muted) 84%, var(--bg-muted) 16%);
  font-size: 0.69rem;
  font-style: normal;
  font-weight: var(--font-weight-normal);
  line-height: 1.2;
  vertical-align: 0.09em;
  white-space: nowrap;
}

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

.settings-section .input {
  width: 100%;
  max-width: 12.5rem;
  min-width: 0;
}

#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-tab-account .settings-section-title {
  margin-bottom: 0.35rem;
}

#settings-tab-account .settings-section-desc,
#settings-tab-account .settings-danger-text {
  margin-bottom: 0.45rem;
  max-width: 42ch;
}

#settings-tab-account .settings-current-value,
#settings-tab-account .settings-cooldown,
#settings-tab-account .settings-help-text,
#settings-tab-account .settings-status {
  font-size: var(--font-size-xs);
}

#settings-tab-account .settings-current-value {
  margin: 0 0 0.3rem;
  color: var(--text-secondary);
}

#settings-tab-account .settings-cooldown {
  margin: 0 0 0.35rem;
}

#settings-tab-account .settings-help-text {
  margin: 0.1rem 0 0;
}

#settings-tab-account .settings-status {
  margin: 0.4rem 0 0;
  min-height: 0;
}

#settings-tab-account .settings-muted-feedback {
  color: var(--text-muted);
}

#settings-tab-account .settings-action-card .settings-status {
  margin: 0;
}

#settings-tab-account .settings-action-card .settings-success-text {
  color: var(--toast-success);
}

#settings-tab-account .settings-action-card .input,
#settings-tab-account .settings-action-card .button-primary,
#settings-tab-account .settings-action-card .button-secondary,
#settings-tab-account .settings-action-card .button-danger,
#settings-tab-account .settings-account-controls > .button-primary,
#settings-tab-account .settings-account-controls > .button-secondary,
#settings-tab-account .settings-account-controls > .button-danger {
  width: 100%;
  max-width: none;
  min-width: 0;
  box-sizing: border-box;
  border-radius: var(--radius-full);
}

#settings-tab-account .settings-action-card .input {
  min-height: var(--app-input-min-height);
  padding: var(--app-input-padding);
  border-radius: var(--radius-full);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.03),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 4%, transparent 96%);
}

#settings-tab-account .settings-action-card .button-primary,
#settings-tab-account .settings-action-card .button-secondary,
#settings-tab-account .settings-action-card .button-danger,
#settings-tab-account .settings-account-controls > .button-primary,
#settings-tab-account .settings-account-controls > .button-secondary,
#settings-tab-account .settings-account-controls > .button-danger {
  justify-content: center;
}

#settings-tab-account .settings-action-card .settings-password-fields {
  width: 100%;
  max-width: none;
  gap: 0.5rem;
  margin-bottom: 0;
}

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

/* Settings rows: compact selectors stay right-aligned; wide and action controls can stack. */
.settings-control-row {
  padding: 0.45rem 0;
  border-bottom: 1px solid var(--border-secondary);
  font-size: var(--font-size-sm);
}

.settings-inline-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  column-gap: var(--space-md);
  row-gap: var(--space-sm);
}

.settings-block-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(6rem, 8rem);
  align-items: start;
  gap: var(--space-sm) var(--space-lg);
}

.settings-keybinding-item {
  list-style: none;
}

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

.settings-keybinding-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  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: 5.5rem;
  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);
  justify-self: end;
  align-self: start;
  white-space: nowrap;
}

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

.settings-range-control {
  cursor: default;
}

.settings-range-text {
  min-width: 0;
}

.settings-range-label {
  display: block;
  color: var(--text-primary);
}

.settings-range-track {
  --range-progress: 0%;
  --settings-range-track-height: 0.28rem;
  --settings-range-thumb-size: 1.06rem;
  position: relative;
  display: flex;
  align-items: center;
  min-width: 0;
  min-height: 1.25rem;
}

.settings-range-control input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  min-width: 0;
  height: 1rem;
  min-height: 0;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  cursor: pointer;
}

.settings-range-control input[type="range"]:not([type="checkbox"]):not(
    [type="radio"]
  ):not([type="hidden"]) {
  border: 0;
  border-radius: 0;
  padding: 0;
  min-height: 0;
  background: transparent;
  box-shadow: none;
}

.settings-range-control input[type="range"]:not([type="checkbox"]):not(
    [type="radio"]
  ):not([type="hidden"]):hover {
  opacity: 1;
}

.settings-range-control input[type="range"]:focus {
  outline: none;
}

.settings-range-control input[type="range"]::-webkit-slider-runnable-track {
  height: var(--settings-range-track-height);
  border: 0;
  border-radius: var(--radius-sm);
  background: linear-gradient(
    to right,
    color-mix(in srgb, var(--accent-primary) 48%, var(--bg-panel) 52%) 0
      var(--range-progress),
    color-mix(in srgb, var(--bg-input) 76%, var(--border-secondary) 24%)
      var(--range-progress) 100%
  );
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--border-secondary) 24%, transparent);
}

.settings-range-control input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: var(--settings-range-thumb-size);
  height: var(--settings-range-thumb-size);
  margin-top: calc(
    (var(--settings-range-track-height) - var(--settings-range-thumb-size)) / 2
  );
  border: 0;
  border-radius: var(--radius-sm);
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--bg-input) 88%, #fff 12%),
      color-mix(in srgb, var(--bg-input) 92%, #000 8%)
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--accent-primary) 56%, var(--border-secondary) 44%),
    inset 0 -0.35rem 0.7rem color-mix(in srgb, #000 18%, transparent);
}

.settings-range-control input[type="range"]:hover::-webkit-slider-thumb,
.settings-range-control input[type="range"]:focus-visible::-webkit-slider-thumb {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--accent-primary) 62%, var(--border-secondary) 38%),
    inset 0 -0.35rem 0.7rem color-mix(in srgb, #000 18%, transparent);
}

.settings-range-control input[type="range"]::-moz-range-track {
  height: var(--settings-range-track-height);
  border: 0;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--bg-input) 76%, var(--border-secondary) 24%);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--border-secondary) 24%, transparent);
}

.settings-range-control input[type="range"]::-moz-range-progress {
  height: var(--settings-range-track-height);
  border-radius: var(--radius-sm);
  background: color-mix(
    in srgb,
    var(--accent-primary) 48%,
    var(--bg-panel) 52%
  );
}

.settings-range-control input[type="range"]::-moz-range-thumb {
  width: var(--settings-range-thumb-size);
  height: var(--settings-range-thumb-size);
  border: 0;
  border-radius: var(--radius-sm);
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--bg-input) 88%, #fff 12%),
      color-mix(in srgb, var(--bg-input) 92%, #000 8%)
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--accent-primary) 56%, var(--border-secondary) 44%),
    inset 0 -0.35rem 0.7rem color-mix(in srgb, #000 18%, transparent);
}

.settings-range-control input[type="range"]:hover::-moz-range-thumb,
.settings-range-control input[type="range"]:focus-visible::-moz-range-thumb {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--accent-primary) 62%, var(--border-secondary) 38%),
    inset 0 -0.35rem 0.7rem color-mix(in srgb, #000 18%, transparent);
}

.settings-range-bubble {
  position: absolute;
  left: clamp(0.7rem, var(--range-progress), calc(100% - 0.7rem));
  bottom: calc(100% + 0.15rem);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.35rem;
  height: 1.25rem;
  padding: 0 0.25rem;
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  color: var(--text-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  pointer-events: none;
  opacity: 0;
  transform: translateX(-50%) translateY(0.2rem);
  transition:
    opacity var(--transition-fast),
    transform var(--transition-fast),
    visibility var(--transition-fast);
  visibility: hidden;
  z-index: 2;
}

.settings-range-track.is-adjusting .settings-range-bubble {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  visibility: visible;
}

.settings-color-options {
  display: flex;
  align-items: center;
  justify-self: end;
  align-self: start;
  gap: 0.4rem;
}

.settings-color-option {
  --settings-color-swatch: var(--accent-primary);
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 1.48rem;
  height: 1.48rem;
  min-width: 0;
  min-height: 0;
  padding: 0.11rem;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast);
}

.settings-color-option:hover,
.settings-color-option:focus-visible,
.settings-toggle:not(.settings-toggle-fixed):hover .settings-color-option,
.checkbox-label:hover .settings-color-option {
  border-color: transparent;
  background: transparent;
}

.settings-color-option:focus-visible,
.settings-choice-input:focus-visible ~ .settings-color-option {
  outline: 2px solid color-mix(in srgb, var(--settings-color-swatch) 34%, transparent);
  outline-offset: 0.16rem;
}

.settings-color-option[aria-pressed="true"],
.settings-choice-input:checked ~ .settings-color-option {
  border-color: transparent;
  box-shadow: none;
}

.settings-choice-input:checked:disabled ~ .settings-color-option {
  border-color: transparent;
  box-shadow: none;
}

.settings-color-swatch {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  border-radius: calc(var(--radius-md) - 0.11rem);
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--settings-color-canvas) 86%, #000 14%),
      var(--settings-color-canvas)
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--settings-color-swatch) 28%, var(--border-secondary) 72%),
    inset 0 -0.6rem 1rem color-mix(in srgb, #000 16%, transparent);
  transition:
    background var(--transition-fast),
    box-shadow var(--transition-fast);
}

.settings-color-option:hover .settings-color-swatch,
.settings-color-option:focus-visible .settings-color-swatch,
.settings-toggle:not(.settings-toggle-fixed):hover .settings-color-swatch,
.checkbox-label:hover .settings-color-swatch {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--settings-color-swatch) 46%, var(--border-secondary) 54%),
    inset 0 -0.6rem 1rem color-mix(in srgb, #000 16%, transparent);
}

.settings-color-option[aria-pressed="true"] .settings-color-swatch,
.settings-choice-input:checked ~ .settings-color-option .settings-color-swatch {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--settings-color-swatch) 62%, var(--border-secondary) 38%),
    inset 0 -0.6rem 1rem color-mix(in srgb, #000 16%, transparent);
}

.settings-choice-input:checked:disabled ~ .settings-color-option .settings-color-swatch {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--text-muted) 58%, var(--border-secondary) 42%),
    inset 0 -0.6rem 1rem color-mix(in srgb, #000 16%, transparent);
}

.settings-color-swatch::after {
  content: "";
  position: absolute;
  top: 47%;
  left: 50%;
  width: 0.28rem;
  height: 0.46rem;
  border-right: 0.11rem solid color-mix(in srgb, var(--color-ink) 92%, #fff 8%);
  border-bottom: 0.11rem solid color-mix(in srgb, var(--color-ink) 92%, #fff 8%);
  border-radius: 0.05rem;
  filter: drop-shadow(0 1px 1px color-mix(in srgb, #000 42%, transparent));
  opacity: 0;
  transform: translate(-50%, -50%) rotate(45deg) scale(0.72);
  transition:
    opacity var(--transition-fast),
    transform var(--transition-fast);
}

.settings-toggle-option,
.settings-checkbox-option {
  --settings-color-canvas: var(--bg-input);
  --settings-color-swatch: var(--accent-primary);
}

.settings-toggle-option {
  order: 2;
  justify-self: end;
  align-self: start;
  pointer-events: none;
}

.settings-checkbox-option {
  flex-shrink: 0;
  margin-top: 0.02rem;
}

.settings-color-option[aria-pressed="true"] .settings-color-swatch::after,
.settings-choice-input:checked ~ .settings-color-option .settings-color-swatch::after {
  opacity: 1;
  transform: translate(-50%, -50%) rotate(45deg) scale(1);
}

.settings-choice-input:disabled ~ .settings-color-option {
  --settings-color-swatch: var(--text-muted);
  cursor: default;
  opacity: 0.78;
}

.settings-color-option-blue {
  --settings-color-canvas: var(--palette-blue-canvas);
  --settings-color-swatch: var(--palette-blue-accent);
}

.settings-color-option-red {
  --settings-color-canvas: var(--palette-red-canvas);
  --settings-color-swatch: var(--palette-red-accent);
}

.settings-color-option-green {
  --settings-color-canvas: var(--palette-green-canvas);
  --settings-color-swatch: var(--palette-green-accent);
}

.settings-color-option-yellow {
  --settings-color-canvas: var(--palette-yellow-canvas);
  --settings-color-swatch: var(--palette-yellow-accent);
}

.settings-color-option-black {
  --settings-color-canvas: var(--palette-black-canvas);
  --settings-color-swatch: var(--palette-black-accent);
}

.settings-toggle {
  position: relative;
  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.settings-inline-control {
  column-gap: var(--space-sm);
}

.settings-toggle:last-child {
  border-bottom: 1px solid var(--border-secondary);
}

.settings-choice-input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: 0;
  padding: 0;
  border: 0;
  opacity: 0;
  pointer-events: none;
}

.settings-toggle-text {
  order: 1;
  min-width: 0;
  color: var(--text-primary);
}

.settings-toggle-context {
  display: block;
  margin-top: 0.15rem;
  color: var(--text-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  line-height: 1.35;
}

.settings-toggle.settings-toggle-fixed {
  cursor: default;
}

.settings-toggle.settings-toggle-fixed .settings-toggle-text {
  color: var(--text-primary);
}

#settings-change-email-btn,
#settings-change-username-btn {
  margin-top: 0;
}

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

.settings-navigation-group + .settings-navigation-group {
  margin-top: 1.1rem;
  padding-top: 0;
  border-top: 0;
}

.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.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-comms {
  display: none !important;
}

/* Settings - Danger section */
.settings-section + .settings-section-danger {
  border-top: 1px solid
    color-mix(in srgb, var(--danger-primary) 50%, transparent);
}

.settings-section:has(+ .settings-section-danger) {
  border-bottom: none;
}

.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;
}

/* Delete Account Modal */
.confirm-modal-content.delete-account-modal-content {
  width: min(100%, var(--modal-list-max-width));
  max-width: var(--modal-list-max-width);
}

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

.delete-account-warning {
  color: var(--text-muted);
  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);
}

/* TOTP Setup Modal */
.confirm-modal-content.totp-setup-modal-content {
  width: min(100%, var(--modal-verification-max-width));
  max-width: var(--modal-verification-max-width);
}

.totp-instructions {
  font-size: var(--font-size-sm);
}

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

.totp-qr-container img {
  max-width: 11.25rem;
  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-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1.45;
  color: var(--text-primary);
}

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

.totp-code-input::placeholder {
  font-family: var(--font-family);
  letter-spacing: 0;
}

#settings-action-2fa-modal .confirm-modal-content {
  width: min(100%, var(--modal-verification-max-width));
  max-width: var(--modal-verification-max-width);
}

#settings-action-2fa-modal .confirm-modal-message {
  white-space: normal;
}

#settings-action-2fa-modal .totp-code-input,
#settings-action-reauth-modal .totp-code-input {
  text-align: left;
  font-family: inherit;
  letter-spacing: 0;
}

#settings-action-password-modal .confirm-modal-actions,
#settings-action-2fa-modal .confirm-modal-actions,
#settings-action-reauth-modal .confirm-modal-actions {
  align-items: stretch;
}

#settings-action-password-modal .confirm-modal-actions button,
#settings-action-2fa-modal .confirm-modal-actions button,
#settings-action-reauth-modal .confirm-modal-actions button {
  flex: 1 1 0;
}

.totp-setup-actions {
  margin-top: var(--modal-section-gap);
}

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

.profile-connect-btn.is-connected {
  background: var(--poster-connection);
  color: #fff;
  border-color: var(--poster-connection);
  box-shadow: 0 1px 3px var(--shadow-md);
}

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

.profile-avatar-wrap {
  position: relative;
  width: 6.875rem;
  height: 6.875rem;
  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(--meta-primary);
  margin: 0;
}

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

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

.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(--meta-primary);
  white-space: nowrap;
  flex-shrink: 0;
}

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

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

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

.profile-site-card p,
.profile-post-card p {
  margin: 0.35rem 0 0;
  color: var(--meta-primary);
  font-size: 0.9rem;
}

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

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

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

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

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

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

.profile-connect-btn {
  flex-shrink: 0;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.34rem 0.78rem;
  border-style: solid;
  border-width: 1px;
  border-radius: var(--radius-full);
  font-size: 0.8rem;
  font-weight: var(--button-font-weight-subtle);
  line-height: var(--button-line-height);
  white-space: nowrap;
  transition:
    color var(--transition-fast),
    background-color var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

.button-secondary.profile-connect-btn:not(.is-connected):not(:hover):not(
    :focus-visible
  ):not(:active) {
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 28%,
    var(--border-secondary) 72%
  );
  color: color-mix(
    in srgb,
    var(--accent-primary) 38%,
    var(--text-muted) 62%
  );
}

.button-secondary.profile-connect-btn:not(.is-connected):hover,
.button-secondary.profile-connect-btn:not(.is-connected):focus-visible,
.button-secondary.profile-connect-btn:not(.is-connected):active {
  opacity: 1;
  border-color: var(--accent-primary);
  background: transparent;
  color: var(--accent-primary);
}

#profile-connect-btn.profile-connect-btn:not(.is-connected):hover {
  border-color: var(--poster-connection);
  color: var(--poster-connection);
}

#profile-connect-btn.profile-connect-btn.is-connected:hover {
  background: color-mix(in srgb, var(--poster-connection) 82%, var(--color-ink) 18%);
  border-color: color-mix(in srgb, var(--poster-connection) 82%, var(--color-ink) 18%);
}

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

/* Connections users chips */

.connections-user-chip img {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  object-fit: cover;
}

.connections-user-chip .no-avatar {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  background: var(--border-secondary);
}

/* Mobile responsive - tablets and below */
@media (max-width: 768px) {
  :root {
    --panel-inline-padding: 0.5rem;
    --nav-scale: 1;
  }

  .top-bar {
    padding-block: calc(0.5rem + 10px) 0.5rem;
    gap: 0.5rem;
  }

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

  .nav-segment-shell {
    --nav-segment-inset: 0.07rem;
    gap: 0.03rem;
    --nav-active-inset-inline: 0.02rem;
  }

  .nav-control-btn {
    padding: 0.3rem 0.72rem;
    font-size: 0.78rem;
  }

  .main-nav {
    gap: 0.32rem;
  }

  .main-nav .main-nav-site-btn {
    min-width: 2.2rem;
  }

  /* Prevent iOS zoom-on-focus for inputs below 16px */
  input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
  select,
  textarea {
    font-size: max(1rem, 16px);
  }

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

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

  .static-panel {
    max-width: 96%;
    margin-inline: auto;
    padding: var(--space-md) var(--panel-inline-padding)
      calc(var(--space-lg) + var(--space-sm));
  }

  .static-panel[data-route-view="feed"] {
    max-width: 100%;
  }

  .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.8rem, 5.65vw, 2.08rem);
  }

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

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

  .profile-header .profile-connect-btn {
    flex-shrink: 1;
    min-height: 0;
    padding: 0.45rem 0.85rem;
    font-size: var(--font-size-xs);
    margin-top: 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: 1rem;
    bottom: auto;
  }

  .toast {
    max-width: 100%;
    padding: 1rem 1.6rem 1rem 1.5rem;
  }

  .toast-close {
    transform: translate(-0.1rem, -0.6rem);
  }

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

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

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

  /* Touch target compliance — 44px minimum on mobile */
  .feed-master-filter .master-filter-option.sort-btn {
    min-height: var(--hit-target-min);
    padding: 0.25rem 0.55rem;
  }

  .feed-master-filter-inline-search .feed-search-bar {
    height: var(--hit-target-min);
    box-sizing: border-box;
  }

  .feed-master-filter-inline-search .feed-search-toggle {
    min-height: var(--hit-target-min);
  }

  .moderator-action-buttons .moderator-inline-btn {
    min-height: var(--hit-target-min);
  }
}

/* Mobile responsive - phones */
@media (max-width: 480px) {
  .top-bar {
    padding-block: calc(0.5rem + 10px) 0.5rem;
  }

  .top-bar-settings-wrap {
    --floating-settings-corner-gap: 0.5rem;
    --floating-settings-control-size: var(--nav-hit-target);
    --floating-settings-gap: 0.15rem;
  }

  .user-menu-trigger,
  .command-console-btn {
    width: var(--nav-hit-target);
    height: var(--nav-hit-target);
  }

  .user-menu-trigger svg,
  .command-console-btn svg {
    width: calc(20px * var(--nav-scale));
    height: calc(20px * var(--nav-scale));
  }

  .nav-segment-shell {
    --nav-segment-inset: 0.06rem;
    gap: 0.025rem;
    --nav-active-inset-inline: 0.018rem;
  }

  .nav-control-btn {
    padding: 0.26rem 0.62rem;
    font-size: 0.75rem;
  }

  .main-nav {
    gap: 0.28rem;
  }

  .main-nav .main-nav-site-btn {
    min-width: 2.2rem;
  }

  .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.82rem;
  }

  .site-row {
    flex-direction: column;
    gap: 0.5rem;
    padding-right: 2.5rem; /* Reserve space for absolute star button */
    overflow: hidden;
  }

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

  .site-body {
    width: 100%;
    gap: 0.35rem;
  }

  .card-title,
  .card-preview {
    white-space: normal;
  }

  .meta {
    font-size: 0.75rem;
    row-gap: 0.35rem;
  }

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

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

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

  .post {
    padding: 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-site-actions,
  .discussion-header .card-site-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 .card-body .card-time-inline-body {
    float: right;
    width: max-content;
    margin: 0 0 0 0.4rem;
    justify-content: flex-end;
  }

  .post .post-actions .card-time-inline {
    width: 100%;
    min-height: 0;
    margin-left: auto;
  }

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

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

  .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;
  }

  .feed-master-filter-inline-search .feed-search-bar {
    height: 30px;
  }

  .feed-master-filter-inline-search .feed-search-toggle {
    min-height: 30px;
  }

  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;
  }

  .feed-master-filter-inline-search .feed-search-bar input.feed-search-input {
    padding: 0;
    min-height: 0;
  }

  textarea {
    padding: 0.6rem 0.85rem;
  }

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

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

/* Modal containers */
.command-console-modal,
.auth-modal,
.avatar-picker-modal,
.discussants-modal,
.confirm-modal {
  position: fixed;
  inset: 0;
  box-sizing: border-box;
  height: var(--stable-viewport-height);
  min-height: var(--stable-viewport-height);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  padding: var(--space-md) var(--space-md)
    calc(var(--space-md) + var(--keyboard-inset-bottom));
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  scroll-padding-block: var(--space-md)
    calc(var(--space-lg) + var(--keyboard-inset-bottom));
}

.terms-gate-modal,
.birthday-gate-modal {
  position: fixed;
  inset: 0;
  box-sizing: border-box;
  height: var(--stable-viewport-height);
  min-height: var(--stable-viewport-height);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
  padding: var(--space-md) var(--space-md)
    calc(var(--space-md) + var(--keyboard-inset-bottom));
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  scroll-padding-block: var(--space-md)
    calc(var(--space-lg) + var(--keyboard-inset-bottom));
}

html[data-keyboard-visible="true"] .command-console-modal,
html[data-keyboard-visible="true"] .auth-modal,
html[data-keyboard-visible="true"] .avatar-picker-modal,
html[data-keyboard-visible="true"] .discussants-modal,
html[data-keyboard-visible="true"] .confirm-modal,
html[data-keyboard-visible="true"] .terms-gate-modal,
html[data-keyboard-visible="true"] .birthday-gate-modal {
  top: var(--visual-viewport-offset-top);
  bottom: auto;
  height: var(--keyboard-safe-viewport-height);
  min-height: var(--keyboard-safe-viewport-height);
  align-items: flex-start;
  padding-bottom: max(var(--space-md), env(safe-area-inset-bottom, 0px));
  scroll-padding-block: var(--space-md)
    max(var(--space-lg), env(safe-area-inset-bottom, 0px));
}

.command-console-modal[hidden],
.auth-modal[hidden],
.avatar-picker-modal[hidden],
.discussants-modal[hidden],
.confirm-modal[hidden],
.terms-gate-modal[hidden],
.birthday-gate-modal[hidden] {
  display: none;
}

/* Modal backdrops */
.command-console-modal,
.auth-modal-backdrop,
.avatar-picker-backdrop,
.discussants-modal-backdrop,
.confirm-modal-backdrop,
.waitlist-modal-backdrop,
.terms-gate-backdrop,
.birthday-gate-backdrop {
  background: rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

@supports not (backdrop-filter: blur(1px)) {
  .command-console-modal,
  .auth-modal-backdrop,
  .avatar-picker-backdrop,
  .discussants-modal-backdrop,
  .confirm-modal-backdrop,
  .waitlist-modal-backdrop,
  .terms-gate-backdrop,
  .birthday-gate-backdrop {
    background: rgba(0, 0, 0, 0.5);
  }
}

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

/* Modal content boxes */
.command-console-content,
.auth-modal-content,
.avatar-picker-content,
.discussants-modal-content,
.confirm-modal-content,
.terms-gate-content,
.birthday-gate-content {
  position: relative;
  background: var(--bg-panel);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-lg);
  width: 100%;
  height: auto;
  min-height: 0;
  box-sizing: border-box;
  max-height: calc(var(--keyboard-safe-viewport-height) - 2rem);
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  scroll-padding-block: var(--space-md)
    calc(var(--space-lg) + var(--keyboard-inset-bottom));
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.1),
    0 8px 20px var(--shadow-md),
    0 25px 50px var(--shadow-lg);
}

.modal-title,
.confirm-modal-content h2,
.avatar-picker-content h3,
.avatar-picker-content h4,
.birthday-gate-content h2,
.discussants-modal-title {
  margin: 0 0 var(--modal-title-gap);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--text-primary);
}

.modal-description,
.confirm-modal-message,
.auth-reset-description,
.birthday-gate-content > p:not([class]),
.totp-instructions {
  margin: 0 0 var(--modal-section-gap);
  color: var(--text-muted);
  line-height: var(--line-height-normal);
}

.modal-description.settings-danger-text {
  color: var(--text-muted);
}

/* Date of birth dropdown layout */
.dob-selects {
  display: flex;
  gap: var(--space-xs);
}

/* DOB pickers mirror the shared default app input tokens. The only differences:
   extra padding-right for the chevron, and a :has() rule for empty-state color. */
.dob-selects select {
  flex: 1;
  min-width: 0;
  appearance: none;
  -webkit-appearance: none;
  box-sizing: border-box;
  height: var(--app-input-default-min-height);
  padding: 0.6rem 1.8rem 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(--app-input-default-font-size);
  line-height: 1.1rem;
  background: color-mix(in srgb, var(--bg-input) 96%, var(--accent-primary) 4%);
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'><path fill='none' stroke='%23ffffff' stroke-opacity='0.7' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M3 4.5 6 7.5 9 4.5'/></svg>"),
    linear-gradient(
      color-mix(in srgb, var(--bg-input) 96%, var(--accent-primary) 4%),
      color-mix(in srgb, var(--bg-input) 96%, var(--accent-primary) 4%)
    );
  background-repeat: no-repeat, no-repeat;
  background-position: right 0.8rem center, center;
  background-size: 0.625rem 0.625rem, 100% 100%;
  color: var(--text-primary);
  text-overflow: ellipsis;
  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);
}

/* Focus state mirrors the auth input focus rule at line ~6424 —
   more accent tint on the border, background shifts toward --bg-panel,
   stronger inset highlight + outer glow. */
.dob-selects select:focus {
  outline: none;
  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%);
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'><path fill='none' stroke='%23ffffff' stroke-opacity='0.85' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M3 4.5 6 7.5 9 4.5'/></svg>"),
    linear-gradient(
      color-mix(in srgb, var(--bg-input) 90%, var(--bg-panel) 10%),
      color-mix(in srgb, var(--bg-input) 90%, var(--bg-panel) 10%)
    );
  background-repeat: no-repeat, no-repeat;
  background-position: right 0.8rem center, center;
  background-size: 0.625rem 0.625rem, 100% 100%;
  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);
}

/* Empty state: first <option value=""> is selected on initial render.
   Keep size stable and use shared placeholder color. */
.dob-selects select:has(option[value=""]:checked) {
  color: var(--text-placeholder);
}

/* Keep the native dropdown option list readable at normal weight even while
   the select itself renders its muted placeholder state above. */
.dob-selects select option {
  color: var(--text-primary);
  font-size: var(--font-size-base);
}

/* Redistribute flex weights so "Month" fits without ellipsis. Month needs
   the most room (longest month name "September" = 9 letters + chevron chrome),
   Day needs the least (3 letters), Year sits in the middle at the default
   weight. Applied to both the auth signup field and the birthday-gate modal
   so selected values never change the select's width on pick — widths are
   determined by flex, not content. */
#signup-dob-field .dob-selects select#modal-dob-month,
.birthday-gate-content .dob-selects select#birthday-gate-month {
  flex: 1.35;
}
#signup-dob-field .dob-selects select#modal-dob-day,
.birthday-gate-content .dob-selects select#birthday-gate-day {
  flex: 0.8;
}

/* Indent the "You must be at least 18 years old" hint so it visually aligns
   with where text inside the DOB pickers starts (1rem padding-left). */
#signup-dob-field .field-hint {
  padding-left: 1rem;
}

.auth-modal-content .field-error {
  margin-top: 0.15rem;
  padding-left: 0.35rem;
}

.birthday-gate-content > p:not([class]) {
  line-height: var(--line-height-normal);
}

.analytics-consent-banner {
  display: flex;
  justify-content: center;
  position: fixed;
  inset-inline: 0;
  bottom: var(--analytics-consent-footer-offset);
  z-index: 140;
  box-sizing: border-box;
  padding: var(--space-md) max(var(--space-md), env(safe-area-inset-right, 0px))
    calc(var(--space-md) + env(safe-area-inset-bottom, 0px))
    max(var(--space-md), env(safe-area-inset-left, 0px));
  pointer-events: none;
}

.analytics-consent-banner[hidden] {
  display: none;
}

.analytics-consent-card {
  width: fit-content;
  max-width: min(100%, 33.75rem);
  box-sizing: border-box;
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-lg);
  background: var(--bg-panel);
  box-shadow: 0 10px 30px var(--shadow-md);
  pointer-events: auto;
}

.analytics-consent-title {
  margin: 0 0 var(--space-xs);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--text-primary);
}

.analytics-consent-card p {
  margin: 0;
  font-size: var(--font-size-xs);
  line-height: var(--line-height-normal);
  color: var(--text-secondary);
}

.analytics-consent-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}

.analytics-consent-actions .button-primary,
.analytics-consent-actions .button-secondary {
  font-size: var(--font-size-xs);
  padding: var(--space-xs) var(--space-sm);
  min-height: 0;
}

.analytics-consent-link {
  margin-inline-start: auto;
  min-width: max-content;
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  text-decoration: none;
  text-align: right;
}

.analytics-consent-link:hover {
  color: var(--text-secondary);
  text-decoration: underline;
}

.analytics-consent-details {
  margin-top: var(--space-sm);
  font-size: var(--font-size-xs);
  color: var(--text-secondary);
}

.analytics-consent-details summary {
  cursor: pointer;
  color: var(--text-muted);
  user-select: none;
  list-style: revert;
}

.analytics-consent-details summary:hover {
  color: var(--text-secondary);
}

.analytics-consent-list {
  margin: var(--space-xs) 0 0;
  padding-inline-start: 1.25em;
  line-height: var(--line-height-relaxed);
}

.analytics-consent-list li {
  margin-bottom: 0.125rem;
}

.analytics-consent-badge {
  display: inline-block;
  font-size: 0.625rem;
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0 0.25rem;
  border-radius: var(--radius-sm);
  vertical-align: middle;
  margin-inline-start: 0.25rem;
}

.analytics-consent-badge--optional {
  color: var(--color-accent);
  background: var(--accent-light);
}

.analytics-consent-badge--functional {
  color: var(--text-muted);
  background: color-mix(in srgb, var(--text-muted) 12%, transparent);
}

/* Modal close buttons */
.auth-modal-close,
.avatar-picker-close,
.discussants-modal-close,
.confirm-modal-close {
  position: absolute;
  top: 0;
  right: 0.125rem;
  background: none;
  border: none;
  font-size: 1.25rem;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0.5rem;
  line-height: 1;
  z-index: 1;
}

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

#command-console-modal {
  align-items: flex-start;
  overflow-y: auto;
  padding: calc(var(--stable-vh) * 15) var(--space-md)
    calc(var(--stable-vh) * 20);
}

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

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

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

.command-console-input {
  width: 100%;
  box-sizing: border-box;
  border-radius: calc(var(--radius-md) + 0.125rem);
  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-console-input::placeholder {
  color: var(--text-muted);
}

.command-console-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-console-context.is-discuss .command-console-input {
  padding: 0;
}

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

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

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

.command-console-category-option:focus-visible {
  outline: 2px solid transparent;
  box-shadow: inset 0 0 0 2px var(--focus-ring);
}

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

.command-console-status {
  margin: 0;
  padding: 0 0.5rem;
  color: var(--text-muted);
  font-size: var(--font-size-xs);
}

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

.command-console-list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 20rem;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.command-console-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-console-item:hover,
.command-console-item.active {
  background: var(--bg-tertiary);
  border-color: var(--border-secondary);
}

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

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

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

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

.command-console-hint {
  margin: -0.45rem 0 0;
  padding: 0 0.50rem;
  color: var(--text-muted);
  font-size: var(--font-size-xs);
}

.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(--modal-account-padding);
  max-width: var(--modal-account-max-width);
}

.auth-modal-content h2:not(.modal-title) {
  margin: 0 0 var(--modal-section-gap);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
}

.auth-modal-content,
#delete-account-modal,
#totp-setup-modal,
#settings-action-password-modal,
#settings-action-2fa-modal,
#settings-action-reauth-modal,
#settings-tab-account {
  --app-input-min-height: var(--app-input-default-min-height);
  --app-input-padding: var(--app-input-default-padding);
  --app-input-font-size: var(--app-input-default-font-size);
}

#delete-account-modal,
#totp-setup-modal,
#settings-action-password-modal,
#settings-action-2fa-modal,
#settings-action-reauth-modal,
#settings-tab-account {
  --app-input-min-height: var(--app-input-compact-min-height);
  --app-input-padding: var(--app-input-compact-padding);
  --app-input-font-size: var(--app-input-compact-font-size);
}

#settings-tab-account .settings-action-card {
  --app-input-min-height: var(--app-input-dense-min-height);
  --app-input-padding: var(--app-input-dense-padding);
  --app-input-font-size: var(--app-input-dense-font-size);
}

.auth-modal-content
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
#delete-account-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
#totp-setup-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
#settings-action-password-modal
  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-action-reauth-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;
  width: 100%;
  box-sizing: border-box;
  min-height: var(--app-input-min-height);
  padding: var(--app-input-padding);
  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(--app-input-font-size);
  line-height: var(--app-input-line-height);
  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,
#delete-account-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
#delete-account-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus,
#totp-setup-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
#totp-setup-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus,
#settings-action-password-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
#settings-action-password-modal
  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-action-reauth-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):hover,
#settings-action-reauth-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,
#delete-account-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus,
#totp-setup-modal
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus,
#settings-action-password-modal
  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-action-reauth-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);
}

.button-modal-action,
#settings-edit-keybindings-btn {
  min-height: 2.6rem;
  padding: 0.62rem 1.2rem;
  border-radius: var(--radius-full);
  font-size: var(--button-font-size);
  font-weight: var(--button-font-weight);
  line-height: var(--button-line-height);
  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(--button-font-size);
  font-weight: var(--button-font-weight);
  line-height: var(--button-line-height);
  white-space: nowrap;
}

#settings-tab-account
  .settings-action-card
  input.input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
  width: 100%;
  max-width: none;
  min-height: var(--app-input-min-height);
  padding: var(--app-input-padding);
  border-radius: var(--radius-full);
  font-size: var(--app-input-font-size);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.03),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 4%, transparent 96%);
}

#settings-tab-account
  .settings-action-card
  input.input:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  ):focus {
  border-radius: var(--radius-full);
}

#settings-tab-account .settings-action-card .button-primary,
#settings-tab-account .settings-action-card .button-secondary,
#settings-tab-account .settings-action-card .button-danger,
#settings-tab-account .settings-account-controls > .button-primary,
#settings-tab-account .settings-account-controls > .button-secondary,
#settings-tab-account .settings-account-controls > .button-danger {
  width: 100%;
  max-width: none;
  min-width: 0;
  min-height: 2.18rem;
  padding: 0.38rem 0.72rem;
  border-radius: var(--radius-full);
  font-size: 0.86rem;
  justify-content: center;
  align-self: stretch;
}

.auth-tab {
  min-height: 3rem;
  padding: 0.08rem 0.48rem;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: var(--button-font-weight-emphasis);
  line-height: var(--button-line-height);
}

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

.auth-modal-content .button-primary.button-modal-action {
  font-weight: var(--button-font-weight-emphasis);
}

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

.waitlist-back-btn,
.auth-reset-back-btn,
.report-reason-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);
  min-width: 0;
  min-height: 0;
  width: auto;
  height: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: opacity var(--transition-fast);
}

.waitlist-back-btn:hover,
.waitlist-back-btn:focus-visible,
.auth-reset-back-btn:hover,
.auth-reset-back-btn:focus-visible,
.report-reason-back-btn:hover,
.report-reason-back-btn:focus-visible {
  background: transparent;
  opacity: 0.7;
}

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

.waitlist-invite-link,
.terms-gate-signout,
.birthday-gate-signout {
  display: block;
  width: 100%;
  margin-top: var(--modal-quiet-action-gap);
  padding: 0.25rem 0;
  border-radius: var(--radius-sm);
  text-align: center;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: color-mix(in srgb, var(--color-accent) 74%, #fff 26%);
  text-shadow:
    0 0 6px
      color-mix(
        in srgb,
        var(--color-accent) calc(12% * var(--neon-text-intensity)),
        transparent
      ),
    0 0 14px
      color-mix(
        in srgb,
        var(--color-accent) calc(5% * var(--neon-text-intensity)),
        transparent
      );
  cursor: pointer;
  opacity: 1;
  transition:
    color var(--transition-fast),
    text-shadow var(--transition-fast),
    opacity var(--transition-fast);
}

.waitlist-invite-link:hover,
.waitlist-invite-link:focus-visible,
.terms-gate-signout:hover,
.terms-gate-signout:focus-visible,
.birthday-gate-signout:hover,
.birthday-gate-signout:focus-visible {
  color: color-mix(in srgb, var(--color-accent) 84%, #fff 16%);
  opacity: 1;
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.14em;
  text-shadow:
    0 0 8px
      color-mix(
        in srgb,
        var(--color-accent) calc(16% * var(--neon-text-intensity)),
        transparent
      ),
    0 0 18px
      color-mix(
        in srgb,
        var(--color-accent) calc(7% * var(--neon-text-intensity)),
        transparent
      );
}

.waitlist-invite-link:focus-visible,
.terms-gate-signout:focus-visible,
.birthday-gate-signout:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .waitlist-invite-link,
  .terms-gate-signout,
  .birthday-gate-signout {
    transition: none;
  }
}

/* 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:
    background var(--transition-fast),
    color var(--transition-fast),
    filter var(--transition-fast);
}

.auth-tab:not(.active):hover {
  background: color-mix(in srgb, var(--color-accent) 40%, var(--color-canvas) 60%);
  color: var(--color-accent);
}

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

.auth-tab.active:hover {
  filter: brightness(1.08);
}

/* Forgot-password link shown under the sign-in password field */
.auth-forgot-password {
  display: flex;
  justify-content: flex-end;
  margin-top: -0.3rem;
}

.auth-forgot-password-link {
  background: none;
  border: none;
  padding: 0;
  color: var(--text-muted);
  cursor: pointer;
  font-size: var(--font-size-xs);
  text-decoration: none;
}

.auth-forgot-password-link:hover,
.auth-forgot-password-link:focus-visible {
  color: var(--text-secondary);
  text-decoration: underline;
}

/* Reset-request and recovery sub-states */
.auth-reset-request,
.auth-reset-recovery {
  display: flex;
  flex-direction: column;
}

.auth-reset-title {
  margin-bottom: var(--modal-title-gap);
}

.auth-reset-description {
  margin-bottom: var(--modal-section-gap);
}

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

#auth-main-fields,
#signup-only-fields {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

#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-top: var(--modal-form-action-gap);
  margin-bottom: var(--modal-form-action-gap);
}

.auth-reset-request .form-actions,
.auth-reset-recovery .form-actions {
  margin-bottom: 0;
}

.terms-gate-actions,
.birthday-gate-actions {
  margin-top: var(--modal-section-gap);
}

.terms-gate-actions .button-modal-action,
.birthday-gate-actions .button-modal-action {
  width: 100%;
}

#terms-gate-status:not(:empty) {
  margin-top: var(--modal-form-action-gap);
}

.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 {
  text-align: center;
}

.avatar-picker-content h3 {
  margin-bottom: var(--modal-section-gap);
}

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

.avatar-picker-content .avatar-color-btn {
  width: 3rem;
  height: 3rem;
  min-width: 3rem;
  min-height: 3rem;
  padding: 0;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
}

/* 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: 1.375rem;
  height: 1.375rem;
  background: var(--bg-panel);
  border: 2px solid var(--border-secondary);
  border-radius: 50%;
  font-size: 0.75rem;
  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;
}

/* Drop the focus outline on the display-name edit input. The .profile-name
   <h2> has overflow: hidden (from its -webkit-line-clamp: 2 responsive
   rule at line ~9066) which clips the outline's top and bottom edges when
   the input is focused inside it. On-open input.select() highlights the
   text, which is sufficient visual cue for edit mode. Selector matches
   the base input.profile-inline-edit:focus :not() chain to beat its
   (0, 5, 1) specificity. Bio's edit state has its own outline: none
   rule, so this only affects the name input. */
input.profile-inline-edit.profile-name-edit:not([type="checkbox"]):not(
    [type="radio"]
  ):not([type="hidden"]):focus {
  outline: none;
}

/* Match the full placeholder selector chain so the inline profile-name edit
   placeholder keeps the display-name weight, color, and scale. */
input.profile-name-edit:not([type="checkbox"]):not([type="radio"]):not(
    [type="hidden"]
  )::placeholder {
  font: inherit;
  color: var(--profile-site);
  opacity: 0.4;
}

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: 2.25rem;
  height: 2.25rem;
  min-width: 2.25rem;
  min-height: 2.25rem;
  aspect-ratio: 1 / 1;
  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);
}

/* Picker upload section (avatar + cover modals) */
.picker-upload-section {
  margin-top: var(--modal-section-gap);
}

.picker-divider {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin: var(--modal-section-gap) 0;
  color: var(--text-tertiary);
  font-size: var(--font-size-sm);
}

.picker-divider::before,
.picker-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--border-primary);
}

.picker-upload-btn {
  width: 100%;
}

.picker-upload-preview {
  margin-top: var(--modal-section-gap);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}

.picker-upload-title {
  align-self: stretch;
  margin-bottom: 0;
  font-size: var(--font-size-base);
  text-align: center;
}

.picker-upload-preview img {
  max-width: 100%;
  max-height: 12.5rem;
  border-radius: var(--radius-md);
  object-fit: contain;
  border: 1px solid var(--border-primary);
}

.avatar-picker-content .picker-upload-actions {
  display: flex;
  gap: var(--modal-form-action-gap);
  justify-content: center;
  width: 100%;
  margin-top: var(--modal-form-action-gap);
}

.avatar-picker-content .picker-upload-actions button {
  flex: 0 1 auto;
}

.picker-upload-status {
  margin-top: var(--space-sm);
  margin-bottom: 0;
  font-size: var(--font-size-sm);
}

.picker-upload-status:empty {
  display: none;
}

.picker-upload-error {
  color: var(--text-secondary);
}

.picker-remove-btn {
  margin-top: var(--space-md);
  width: 100%;
  font-size: var(--font-size-sm);
  color: var(--text-tertiary);
}

.picker-remove-btn:hover {
  color: var(--text-secondary);
}

/* 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);
}

/* When a user has an uploaded image, remove the color background
   so transparent PNGs/WebPs render without color bleeding through. */
.profile-avatar-wrap.has-image {
  background: transparent;
}

/* 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: 2.25rem;
  height: 2.25rem;
  border-radius: var(--radius-md);
  overflow: hidden;
  flex-shrink: 0;
}

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

.card-avatar-link {
  display: contents;
}

/* Card avatars */
.card-avatar {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  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-sites,
.footer-copyright {
  color: var(--text-muted);
}

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

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

.footer-sites 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-sites a:hover,
.footer-sites a:focus-visible,
.footer-copyright a:hover,
.footer-copyright a:focus-visible {
  opacity: 0.7;
}

.footer-copyright {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: calc(var(--space-md) - 0.5rem) 0 0;
  font-size: calc(var(--font-size-xs) * 0.85);
  color: color-mix(in srgb, var(--text-muted) 92%, var(--bg-body) 8%);
}

/* ============================================================================
   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);
}

@media (max-width: 768px) {
  .static-card {
    padding: 1.2rem;
    border-radius: 0.75rem;
  }
}

.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-route-slot {
  width: 100%;
}

.static-route-shell {
  min-height: 18rem;
}

.static-route-status {
  margin: 0;
  color: var(--text-muted);
}

.static-tagline {
  margin: 0 0 var(--space-md);
  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-tilde-highlight {
  display: inline;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  padding: 0.01em 0.1em 0.05em;
  border-radius: calc(var(--radius-sm) * 0.75);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--accent-primary) 6%, transparent) 0%,
    color-mix(in srgb, var(--accent-primary) 10%, transparent) 64%,
    color-mix(in srgb, var(--accent-primary) 7%, transparent) 100%
  );
  color: color-mix(in srgb, var(--text-primary) 90%, var(--accent-primary) 10%);
  box-shadow: inset 0 -0.08em 0
    color-mix(in srgb, var(--accent-primary) 10%, transparent);
}

.about-support {
  font-size: var(--font-size-sm);
  font-style: italic;
  color: var(--text-secondary);
}

.about-underscored {
  display: inline-block;
  position: relative;
  width: fit-content;
  max-width: 100%;
  padding-bottom: 0.12em;
  color: inherit;
  text-decoration: none;
  transform-origin: center;
  transition: transform var(--transition-fast);
}

.static-content a.about-underscored {
  color: inherit;
  text-decoration: none;
}

.static-content a.about-underscored:hover,
.static-content a.about-underscored:focus-visible {
  color: inherit;
  text-decoration: none;
  transform: scale(1.004);
}

.about-underscored::after,
.static-content a.extension-eyebrow::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 0;
  border-top: 1px solid var(--border-secondary);
  border-radius: var(--radius-pill);
  box-shadow: 0 0 26px
    color-mix(
      in srgb,
      var(--accent-primary) calc(22% * var(--neon-surface-intensity)),
      transparent
    );
  filter: drop-shadow(
      0 0 10px
        color-mix(
          in srgb,
          var(--accent-primary) calc(58% * var(--neon-surface-intensity)),
          transparent
        )
    )
    drop-shadow(
      0 0 22px
        color-mix(
          in srgb,
          var(--accent-primary) calc(34% * var(--neon-surface-intensity)),
          transparent
        )
    )
    drop-shadow(
      0 0 36px
        color-mix(
          in srgb,
          var(--accent-primary) calc(24% * var(--neon-surface-intensity)),
          transparent
        )
  );
  pointer-events: none;
}

.static-content p.about-support {
  margin-top: calc(var(--space-md) + (var(--space-xs) / 2));
}

.about-support a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 0.14em;
}

.about-support a:hover,
.about-support a:focus-visible {
  color: inherit;
}

.static-tldr {
  box-sizing: border-box;
  width: 100%;
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: 0;
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 5%, transparent 95%),
    0 0 20px
      color-mix(
        in srgb,
        var(--accent-primary) calc(10% * var(--neon-surface-intensity)),
        transparent
      );
}

.static-tldr h2 {
  margin: 0 0 var(--space-sm);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.static-tldr ul {
  margin: 0;
  padding-left: 1.25rem;
}

.static-tldr li {
  margin-bottom: 0.3rem;
  font-size: var(--font-size-base);
}

.static-tldr li:last-child {
  margin-bottom: 0;
}

.static-tldr li.static-tldr-contact {
  margin-bottom: calc(var(--space-sm) + var(--space-xs));
}

.static-tldr .static-updated {
  margin: 0 0 var(--space-md);
}

.static-inline-action {
  margin: 0 0 var(--space-lg);
}

.static-inline-action .button-secondary:not(.profile-connect-btn) {
  min-height: var(--hit-target-min);
}

.static-tldr-action {
  display: flex;
  padding-left: 1.25rem;
  line-height: 1;
}

.static-content .static-tldr-action {
  margin: 0 0 0.18rem;
}

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

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

/* Protocol specific */

.protocol-content {
  line-height: var(--line-height-relaxed);
}

.protocol-rule-list {
  display: grid;
  gap: 0;
  margin: 0;
}

.protocol-rule {
  padding: var(--space-sm) 0 var(--space-md);
  border-bottom: 1px solid var(--border-secondary);
}

.protocol-rule:first-child {
  padding-top: var(--space-sm);
}

.protocol-rule h2 {
  margin: 0 0 var(--space-sm);
  color: var(--text-muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.protocol-rule-points {
  margin: 0;
  padding-left: 1.25rem;
}

.protocol-rule-points li::marker {
  color: var(--text-muted);
}

.protocol-rule:last-child {
  border-bottom: 0;
}

.protocol-content .protocol-intro {
  color: inherit;
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  margin: 0;
}

.protocol-content .protocol-note {
  margin: 0;
}

.protocol-note {
  padding: 0.56rem 0 0;
  border-top: 1px solid var(--border-secondary);
  color: var(--text-muted);
  font-size: var(--font-size-xs);
  line-height: 1.5;
}

.protocol-note + .protocol-note {
  margin-top: 0.42rem;
  padding-top: 0;
  border-top: 0;
}

.protocol-intro + .protocol-rule-list {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--border-secondary);
}

@media (max-width: 480px) {
  .protocol-rule {
    padding: var(--space-xs) 0 var(--space-sm);
  }
}

/* Pricing specific */

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

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

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

/* Extensions specific */

.extension-launch {
  display: grid;
  gap: var(--space-md);
  margin-top: var(--space-lg);
  text-align: left;
}

.extension-copy {
  min-width: 0;
  text-align: left;
}

.extension-copy p:last-child {
  margin-bottom: 0;
}

.static-content .extension-eyebrow {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  margin: 0 0 0.15rem;
  padding-bottom: 0.1rem;
  color: var(--accent-primary);
  font-size: 0.95rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-decoration: none;
  text-transform: uppercase;
  transform-origin: center;
  transition: transform var(--transition-fast);
}

.static-content a.extension-eyebrow:hover,
.static-content a.extension-eyebrow:focus-visible {
  text-decoration: none;
  transform: scale(1.004);
}

.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-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);
}

/* ============================================================================
   Legal Pages (Terms, Privacy)
   ============================================================================ */

.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-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;
}

.auth-modal-content .field-checkbox,
.terms-gate-content .field-checkbox {
  text-align: left;
  margin-top: var(--space-sm);
}

.checkbox-label {
  position: relative;
  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;
}

.auth-modal-content .checkbox-label,
.terms-gate-content .checkbox-label {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  width: 100%;
  max-width: 100%;
  min-height: 0;
  white-space: normal;
  line-height: 1.45;
}

.auth-modal-content .checkbox-text,
.terms-gate-content .checkbox-text {
  min-width: 0;
}

.checkbox-label a {
  color: var(--text-site);
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.checkbox-label a:hover {
  opacity: 0.7;
}

.field-error {
  margin: var(--space-xs) 0 0;
}

.field-error:empty {
  display: none;
}

/* ============================================================================
   Legal Pages Responsive
   ============================================================================ */
@media (max-width: 768px) {
  .legal-content {
    padding: var(--space-lg);
  }
}

@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)
   ============================================================================ */
.confirm-modal-content.discussants-modal-content {
  padding: var(--modal-compact-padding);
  width: min(100%, var(--modal-list-max-width));
  max-width: var(--modal-list-max-width);
}

.discussants-modal-title {
  margin-bottom: var(--modal-section-gap);
}

.discussants-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  max-height: var(--modal-list-max-height);
  overflow-y: auto;
}

.discussants-load-more-btn {
  width: 100%;
  margin-top: var(--modal-section-gap);
}

.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-site);
  text-decoration: none;
  font-weight: var(--font-weight-normal);
  transition: opacity var(--transition-fast);
}

.discussant-item a:hover {
  opacity: 0.7;
}

.discussant-item--connection a {
  color: var(--poster-connection);
}

.discussant-item--connection a:hover {
  color: color-mix(in srgb, var(--poster-connection) 70%, #fff 30%);
  opacity: 1;
}

.discussant-item--submitter a {
  color: var(--poster-submitter);
}

.discussant-item--submitter a:hover {
  color: color-mix(in srgb, var(--poster-submitter) 70%, #fff 30%);
  opacity: 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.15rem;
  font-size: var(--button-font-size);
  font-weight: var(--button-font-weight-subtle);
  color: var(--discussant-site);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  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(--modal-compact-padding);
  width: min(100%, var(--modal-compact-max-width));
  max-width: var(--modal-compact-max-width);
}

#confirm-modal .confirm-modal-content {
  width: auto;
  max-width: min(100%, var(--modal-compact-max-width));
}

.confirm-modal-content h2 {
  margin-bottom: var(--modal-title-gap);
}

.confirm-modal-message {
  word-break: break-word;
  white-space: pre-wrap;
}

.confirm-modal-message-block {
  display: block;
}

.confirm-modal-message-url {
  margin-top: var(--space-xs);
  color: var(--text-primary);
}

.confirm-modal-message-details {
  margin-top: var(--space-sm);
}

.confirm-modal-actions {
  display: flex;
  gap: var(--modal-form-action-gap);
  flex-wrap: wrap;
  justify-content: flex-start;
}

.confirm-modal-actions button {
  min-width: 0;
  min-height: 2.25rem;
  padding: 0.45rem 0.95rem;
  border-radius: var(--radius-full);
  font-size: var(--button-font-size);
  font-weight: var(--button-font-weight);
  line-height: var(--button-line-height);
  white-space: nowrap;
}

.confirm-modal-actions .button-secondary {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--border-secondary);
}

.confirm-modal-actions .button-secondary:hover {
  color: var(--text-primary);
  border-color: var(--text-muted);
}

#delete-account-modal .confirm-modal-actions,
#disable-2fa-modal .confirm-modal-actions,
#settings-action-2fa-modal .confirm-modal-actions,
#settings-action-password-modal .confirm-modal-actions,
#settings-action-reauth-modal .confirm-modal-actions {
  margin-top: var(--modal-section-gap);
}

#delete-account-modal .field + .field,
#disable-2fa-modal .field + .field,
#settings-action-2fa-modal .field + .field {
  margin-top: var(--modal-section-gap);
}

#report-reason-modal .confirm-modal-actions {
  display: flex;
  flex-direction: column;
  gap: var(--modal-form-action-gap);
}

.moderator-action-modal-content {
  width: min(100%, var(--modal-form-max-width));
  max-width: var(--modal-form-max-width);
}

.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(--modal-section-gap);
}

#report-reason-modal .report-reason-extra {
  --report-reason-toggle-width: 2.6rem;
  --report-reason-toggle-height: 1.55rem;
  --report-reason-toggle-gap: 0.75rem;
  margin: 0 0 var(--modal-form-action-gap);
  padding: 0.95rem 1rem 1rem;
  border: 1px solid
    color-mix(in srgb, var(--accent-primary) 38%, var(--border-secondary) 62%);
  border-radius: calc(var(--radius-lg) + 0.125rem);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--accent-light) 24%, var(--bg-panel) 76%) 0%,
    color-mix(in srgb, var(--bg-panel) 94%, var(--accent-primary) 6%) 100%
  );
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--color-ink) 10%, transparent 90%),
    0 10px 24px color-mix(in srgb, var(--shadow-md) 36%, transparent 64%);
  text-align: left;
}

#report-reason-modal .report-reason-checkbox {
  position: relative;
  align-items: flex-start;
  justify-content: flex-start;
  gap: var(--report-reason-toggle-gap);
  width: 100%;
  min-height: 0;
  padding: 0;
  white-space: normal;
  color: var(--text-primary);
}

#report-reason-modal .report-reason-toggle-input {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

#report-reason-modal .report-reason-toggle {
  position: relative;
  flex: 0 0 auto;
  width: var(--report-reason-toggle-width);
  height: var(--report-reason-toggle-height);
  margin-top: 0.05rem;
  border-radius: var(--radius-full);
  border: 1px solid
    color-mix(in srgb, var(--border-secondary) 78%, var(--color-ink) 22%);
  background: color-mix(in srgb, var(--bg-input) 88%, var(--color-ink) 12%);
  box-shadow: inset 0 1px 2px var(--shadow-sm);
  transition:
    background-color var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

#report-reason-modal .report-reason-toggle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.16rem;
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-ink) 92%, #fff 8%);
  box-shadow: 0 2px 6px var(--shadow-md);
  transform: translateY(-50%);
  transition: transform var(--transition-fast);
}

#report-reason-modal
  .report-reason-toggle-input:checked
  + .report-reason-toggle {
  border-color: color-mix(in srgb, var(--accent-primary) 62%, #fff 38%);
  background: linear-gradient(
    180deg,
    var(--accent-hover) 0%,
    var(--accent-primary) 100%
  );
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--accent-primary) 14%, transparent 86%),
    0 10px 24px color-mix(in srgb, var(--accent-primary) 22%, transparent 78%);
}

#report-reason-modal
  .report-reason-toggle-input:checked
  + .report-reason-toggle::after {
  transform: translate(1.06rem, -50%);
}

#report-reason-modal
  .report-reason-toggle-input:focus-visible
  + .report-reason-toggle {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

#report-reason-modal .report-reason-copy {
  display: flex;
  flex: 1 1 auto;
  min-width: 0;
  flex-direction: column;
  gap: 0.28rem;
}

#report-reason-modal .report-reason-kicker {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: 0.16rem 0.5rem;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--accent-primary) 12%, transparent 88%);
  color: color-mix(in srgb, var(--accent-hover) 88%, #fff 12%);
  font-size: 0.68rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.045em;
  text-transform: uppercase;
}

#report-reason-modal .report-reason-title {
  font-size: var(--font-size-base);
  font-weight: var(--button-font-weight);
  line-height: 1.35;
  color: var(--text-primary);
}

#report-reason-modal .report-reason-hint {
  margin: 0 0 0
    calc(var(--report-reason-toggle-width) + var(--report-reason-toggle-gap));
  font-size: var(--font-size-sm);
  line-height: 1.55;
  color: var(--text-secondary);
}

#report-reason-modal .confirm-modal-actions button {
  width: 100%;
  min-width: 0;
}

#report-reason-modal .report-reason-cancel-btn {
  color: var(--text-secondary);
  border-color: var(--border-secondary);
}

#report-reason-modal .report-reason-other-view {
  display: flex;
  flex-direction: column;
  gap: var(--modal-form-action-gap);
  overflow: visible;
}

#report-reason-modal .report-reason-other-title {
  margin-bottom: var(--modal-title-gap);
}

#report-reason-modal .report-reason-other-input {
  box-sizing: border-box;
  width: 100%;
  padding: 0.65rem 0.75rem;
  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%);
  color: var(--text-primary);
  font-family: inherit;
  font-size: var(--font-size-sm);
  line-height: 1.45;
  resize: vertical;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

#report-reason-modal .report-reason-other-input::placeholder {
  font-style: normal;
}

#report-reason-modal .report-reason-other-input:focus {
  outline: none;
  background: transparent;
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 12%,
    var(--border-secondary) 88%
  );
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 10%, transparent 90%);
}

#report-reason-modal .report-reason-submit-btn {
  width: 100%;
}

/* ============================================================================
   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;
}

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

/* ============================================================================
   Unified Card Component (used by feed and profile activity)
   ============================================================================ */
.card {
  display: flex;
  gap: var(--space-sm);
  padding: 0.4rem var(--space-md) 0.3rem;
  border-radius: var(--radius-md);
  background: var(--site-row-bg);
  transition: background var(--transition-fast);
  align-items: stretch;
  cursor: pointer;
  position: relative;
}

.card.card-has-site-actions {
  padding-bottom: 0.45rem;
}

.card:hover {
  background: var(--bg-secondary);
}

/*
 * Neon-sign effect for the sites feed: a thin accent-colored outline with a
 * soft outer bloom + a subtle downward drop shadow so each card feels
 * slightly lifted off the background. Scoped to #sites-list so profile
 * activity cards stay flat.
 */
#sites-list .card {
  outline: 1px solid
    color-mix(
      in srgb,
      var(--color-accent) calc(13% * var(--neon-surface-intensity)),
      transparent
    );
  outline-offset: -1px;
  isolation: isolate;
  background: linear-gradient(
    180deg,
    color-mix(
        in srgb,
        var(--site-row-bg) calc(100% - (5% * var(--neon-surface-intensity))),
        var(--color-accent) calc(5% * var(--neon-surface-intensity))
      )
      0%,
    var(--site-row-bg) 55%
  );
  box-shadow:
    0 0 14px -6px
      color-mix(
        in srgb,
        var(--color-accent) calc(22% * var(--neon-surface-intensity)),
        transparent
      ),
    0 2px 6px -2px color-mix(in srgb, #000 45%, transparent);
  transition:
    background var(--transition-fast),
    box-shadow var(--transition-fast);
}

/*
 * Hover top-tint overlay: a second gradient on a ::before pseudo-element that
 * fades in/out via opacity. Opacity interpolates smoothly in every browser,
 * unlike gradient-to-gradient background transitions which hard-swap.
 */
#sites-list .card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: inherit;
  background: linear-gradient(
    180deg,
    color-mix(
        in srgb,
        var(--site-row-bg) calc(100% - (8% * var(--neon-surface-intensity))),
        var(--color-accent) calc(8% * var(--neon-surface-intensity))
      )
      0%,
    var(--bg-secondary) 55%
  );
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-slow);
}

#sites-list .card:hover::before {
  opacity: 1;
}

#sites-list .card:hover {
  outline-color: color-mix(
    in srgb,
    var(--color-accent) calc(20% * var(--neon-surface-intensity)),
    transparent
  );
  box-shadow:
    0 0 16px -5px
      color-mix(
        in srgb,
        var(--color-accent) calc(25% * var(--neon-surface-intensity)),
        transparent
      ),
    0 4px 10px -3px color-mix(in srgb, #000 55%, transparent);
}

/* Needs the #sites-list prefix to beat the base rule's ID specificity.
   Uses outline (not box-shadow) to avoid clobbering the decorative glow. */
#sites-list .card:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: -2px;
}

.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-top: 0.4rem;
  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;
  margin-top: 0.4rem;
}

.profile-activity-post .card-body .card-time-inline-body {
  margin-top: -0.3rem;
  line-height: var(--line-height-tight);
}

.card:focus-visible {
  /* Inset ring to match the picker focus style — consistent arrow-key loop. */
  outline: 2px solid transparent;
  box-shadow: inset 0 0 0 2px var(--focus-ring);
}

.card-content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0;
  flex: 1;
  min-width: 0;
}

.card-title {
  color: var(--external-site-link);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  text-shadow:
    0 0 6px
      color-mix(
        in srgb,
        var(--color-accent) calc(14% * var(--neon-text-intensity)),
        transparent
      ),
    0 0 14px
      color-mix(
        in srgb,
        var(--color-accent) calc(4% * var(--neon-text-intensity)),
        transparent
      );
  line-height: var(--line-height-tight);
  margin-top: 0;
  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(--meta-primary);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0;
}

.card-meta-item {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  max-width: 100%;
}

.card-post-count,
.card-category-label,
.card-pending-release {
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  padding: 0.25rem 0.15rem;
  color: var(--discussant-site);
  white-space: nowrap;
  transition:
    color var(--transition-fast),
    opacity var(--transition-fast);
}

.card-pending-release {
  color: var(--pending-release);
}

a.card-category-label {
  border-radius: var(--radius-sm);
  text-decoration: none;
}

a.card-category-label:hover,
a.card-category-label:focus-visible {
  color: var(--accent-hover);
  text-decoration: none;
}

a.card-category-label:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--focus-ring) 44%, transparent);
  outline-offset: 0.12rem;
}

.card-meta-sep {
  color: var(--meta-muted);
  margin: 0 0.1rem;
}

.card-meta-item:not(.card-meta-item-final):not(.card-meta-item-row-end)::after {
  content: "\2022";
  color: var(--meta-muted);
  margin: 0 0.1rem;
}

.card-last-poster {
  color: var(--discussant-site);
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  padding: 0.25rem 0.15rem;
}

@media (max-width: 768px) {
  .card-post-count,
  .card-category-label,
  .card-pending-release,
  .card-last-poster {
    min-height: var(--hit-target-min);
  }
}

.card-last-poster--connection {
  color: var(--poster-connection);
}

.card-last-poster--submitter {
  color: var(--poster-submitter);
}

.card-last-poster .profile-site {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

.card-last-poster .profile-site:hover {
  color: var(--accent-hover);
}

.card-last-poster--connection .profile-site:hover {
  color: color-mix(in srgb, var(--poster-connection) 70%, #fff 30%);
  opacity: 0.96;
}

.card-last-poster--submitter .profile-site:hover {
  color: color-mix(in srgb, var(--poster-submitter) 70%, #fff 30%);
  opacity: 0.96;
}

.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: 0.25rem;
  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;
}

@media (max-width: 768px) {
  .post .card-right {
    top: 0.65rem;
    right: 0.85rem;
    width: auto;
    min-width: 0;
    align-items: flex-end;
  }

  .post .card-right .star-btn,
  .card .card-right .star-btn {
    padding-right: 0 !important;
  }
}

@media (max-width: 480px) {
  .post .card-right {
    right: var(--space-sm);
  }
}

.post .card-right .star-btn {
  margin-left: auto;
}

.card-time {
  font-size: var(--font-size-xs);
  color: var(--meta-muted);
  white-space: nowrap;
}

.post .card-time {
  min-height: 0;
  display: inline-flex;
  align-items: center;
  margin-top: -6px;
}

/* Star button in cards */
.card .star-btn {
  padding: 0.125rem 0.375rem;
  font-size: 0.825rem;
  color: var(--star-star);
  transition:
    color var(--transition-fast);
}

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

.card .star-btn.starred {
  color: var(--star-star-active);
  filter:
    drop-shadow(
      0 0 6px
        color-mix(
          in srgb,
          var(--star-star-active) calc(15% * var(--neon-surface-intensity)),
          transparent
        )
    )
    drop-shadow(
      0 0 18px
        color-mix(
          in srgb,
          var(--star-star-active) calc(4% * var(--neon-surface-intensity)),
          transparent
        )
    );
}

.card .star-btn.starred:hover {
  color: var(--star-star-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;
}

/* Site-level actions (Report / Delete) — hidden by default, shown on hover */
.card-site-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-site-actions-row {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.35rem;
  width: auto;
  max-width: 100%;
}

.discussion-category-editor {
  display: grid;
  grid-template-columns: minmax(4.6rem, auto) minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.42rem;
  width: 100%;
  padding: 0.5rem 0;
}

.discussion-category-editor + .discussion-category-editor {
  border-top: 1px solid
    color-mix(in srgb, var(--accent-primary) 10%, var(--border-secondary) 90%);
}

.discussion-category-editor-label {
  min-width: 0;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
}

.discussion-editor-control {
  box-sizing: border-box;
  width: 6.35rem;
  min-width: 6.35rem;
  max-width: 6.35rem;
  min-height: 1.8rem;
  border: 1px solid
    color-mix(in srgb, var(--accent-primary) 8%, var(--border-secondary) 92%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--bg-input) 96%, var(--accent-primary) 4%);
  color: var(--text-primary);
  font-family: inherit;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  line-height: 1.1;
  padding: 0.28rem 0.62rem;
  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%);
  transition:
    border-color var(--transition-fast),
    background var(--transition-fast),
    box-shadow var(--transition-fast);
}

.moderator-filter-grid select,
.discussion-category-select {
  appearance: none;
  -webkit-appearance: none;
  height: 1.8rem;
  min-height: 1.8rem;
  border-radius: var(--radius-full);
  padding: 0 1.55rem 0 0.7rem;
  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.84rem) 50%,
    calc(100% - 0.56rem) 50%;
  background-size:
    0.32rem 0.32rem,
    0.32rem 0.32rem;
  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-site-status-value {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--bg-secondary) 72%, var(--bg-input) 28%);
  color: var(--text-primary);
  text-align: center;
  width: auto;
  min-width: 0;
  max-width: none;
  justify-self: start;
  padding-inline: 0.68rem;
}

.discussion-editor-control:hover {
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 16%,
    var(--border-secondary) 84%
  );
}

.discussion-editor-control:focus {
  outline: none;
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 24%,
    var(--border-secondary) 76%
  );
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 0 0 3px color-mix(in srgb, var(--focus-ring) 18%, transparent);
}

.discussion-editor-save-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.8rem;
  min-width: 0;
  flex: 0 0 auto;
  width: fit-content;
  padding: 0.26rem 0.68rem;
  white-space: nowrap;
}

.discussion-editor-save-btn.button-secondary {
  color: var(--text-primary);
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 26%,
    var(--border-secondary) 74%
  );
  background: color-mix(in srgb, var(--accent-primary) 12%, transparent 88%);
}

.discussion-editor-save-btn.button-secondary:hover {
  opacity: 1;
  background: color-mix(in srgb, var(--accent-primary) 18%, transparent 82%);
}

.discussion-trending-toggle-btn[aria-pressed="true"] {
  border-color: color-mix(
    in srgb,
    var(--accent-primary) 46%,
    var(--border-secondary) 54%
  );
  background: color-mix(in srgb, var(--accent-primary) 22%, transparent 78%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 0 0 1px color-mix(in srgb, var(--accent-primary) 12%, transparent);
}

.discussion-featured-rank-editor {
  display: grid;
  align-items: center;
}

.discussion-moderator-action-group {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 0.28rem;
}

.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: 100%;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  overflow: visible;
}

.discussion-moderator-dropdown .discussion-category-editor,
.discussion-moderator-dropdown .discussion-featured-rank-editor,
.discussion-moderator-dropdown .discussion-trending-editor {
  width: 100%;
  min-width: 0;
  max-width: none;
}


.discussion-moderator-dropdown .discussion-category-editor-label {
  min-width: 0;
}

.discussion-moderator-dropdown .discussion-editor-control {
  flex: 0 0 auto;
  width: auto;
  max-width: 100%;
}

.discussion-moderator-dropdown .discussion-editor-save-btn {
  min-width: 3.5rem;
  justify-self: start;
}

.discussion-moderator-dropdown .discussion-category-select {
  min-width: 7.25rem;
}

.discussion-moderator-dropdown .discussion-featured-rank-input {
  min-width: 4.1rem;
}

.discussion-moderator-dropdown .delete-site-btn {
  width: auto;
  margin-top: 0.38rem;
  padding-inline: 0;
  border: none;
  background: transparent;
  color: var(--danger-primary);
  box-shadow: none;
}

.discussion-moderator-dropdown .delete-site-btn:hover,
.discussion-moderator-dropdown .delete-site-btn:focus-visible {
  opacity: 0.8;
  background: transparent;
}

.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.8rem;
  min-height: 1.8rem;
  border-radius: var(--radius-full);
  padding: 0 0.62rem;
  line-height: 1.1;
  font-size: var(--font-size-xs);
}

@media (max-width: 520px) {
  .discussion-moderator-dropdown {
    right: -0.25rem;
    width: calc(100vw - 1rem);
    padding: var(--space-md);
  }

  .discussion-category-editor {
    grid-template-columns: 1fr;
  }

  .discussion-moderator-dropdown .discussion-category-select,
  .discussion-moderator-dropdown .discussion-featured-rank-input {
    width: 100% !important;
    min-width: 0;
  }

  .discussion-moderator-action-group,
  .discussion-moderator-dropdown .discussion-editor-save-btn {
    width: 100%;
  }

  .discussion-moderator-action-group > button,
  .discussion-moderator-dropdown .discussion-editor-save-btn {
    justify-content: center;
  }

  .discussion-moderator-dropdown .delete-site-btn {
    width: 100%;
    justify-content: center;
  }
}

.draft-meta-category-control {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 1.5rem;
  color: var(--discussant-site);
}

.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% + 0.5rem);
  left: 0;
  width: fit-content;
  min-width: 0;
  max-width: min(16rem, calc(100vw - 1.5rem));
  max-height: min(18rem, calc(var(--stable-viewport-height) - 8rem));
  overflow-x: hidden;
  overflow-y: scroll;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
  -webkit-overflow-scrolling: touch;
}

.draft-meta-category-menu::-webkit-scrollbar {
  width: 0.25rem;
}

.draft-meta-category-menu::-webkit-scrollbar-track {
  background: transparent;
  margin: 0.5rem 0;
}

.draft-meta-category-menu::-webkit-scrollbar-thumb {
  background: var(--text-secondary);
  border-radius: 0.125rem;
}

/* Firefox */
.draft-meta-category-menu {
  scrollbar-width: thin;
  scrollbar-color: var(--text-secondary) transparent;
}

.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;
  white-space: nowrap;
}

.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%;
}

.draft-meta-refining-slot {
  display: inline-flex;
  align-items: center;
}

.draft-meta-category-refining {
  display: inline-flex;
  align-items: center;
  min-height: 1.5rem;
  padding: 0.08rem 0.15rem;
  color: var(--discussant-site);
  font-size: var(--font-size-sm);
  letter-spacing: 0.01em;
}

.card.card-has-site-actions .card-site-row {
  margin-top: -0.1rem;
}

.card-site-row .card-site-actions {
  margin-right: auto;
}

.card-site-row .card-time-inline {
  margin-left: auto;
  min-height: 1.5rem;
  display: inline-flex;
  align-items: center;
}

.card.card-has-site-actions .card-content {
  justify-content: flex-start;
}

.card.card-has-site-actions .card-meta {
  margin-top: 0.3rem;
  width: calc(100% + var(--post-time-col-width) + var(--space-sm));
  row-gap: 0.1rem;
}

.card.card-has-site-actions .card-title {
  margin-top: 0.3rem;
}

.card.card-has-site-actions .card-right {
  width: var(--post-time-col-width);
  align-self: flex-start;
  padding-top: 0.4rem;
}

.card.card-has-site-actions .star-btn {
  min-height: 1.25rem;
  padding-top: 0;
  padding-bottom: 0;
}

.card.card-has-site-actions .card-meta .card-time-inline {
  margin-left: auto;
  min-height: 1.4rem;
  display: inline-flex;
  align-items: center;
}

.card.card-has-site-actions .card-meta .card-time-inline-spacer {
  flex: 1 1 0.75rem;
  min-width: 0.5rem;
  height: 0;
  pointer-events: none;
}

.card.card-has-site-actions:hover .card-meta .card-post-count,
.card.card-has-site-actions:focus-within .card-meta .card-post-count {
  color: var(--accent-hover);
  opacity: 0.96;
}

.card.card-has-site-actions:hover:has(.card-title:hover)
  .card-meta
  .card-post-count,
.card.card-has-site-actions:hover:has(.card-discussant-btn:hover)
  .card-meta
  .card-post-count,
.card.card-has-site-actions:hover:has(.profile-site:hover)
  .card-meta
  .card-post-count,
.card.card-has-site-actions:focus-within:has(.card-title:focus-visible)
  .card-meta
  .card-post-count,
.card.card-has-site-actions:focus-within:has(.card-discussant-btn:focus-visible)
  .card-meta
  .card-post-count {
  color: var(--discussant-site);
  opacity: 1;
}

.card .card-content > .card-site-actions {
  margin-top: 0.3rem;
  min-height: 1.75rem;
}

.card-site-actions .card-action {
  min-height: 1.5rem;
  padding: 0.14rem 0.35rem 0.08rem;
  line-height: 1.1;
}

.card.card-has-site-actions .card-meta .card-discussant-btn,
.card.card-has-site-actions .card-meta .card-post-count,
.card.card-has-site-actions .card-meta .card-category-label,
.card.card-has-site-actions .card-meta .card-pending-release,
.card.card-has-site-actions .card-meta .card-last-poster,
#site-meta .card-discussant-btn,
#site-meta .card-post-count,
#site-meta .card-category-label,
#site-meta .card-pending-release,
#site-meta .draft-meta-category-trigger {
  min-height: 1.5rem;
  padding-top: 0.08rem;
  padding-bottom: 0.08rem;
}

.card.card-has-site-actions .card-meta .card-discussant-btn--feed {
  min-height: 1.35rem;
  padding: 0.02rem 0.08rem;
}

#site-meta {
  width: 100%;
  flex-wrap: nowrap;
  margin-top: -0.84rem;
}

.discussion-header h1.discussion-title-is-wrapped ~ #site-meta {
  margin-top: 0.24rem;
}

@media (max-width: 768px) {
  #site-meta {
    margin-top: -0.88rem;
  }
}

@media (max-width: 732px) {
  #site-meta {
    flex-wrap: wrap;
  }

  #site-meta .card-meta-time {
    margin-left: 0;
    margin-right: 0;
    flex-basis: 100%;
    order: 99;
    padding-left: 0.25rem;
    padding-top: 0.3rem;
  }
}

#site-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-site-actions,
.card:focus-within .card-site-actions,
.discussion-header:hover .card-site-actions,
.discussion-header:focus-within .card-site-actions {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.discussion-header .card-site-actions {
  width: 100%;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.discussion-header .card-site-actions .card-site-actions-row {
  width: auto;
  max-width: 100%;
}

/* Legacy aliases - keep .site-row working during transition */
.site-row {
  display: flex;
  gap: 0.68rem;
  padding: 0.72rem 0.95rem 0.76rem;
  border-radius: var(--radius-md);
  background: var(--site-row-bg);
  transition: background var(--transition-fast);
  align-items: flex-start;
  cursor: pointer;
  position: relative;
}

.site-row:hover {
  background: var(--bg-secondary);
}

.site-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-site);
  overflow-wrap: break-word;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.profile-stats-row {
  display: flex;
  gap: 0.85rem;
}

/* ============================================================================
   Profile Cover Banner
   ============================================================================ */
.profile-cover {
  position: relative;
  z-index: 0;
  height: 7.5rem;
  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%
  );
}

/* When a cover image is loaded, it overrides the gradient via inline style.
   The gradient remains as a fallback while the image loads. */
.profile-cover.has-image {
  background-color: var(--cover-start);
}

/* 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: 2.75rem;
  pointer-events: none;
}

.profile-card .profile-info > * {
  pointer-events: auto;
}

.profile-card #profile-connect-btn.profile-connect-btn {
  margin-top: 2.75rem;
  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: -42px;
  }

  .profile-card .profile-info {
    padding-top: 30px;
  }

  .profile-card #profile-connect-btn.profile-connect-btn {
    margin: var(--space-sm) auto 0 0;
    order: 10;
    padding: 0.34rem 0.78rem;
    font-size: 0.8rem;
  }

  .profile-bio.has-bio {
    text-align: left;
  }

  .profile-header {
    padding: var(--space-md) var(--space-md) var(--space-md) 0.5rem;
    gap: var(--space-sm);
  }

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

  .profile-card .profile-avatar-wrap {
    margin-left: 0;
  }

  .profile-header .profile-name {
    font-size: 1.15rem;
  }

  .profile-stats-row {
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-sm);
  }

  .profile-bio {
    text-align: center;
  }

  .profile-activity-section {
    padding: var(--space-md) 0.25rem;
  }

  /* Card mobile styles */
  .card {
    padding: var(--space-sm);
    gap: var(--space-sm);
  }

  .card-title {
    font-size: var(--font-size-sm);
  }

  #sites-list .card-title {
    font-size: var(--font-size-base);
  }

  .card-actions {
    margin-left: var(--space-xs);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .profile-section {
    padding: var(--space-sm) 0.25rem;
  }

  .profile-section-title {
    font-size: var(--font-size-xs);
  }
}

/* ============================================================================
   Mobile Layout Hardening
   ============================================================================ */
@media (max-width: 768px) {
  .top-bar,
  .static-panel,
  .static-card,
  .settings-card,
  .profile-card,
  .legal-content,
  .site-footer,
  .command-console-content,
  .auth-modal-content,
  .avatar-picker-content,
  .discussants-modal-content,
  .confirm-modal-content,
  .terms-gate-content,
  .birthday-gate-content {
    box-sizing: border-box;
    max-width: 100%;
    min-width: 0;
  }

  .main-nav,
  .account-wrap,
  .nav-segment-shell,
  .master-filter-wrap,
  .sort-controls,
  .discussion-header,
  .profile-header,
  .profile-header .profile-info,
  .settings-section,
  .settings-keybinding-item,
  .confirm-modal-actions {
    min-width: 0;
  }

  .feed-card,
  .discussion-card,
  .profile-section,
  .card,
  .site-row,
  .post {
    min-width: 0;
  }

  .command-console-modal,
  .auth-modal,
  .avatar-picker-modal,
  .discussants-modal,
  .confirm-modal,
  .terms-gate-modal,
  .birthday-gate-modal {
    box-sizing: border-box;
    align-items: flex-start;
    justify-content: center;
    overflow-x: hidden;
    overflow-y: auto;
    padding: max(var(--space-md), env(safe-area-inset-top, 0px))
      max(var(--space-md), env(safe-area-inset-right, 0px))
      calc(
        max(var(--space-md), env(safe-area-inset-bottom, 0px)) +
          var(--keyboard-inset-bottom)
      )
      max(var(--space-md), env(safe-area-inset-left, 0px));
    scroll-padding-block: max(var(--space-md), env(safe-area-inset-top, 0px))
      calc(
        max(var(--space-lg), env(safe-area-inset-bottom, 0px)) +
          var(--keyboard-inset-bottom)
      );
  }

  #command-console-modal {
    align-items: flex-start;
    padding-top: max(
      calc(var(--stable-vh) * 15),
      calc(env(safe-area-inset-top, 0px) + 3rem)
    );
  }

  .command-console-hint {
    display: none;
  }

  .command-console-content,
  .auth-modal-content,
  .avatar-picker-content,
  .discussants-modal-content,
  .confirm-modal-content,
  .terms-gate-content,
  .birthday-gate-content {
    max-height: calc(var(--keyboard-safe-viewport-height) - 2rem);
    overflow-y: auto;
    scroll-padding-block: var(--space-md)
      calc(var(--space-lg) + var(--keyboard-inset-bottom));
  }

  .discussants-modal-content {
    margin-top: 0;
  }

  .analytics-consent-banner {
    padding: var(--space-md)
      max(var(--space-md), env(safe-area-inset-right, 0px))
      calc(var(--space-md) + env(safe-area-inset-bottom, 0px))
      max(var(--space-md), env(safe-area-inset-left, 0px));
  }

  .analytics-consent-card {
    padding: var(--space-sm);
  }

  .analytics-consent-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .analytics-consent-link {
    align-self: flex-end;
    text-align: right;
  }
}

@media (max-width: 480px) {
  .top-bar {
    grid-template-columns: minmax(0, auto) minmax(0, 1fr) auto;
    padding-inline: 0.75rem;
  }

  .main-nav,
  .account-wrap {
    min-width: 0;
  }

  #account-nav-btn {
    max-width: 6.5rem;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .top-bar-settings-wrap {
    --floating-settings-corner-gap: 0.45rem;
    --floating-settings-corner-nudge: 0px;
    --floating-settings-control-size: var(--nav-hit-target);
  }

  .notifications-wrap {
    position: static;
  }

  .notifications-dropdown {
    left: 0.75rem;
    right: 0.75rem;
    width: auto;
    max-width: none;
  }

  .notifications-header {
    flex-wrap: wrap;
  }

  .notification-context {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }

  .sort-controls.feed-sort-filter {
    width: 100%;
  }

  .feed-sort-filter .feed-sort-group {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    touch-action: pan-x;
  }

  .feed-sort-filter .sort-btn[data-sort] {
    flex: 0 0 auto;
  }

  .card.card-has-site-actions .card-meta .card-time-inline-spacer {
    display: none;
  }

  .card.card-has-site-actions .card-meta .card-time-inline {
    flex: 0 0 100%;
    margin-left: 0.15rem;
    justify-content: flex-start;
  }

  .card.card-has-site-actions .card-meta .card-meta-item-last-poster {
    margin-left: 0;
  }

  .feed-master-filter-inline-search.is-search-active
    .feed-search-bar
    input.feed-search-input {
    width: clamp(6rem, 38vw, 8.5rem);
  }

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

  .discussion-header {
    gap: 0.15rem;
  }

  .discussion-header-controls {
    position: static;
    align-self: flex-end;
    margin-top: 0.25rem;
    margin-bottom: -0.25rem;
  }

  .discussion-back-row {
    min-width: 0;
    flex-wrap: wrap;
    padding-right: 0;
  }

  .discussion-header {
    padding-bottom: var(--space-xs);
    margin-bottom: 0.35rem;
  }

  .discussion-header h1 {
    flex-wrap: nowrap;
  }

  .discussion-header h1 .star-btn {
    top: -4px;
  }

  .discussion-header .card-site-actions {
    margin-top: -0.15rem;
  }

  #site-meta {
    flex-wrap: wrap;
    row-gap: 0;
    margin-top: -0.88rem;
  }

  .discussion-header h1.discussion-title-is-wrapped ~ #site-meta {
    margin-top: 0.24rem;
  }

  #site-meta .card-discussant-btn,
  #site-meta .card-post-count,
  #site-meta .card-category-label,
  #site-meta .card-pending-release,
  #site-meta .draft-meta-category-trigger {
    min-height: 1rem;
    padding-top: 0;
    padding-bottom: 0;
  }

  #site-meta .card-meta-time {
    margin-left: 0;
    margin-right: 0;
    flex-basis: 100%;
    order: 99;
    padding-left: 0.25rem;
    min-height: auto;
    padding-top: 0.3rem;
    padding-bottom: 0;
  }

  .discussion-header .card-site-actions .card-site-actions-row {
    width: 100%;
  }

  #post-form {
    --post-body-width: min(80%, 31rem);
  }

  #post-form > .post-form-footer > .form-actions {
    margin-top: calc(var(--space-sm) - var(--post-form-stack-gap));
  }

  #post-form > .post-form-footer > #post-char-counter {
    white-space: nowrap;
  }

  #post-form .form-actions #post-submit-btn:not(.load-more-btn) {
    width: 100%;
    min-width: 0;
  }

  .replying-to {
    flex-wrap: wrap;
    row-gap: var(--space-xs);
    padding: 0.5rem var(--space-sm);
  }

  .replying-to-copy {
    white-space: normal;
  }

  .replying-to .ghost-btn {
    margin-left: 0;
  }

  .settings-tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .settings-tabs::-webkit-scrollbar {
    display: none;
  }

  .settings-title,
  .settings-section {
    padding-left: var(--space-md);
    padding-right: var(--space-md);
  }

  .settings-section .input,
  #settings-tab-account .input,
  #settings-tab-account .settings-password-fields {
    max-width: none;
  }

  #settings-tab-account .button-primary,
  #settings-tab-account .button-secondary,
  #settings-tab-account .button-danger,
  #settings-edit-keybindings-btn {
    width: 100%;
    justify-content: center;
  }

  #settings-tab-account .settings-action-card .button-primary,
  #settings-tab-account .settings-action-card .button-secondary,
  #settings-tab-account .settings-action-card .button-danger,
  #settings-tab-account .settings-account-controls > .button-primary,
  #settings-tab-account .settings-account-controls > .button-secondary,
  #settings-tab-account .settings-account-controls > .button-danger {
    width: 100%;
    min-width: 0;
    align-self: stretch;
  }

  .settings-action-row {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }

  .settings-account-controls {
    width: 100%;
    justify-self: stretch;
  }

  .settings-block-control {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }

  .moderator-filter-actions .moderator-pill-btn {
    width: 100%;
  }

  .confirm-modal-actions {
    flex-wrap: wrap;
    justify-content: stretch;
  }

  .confirm-modal-actions button {
    flex: 1 1 100%;
    min-width: 0;
  }

  #delete-account-modal .confirm-modal-actions button,
  #disable-2fa-modal .confirm-modal-actions button,
  #settings-action-2fa-modal .confirm-modal-actions button {
    white-space: normal;
  }

  .auth-tabs,
  .waitlist-back-row {
    flex-wrap: wrap;
  }

  .auth-modal-content {
    max-width: none;
  }

  .checkbox-label {
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
    white-space: normal;
  }

  body[data-route="site"] .static-card {
    padding-top: 0;
  }

  .discussion-header-controls {
    margin-top: 0.35rem;
    transform: translateY(0.5rem);
  }

  .discussion-header .card-site-actions {
    margin-top: 0.15rem;
  }

  .command-console-content {
    max-width: 415px;
  }

  #post-form.is-login-prompt {
    margin-top: 0.5rem;
  }

}

@media (max-width: 360px) {
  :root {
    --panel-inline-padding: 0.35rem;
  }

  .top-bar {
    gap: 0.35rem;
    padding-inline: 0.55rem;
  }

  .nav-control-btn {
    padding: 0.22rem 0.48rem;
  }

  #account-nav-btn {
    max-width: 5.75rem;
  }

  .feed-master-filter-inline-search.is-search-active
    .feed-search-bar
    input.feed-search-input {
    width: clamp(5.25rem, 34vw, 6.75rem);
  }

  .feed-master-filter-inline-search.is-search-focused
    .feed-search-bar
    input.feed-search-input {
    width: clamp(6rem, 40vw, 7.5rem);
  }

  .site-row {
    padding: 0.6rem 2.2rem 0.6rem 0.7rem;
  }

  .site-meta-actions {
    width: 100%;
    flex-wrap: wrap;
    padding-left: 0;
  }

  .card-title,
  .card-preview,
  .profile-activity-post .card-title,
  .notification-context {
    width: 100%;
    max-width: 100%;
    white-space: normal;
  }

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

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

  .profile-header {
    padding-left: var(--space-sm);
    padding-right: var(--space-sm);
  }

  .profile-item .meta {
    white-space: normal;
  }
}

/* ─────────────────────────────────────────────────────────────────────────
   View Transitions API — speed up the default root cross-fade between
   route views from ~250ms (browser default) to 150ms so navigation
   feels snappy instead of sluggish. Browsers without View Transitions
   support (Firefox, older Safari) ignore these selectors gracefully.
   ───────────────────────────────────────────────────────────────────────── */
::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 150ms;
}
