/* gazeta styles */

:root {
  --font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
  --primary: #1e3a8a;
  --accent: #2f4aa6;
  --accent-dark: #223b85;
  --teal: #2563eb;
  --green: #60a5fa;
  --purple: #4338ca;
  --violet: #a5b4fc;
  --amethyst: #6a4fa3;
  --amethyst-dark: #553f83;
  --list-vote-up-color: #2c8b6e;
  --list-vote-up-stale-color: color-mix(in srgb, var(--list-vote-up-color) 56%, var(--muted-text, #64748b) 44%);
  --list-vote-down-color: var(--accent);
  --list-vote-down-stale-color: color-mix(in srgb, var(--list-vote-down-color) 56%, var(--muted-text, #64748b) 44%);
  --list-vote-idle-color: #c9ced8;
  --text: #0b132b;
  --light-text: #475569;
  --heading-color: var(--text);
  --heading-gradient: none;
  --heading-fill: var(--heading-color);
  --heading-glow: none;
  --border: #c7d2fe;
  --bg: #d9dde6;
  --light-bg: #e0e7ff;
  --code-bg: #e2e8f0;
  --shadow: rgba(30, 58, 138, 0.14);
  --nav-link-hover: #e0e7ff;
  --nav-link-active: #f59e0b;
  --nav-icon: #f59e0b;
  --nav-button-bg: var(--light-bg);
  --nav-button-bg-dark: var(--light-bg);
  --select-bg: var(--bg);
  --select-text: var(--text);
  --select-border: var(--border);
  --select-option-bg: var(--select-bg);
  --select-option-text: var(--select-text);
  --select-option-disabled-text: var(--light-text);
  --select-option-selected-bg: var(--accent);
  --select-option-selected-text: #fff;
  --select-color-scheme: light;
  --accent-hover-end: #1d4ed8;
  --button-primary-start: #c56b28;
  --button-primary-end: #9a4e1d;
  --button-primary-hover-start: #ad551f;
  --button-primary-hover-end: #7f3f17;
  --button-primary-active-start: #b25d22;
  --button-primary-active-end: #8b451a;
  --button-primary-text: var(--nav-active-text, #fff);
  --button-primary-border: color-mix(in srgb, var(--button-primary-end) 70%, var(--border) 30%);
  --button-primary-overlay: none;
  --nav-search-icon: var(--nav-icon);
  --nav-search-icon-hover: var(--nav-icon-hover);
  --nav-username-color: var(--text);
  --nav-username-hover: var(--accent);
  --nav-button-hover-bg: var(--nav-button-bg);
  --nav-button-hover-bg-dark: var(--nav-button-bg-dark);
  --nav-button-hover-border: #ccfbf1;
  --nav-pill-radius: 8px;
  --nav-signature-color: color-mix(in srgb, var(--text) 62%, var(--bg) 38%);
  --nav-icon-hover: var(--nav-icon);
  --nav-bg: var(--bg);
  --nav-border: var(--border);
  --post-card-bg: #fbfbf7;
  --post-card-bg-single: #fdfdfb;
  --post-card-shell-bg: var(--post-card-bg);
  --post-body-bg: var(--post-card-bg-single);
  --secure-chat-paper-texture: var(--lapidarist-parchment-texture, url("/static/textures/lapidarist-parchment.webp"));
  --secure-chat-paper-surface: var(
    --lapidarist-parchment-surface,
    radial-gradient(900px 360px at 18% 6%, rgba(255, 250, 236, 0.72) 0%, rgba(255, 250, 236, 0) 62%),
    linear-gradient(180deg, rgba(255, 249, 235, 0.86) 0%, rgba(239, 224, 193, 0.78) 100%),
    var(--secure-chat-paper-texture)
  );
  --secure-chat-paper-muted: var(
    --lapidarist-parchment-muted,
    radial-gradient(640px 260px at 18% 4%, rgba(255, 249, 232, 0.56) 0%, rgba(255, 249, 232, 0) 64%),
    linear-gradient(180deg, rgba(249, 239, 219, 0.84) 0%, rgba(231, 214, 180, 0.72) 100%),
    var(--secure-chat-paper-texture)
  );
  --danger: #b42318;
  --danger-soft: rgba(180, 35, 24, 0.14);
  --danger-soft-strong: rgba(180, 35, 24, 0.2);
  --status-error-bg: #641925;
  --status-error-border: #96394d;
  --status-error-text: #f6f8ff;
  --status-warn-bg: #5a4516;
  --status-warn-border: #8a6a24;
  --status-warn-text: #f6f8ff;
  --save-error-text: #b43535;
  --focus-ring: rgba(91, 126, 216, 0.2);
  --focus-ring-strong: #5b7ed8;
  --spinner-track: rgba(49, 103, 189, 0.2);
  --spinner-head: #3167bd;
  --nav-active-text: #fff;
  --nav-compose-icon: #000;
  --nav-compose-name: var(--muted-text, #5f6f92);
  --nav-compose-cycle: var(--muted-text, #5f6f92);
  --nav-compose-cycle-hover-text: var(--text);
  --site-content-width: 46rem;
  --feed-rss-start: #f8a31f;
  --feed-rss-end: #ea6b0f;
  --feed-rss-border: #de7f15;
  --feed-atom-start: #4f73d9;
  --feed-atom-end: #2e4fae;
  --feed-atom-border: #3d60bf;
  --admin-bg: var(--bg);
  --admin-surface: var(--post-card-bg-single);
  --admin-surface-alt: var(--post-card-bg);
  --admin-border: var(--border);
  --admin-text: var(--text);
  --admin-muted: var(--light-text);
  --admin-accent: var(--accent);
  --admin-accent-strong: var(--accent-dark);
  --admin-hover: var(--nav-link-hover);
  --admin-danger: var(--danger);
  --surface-raised: #fff;
  --surface-raised-strong: #fff;
  --surface-muted: var(--light-bg);
  --surface-overlay: rgba(15, 23, 42, 0.72);
  --menu-bg: var(--surface-raised);
  --menu-border: var(--border);
  --menu-shadow: 0 12px 28px rgba(15, 23, 42, 0.16);
  --popup-menu-shadow:
    0 18px 44px rgba(15, 23, 42, 0.18),
    0 2px 8px rgba(15, 23, 42, 0.08);
  --menu-hover-bg: var(--light-bg);
  --menu-danger-text: var(--danger);
  --menu-danger-hover-bg: var(--danger-soft);
  --status-ok-bg: #ebfcf2;
  --status-ok-border: #9ad5b0;
  --status-ok-text: #14532d;
  --toast-info-bg: #eef4ff;
  --toast-info-border: #cdd9f1;
  --toast-info-text: var(--text);
  --modal-bg: #f8fbff;
  --modal-shadow: 0 22px 50px rgba(15, 23, 42, 0.3);
  --tag-bg: #e8eeff;
  --tag-border: #c8d4f3;
  --tag-text: var(--accent);
  --tag-muted-bg: #f6f8ff;
  --tag-muted-border: #e2e8f8;
  --tag-muted-text: #6f7fae;
  --tag-muted-hover-bg: #edf2ff;
  --tag-muted-hover-text: #5f709f;
  --post-tag-standard-bg: #f3e4bf;
  --post-tag-standard-border: #ddc486;
  --post-tag-standard-text: #6b4b12;
  --post-tag-type-bg: #dff4d7;
  --post-tag-type-border: #a9d89b;
  --post-tag-type-text: #285f28;
  --post-tag-year-bg: #dcecff;
  --post-tag-year-border: #a8c8f0;
  --post-tag-year-text: #245a93;
  --action-soft-bg: #f5e4d7;
  --action-soft-border: #c58f6f;
  --action-soft-text: #6d3a20;
  --action-soft-hover-bg: #f0d7c5;
  --action-soft-hover-border: #b77753;
  --action-soft-hover-text: #5b2f18;
  --action-soft-active-bg: #e8c9b3;
  --action-soft-active-border: #a86442;
  --action-soft-active-text: #4d2614;
  --page-canvas-bg:
    radial-gradient(1200px 600px at 20% -10%, rgba(255,255,255,0.45) 0%, rgba(255,255,255,0) 55%),
    var(--bg);
}


* {
  box-sizing: border-box;
}

html {
  /* Keep layout width stable across pages with/without vertical scrollbars. */
  scrollbar-gutter: stable;
  overflow-x: hidden;
  background: var(--page-canvas-bg);
  background-attachment: fixed;
}

@supports (overflow: clip) {
  html {
    overflow-x: clip;
  }
}

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

@supports not (scrollbar-gutter: stable) {
  html {
    overflow-y: scroll;
  }
}

html.theme-switching *,
html.theme-switching *::before,
html.theme-switching *::after,
body.theme-switching *,
body.theme-switching *::before,
body.theme-switching *::after {
  transition: none !important;
  animation: none !important;
}

/* Keep nav visible during hydration so route changes do not flash it out. */
html.app-hydrating nav.site-nav,
html.app-hydrating .skip-link,
html.app-hydrating #nav-top-toast-host {
  visibility: visible;
}

.route-load-failure {
  margin: 1.1rem 0 0.95rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-raised-strong, #fff);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.07);
}

.route-load-failure h1 {
  margin: 0;
  font-size: 1.25rem;
}

.route-load-failure p {
  margin: 0.35rem 0 0;
  color: var(--light-text);
}

body {
  font-family: var(--font-family);
  max-width: var(--site-content-width);
  margin: 0 auto;
  padding: 0 2rem 2rem 2rem;
  display: flex;
  flex-direction: column;
  line-height: 1.7;
  color: var(--text);
  background: var(--page-canvas-bg);
  background-attachment: fixed;
  min-height: 100vh;
}

/* Blog index and single-post routes get a wider reading canvas. */
body:has(#blog-page-root),
body:has(.post-single-item),
body:has(.post-list > .post-item) {
  max-width: 800px;
}

body.blog-post-resize-enabled {
  max-width: min(1820px, calc(100vw - 0.75rem));
}

/* Keep blog-listing canvas uniform without painting a second centered body panel. */
html:has(#blog-page-root) {
  background: var(--page-canvas-bg) !important;
  background-size: var(--page-canvas-bg-size, auto) !important;
  background-position: var(--page-canvas-bg-position, center) !important;
  background-attachment: fixed;
}

body:has(#blog-page-root) {
  background: transparent !important;
  background-image: none !important;
}

body.list-page-width-anim {
  transition: max-width 420ms cubic-bezier(0.22, 1, 0.36, 1);
}

body.list-page-width-anim.list-page-wide {
  max-width: min(1820px, calc(100vw - 0.75rem));
  margin-left: auto;
  margin-right: auto;
}

a[href],
button,
input[type="button"],
input[type="submit"],
input[type="reset"],
[role="button"],
summary,
.tag,
.feed-link,
.footer-feed-link,
.btn-login {
  cursor: pointer;
}

button:disabled,
input:disabled,
select:disabled,
[aria-disabled="true"] {
  cursor: default;
}

body > h1:first-of-type {
  margin-top: 3rem;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--heading-color);
  background: var(--heading-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: var(--heading-fill);
  text-shadow: var(--heading-glow);
}

/* Header & Navigation */
/* Hide Pandoc's title-block-header (causes duplicate titles) */
header#title-block-header {
  display: none;
}

header {
  border-bottom: 2px solid var(--border);
  padding-bottom: 1rem;
  margin-bottom: 2rem;
}

header h1 {
  margin: 0;
  font-size: 2rem;
  color: var(--heading-color);
}

/* Site Navigation */
.site-nav {
  --nav-pill-font-size: 0.9rem;
  --nav-pill-line-height: 1.15;
  --nav-pill-pad-y: 0.36rem;
  --nav-pill-pad-x: 0.92rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 2rem;
  background: var(--nav-bg, var(--bg));
  border-top: 1px solid var(--nav-border, var(--border));
  border-bottom: 1px solid var(--nav-border, var(--border));
  margin-bottom: 0;
  position: relative;
  top: auto;
  z-index: 100;
  width: 100%;
  margin-left: 0;
}

.nav-site-signature {
  flex: 0 0 auto;
  color: var(--nav-signature-color);
  font-family: "Palatino Linotype", "Book Antiqua", Palatino, "Times New Roman", serif;
  font-size: 1.03rem;
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: 0.01em;
  white-space: nowrap;
  margin-left: 0.68rem;
  margin-right: 0.35rem;
  user-select: none;
  pointer-events: auto;
  cursor: pointer;
  text-decoration: none;
  background: transparent !important;
  transform: translateY(1px);
  min-width: max-content;
}

nav.site-nav .nav-site-signature {
  font-family: "Palatino Linotype", "Book Antiqua", Palatino, "Times New Roman", serif;
}

.nav-site-signature:link,
.nav-site-signature:visited,
.nav-site-signature:active {
  color: var(--nav-signature-color) !important;
}

.nav-site-signature:hover,
.nav-site-signature:focus-visible {
  color: var(--nav-signature-color) !important;
  text-decoration: underline;
  background: transparent !important;
}

.nav-center {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  flex: 1;
  justify-content: center;
}

.nav-center a {
  color: var(--text);
  text-decoration: none;
  font-weight: 600;
  font-size: var(--nav-pill-font-size);
  padding: var(--nav-pill-pad-y) var(--nav-pill-pad-x);
  line-height: var(--nav-pill-line-height);
  border-radius: var(--nav-pill-radius);
  transition: background-color 0.2s ease, color 0.2s ease;
  cursor: pointer;
}

.nav-center a:hover {
  background-color: transparent;
  color: var(--text);
  text-decoration: underline;
  border-radius: var(--nav-pill-radius);
}

.nav-center a.active,
.nav-username.active {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  color: var(--nav-active-text);
  font-weight: 700;
  cursor: default;
  border-radius: var(--nav-pill-radius);
  pointer-events: none;
}

.nav-center a.active.allow-active-click {
  pointer-events: auto;
  cursor: pointer;
  background: transparent !important;
  background-image: none !important;
  color: var(--text) !important;
  text-decoration: none !important;
  font-weight: 600;
}

.nav-center a.active.allow-active-click:hover,
.nav-center a.active.allow-active-click:focus-visible {
  background: transparent !important;
  background-image: none !important;
  color: var(--text) !important;
  text-decoration: underline !important;
}

.nav-center a.active:hover,
.nav-center a.active:focus-visible,
.nav-username.active:hover,
.nav-username.active:focus-visible {
  text-decoration: none;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  color: var(--nav-active-text);
}

.nav-right {
  display: flex;
  gap: 0.75rem;
  align-items: center;
}

@media (max-width: 900px) {
  .nav-site-signature {
    display: inline-flex;
    font-size: 0.94rem;
    margin-left: 0.2rem;
    margin-right: 0.15rem;
  }
}

.nav-feeds {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.feed-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  text-decoration: none;
  border: 1px solid var(--border);
  transition: transform 0.15s ease, filter 0.2s ease;
}

.feed-link:hover {
  transform: translateY(-1px);
  text-decoration: none;
  filter: brightness(1.05);
}

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

.feed-rss {
  color: var(--nav-active-text);
  background: linear-gradient(140deg, var(--feed-rss-start) 0%, var(--feed-rss-end) 100%);
  border-color: var(--feed-rss-border);
}

.feed-atom {
  color: var(--nav-active-text);
  background: linear-gradient(140deg, var(--feed-atom-start) 0%, var(--feed-atom-end) 100%);
  border-color: var(--feed-atom-border);
}

/* Search box in nav */
.nav-search {
  display: flex;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  transition: transform 0.3s ease, margin-left 0.3s ease, margin-right 0.3s ease;
}

.nav-search input[type="text"] {
  height: 2.25rem;
  padding: 0.24rem 0.8rem 0 0.8rem;
  border: 1px solid var(--border);
  border-radius: 20px 0 0 20px;
  font-size: 0.9rem;
  line-height: 1.15;
  width: 180px;
  outline: none;
  border-right: none;
}

.nav-search input[type="text"]::placeholder {
  line-height: 1.15;
  position: static;
}

.nav-search input[type="text"]:focus {
  border-color: var(--accent);
}

.nav-search button {
  height: 2.25rem;
  padding: 0 1rem;
  background: linear-gradient(135deg, var(--nav-button-bg) 0%, var(--nav-button-bg-dark) 100%);
  color: var(--nav-search-icon);
  border: 1px solid var(--border);
  border-left: 1px solid var(--nav-border, var(--border));
  border-radius: 0 20px 20px 0;
  font-size: 0.9rem;
  cursor: pointer;
  font-weight: 600;
  transition: border-color 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
}

.nav-search button:hover {
  background: linear-gradient(
    135deg,
    var(--nav-button-hover-bg) 0%,
    var(--nav-button-hover-bg-dark) 100%
  );
  color: var(--nav-search-icon-hover);
  border-color: var(--nav-button-hover-border);
}

.nav-compose {
  color: var(--text);
  text-decoration: none;
  font-weight: 500;
  font-size: 0.9rem;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.3s ease;
}

.nav-compose-tools {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.03rem;
  align-self: center;
}

.nav-compose-row {
  display: inline-flex;
  align-items: center;
  gap: 0.22rem;
}

.nav-compose-name {
  display: inline-block;
  font-size: 0.56rem;
  line-height: 1.1;
  color: var(--nav-compose-name);
  max-width: 4.1rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding-left: 0.18rem;
  letter-spacing: 0.01em;
}

.nav-compose-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.55rem;
  height: 2.25rem;
  padding: 0 0.04rem 0 0.18rem;
  border-radius: 9px;
  color: var(--nav-compose-icon);
  align-self: center;
}

.nav-compose-icon svg {
  width: 21px;
  height: 21px;
  transform: translateY(-1px);
}

.nav-compose-icon img {
  width: 21px;
  height: 21px;
  object-fit: contain;
  transform: translateY(-1px);
  filter: none;
}

.nav-compose-icon:hover,
.nav-compose-icon.active {
  color: var(--nav-compose-icon);
}

.nav-compose-cycle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.55rem;
  height: 2.25rem;
  padding: 0;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: var(--nav-compose-cycle);
  font-size: 0.88rem;
  line-height: 1;
  cursor: pointer;
}

.nav-compose-cycle:hover {
  background: var(--light-bg);
  color: var(--nav-compose-cycle-hover-text);
}

.nav-compose:hover {
  background-color: var(--light-bg);
  color: var(--accent);
  text-decoration: none;
}

.nav-compose.active {
  background-color: var(--nav-link-hover);
  color: var(--accent);
  cursor: default;
  pointer-events: none;
}

.nav-cart-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.34rem;
  border: 1px solid var(--border);
  background: var(--surface-raised, #fff);
  color: var(--text);
  border-radius: 999px;
  padding: 0.3rem 0.58rem;
  line-height: 1;
  cursor: pointer;
}

.nav-cart-toggle:hover,
.nav-cart-toggle:focus-visible {
  border-color: var(--accent);
  color: var(--accent);
}

.nav-cart-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.15rem;
  height: 1.15rem;
  border-radius: 999px;
  background: var(--accent, #2f4aa6);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0 0.22rem;
}

:root {
  --nav-cart-drawer-width: min(420px, calc(100vw - 1.1rem));
}

body.nav-cart-open {
  overflow: hidden;
}

.nav-cart-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: var(--nav-cart-drawer-width);
  height: 100vh;
  background: var(--surface-raised, #fff);
  border-left: 1px solid var(--border);
  box-shadow: -16px 0 36px rgba(15, 23, 42, 0.22);
  z-index: 1400;
  display: flex;
  flex-direction: column;
  padding: 0.95rem 0.95rem 0.8rem;
  overflow: hidden;
}

#nav-cart-drawer[hidden] {
  display: none !important;
}

.nav-cart-drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.58rem;
}

.nav-cart-drawer-head h2 {
  margin: 0;
  font-size: 1rem;
  line-height: 1.2;
}

#nav-cart-close {
  border: 1px solid var(--border);
  background: var(--surface-muted, #f3f5fb);
  color: var(--text);
  border-radius: 9px;
  line-height: 1;
  min-width: 2rem;
  height: 2rem;
  cursor: pointer;
}

.nav-cart-empty {
  margin: 0.5rem 0 0.8rem;
  color: var(--light-text);
  font-size: 0.92rem;
}

.nav-cart-items {
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.nav-cart-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.62rem;
  padding: 0.58rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--post-card-bg-single, #fdfdfb);
}

.nav-cart-item-media {
  width: 56px;
  height: 56px;
  border-radius: 8px;
  background: var(--surface-muted, #eef2f9);
  overflow: hidden;
}

.nav-cart-item-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.nav-cart-item-main {
  display: flex;
  flex-direction: column;
  gap: 0.34rem;
}

.nav-cart-item-title {
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  line-height: 1.2;
}

.nav-cart-item-title:hover,
.nav-cart-item-title:focus-visible {
  text-decoration: underline;
}

.nav-cart-item-price {
  font-size: 0.84rem;
  color: var(--text);
}

.nav-cart-item-crypto {
  color: var(--light-text);
}

.nav-cart-item-actions {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.3rem;
}

.nav-cart-item-actions button {
  min-height: 1.8rem;
  padding: 0.15rem 0.54rem;
  border-radius: 7px;
  font-size: 0.8rem;
}

.nav-cart-item-qty {
  font-size: 0.8rem;
  color: var(--light-text);
  padding: 0 0.1rem;
}

.nav-cart-drawer-footer {
  border-top: 1px solid var(--border);
  padding-top: 0.62rem;
  margin-top: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.nav-cart-subtotal-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
}

.nav-cart-subtotal-crypto {
  color: var(--light-text);
  font-weight: 500;
}

.nav-cart-drawer-links {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.38rem;
}

.nav-cart-link-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.36rem 0.64rem;
  text-decoration: none;
  color: var(--text);
  background: var(--surface-raised, #fff);
  font-weight: 600;
  font-size: 0.86rem;
}

.nav-cart-link-button:hover,
.nav-cart-link-button:focus-visible {
  text-decoration: none;
  border-color: var(--accent);
}

.nav-cart-link-button-primary {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  border-color: color-mix(in srgb, var(--accent-dark) 70%, var(--border) 30%);
  color: var(--nav-active-text, #fff);
}

@media (max-width: 720px) {
  :root {
    --nav-cart-drawer-width: 100vw;
  }

  .nav-cart-drawer {
    width: 100vw;
    max-width: 100vw;
    border-left: 0;
  }
}

.checkout-shell {
  width: 100%;
  max-width: 100%;
  margin: 1.2rem auto 2.2rem;
  border: 1px solid #afbdd8;
  border-radius: 12px;
  background: var(--post-card-bg-single, #fdfdfb);
  box-shadow:
    0 18px 36px rgba(15, 23, 42, 0.09),
    0 1px 0 rgba(255, 255, 255, 0.82) inset;
  padding: 1rem 1.08rem 1.12rem;
}

.checkout-head h1 {
  margin: 0;
  font-size: 1.55rem;
  line-height: 1.2;
}

.checkout-head p {
  margin: 0.35rem 0 0;
  color: var(--light-text);
}

.checkout-page-content {
  margin-top: 0.85rem;
}

.checkout-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(280px, 1.2fr);
  gap: 0.9rem;
  align-items: start;
}

.checkout-column {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-raised, #fff);
  padding: 0.7rem 0.76rem;
}

.checkout-column h2 {
  margin: 0 0 0.5rem;
  font-size: 1rem;
}

.checkout-item-list,
.cart-page-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.checkout-item-row,
.cart-page-row {
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--post-card-bg-single, #fdfdfb);
  padding: 0.5rem 0.56rem;
}

.checkout-item-row {
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  align-items: center;
}

.checkout-item-title {
  font-size: 0.9rem;
}

.checkout-item-price {
  font-size: 0.86rem;
  color: var(--light-text);
}

.checkout-totals {
  display: flex;
  flex-direction: column;
  gap: 0.38rem;
  margin-top: 0.65rem;
}

.checkout-totals > div {
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  align-items: baseline;
}

.checkout-radio-group,
.checkout-provider-group {
  border: 1px solid var(--border);
  border-radius: 8px;
  margin: 0.45rem 0 0;
  padding: 0.42rem 0.55rem 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.36rem;
}

.checkout-radio-group legend,
.checkout-provider-group legend {
  font-size: 0.82rem;
  color: var(--light-text);
  padding: 0 0.15rem;
}

.checkout-radio-group label,
.checkout-provider-group label {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.9rem;
}

.checkout-choice-grid {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.42rem;
}

.checkout-choice {
  display: inline-flex !important;
  align-items: center;
  gap: 0.36rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 0.22rem 0.58rem;
  background: var(--surface-raised, #fff);
  color: var(--text);
  font-size: 0.86rem !important;
  line-height: 1.2;
  cursor: pointer;
  user-select: none;
}

.checkout-choice input[type="radio"] {
  margin: 0;
}

.checkout-choice.is-selected {
  border-color: color-mix(in srgb, var(--accent, #2f4aa6) 55%, var(--border, #c8d4f3) 45%);
  background: color-mix(in srgb, var(--accent, #2f4aa6) 12%, #fff 88%);
  color: color-mix(in srgb, var(--accent-dark, #223b85) 84%, #17253f 16%);
  font-weight: 600;
}

.checkout-actions {
  margin-top: 0.62rem;
}

.checkout-provider-shell {
  margin-top: 0.66rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  min-height: 260px;
  background: var(--surface-muted, #eef2f9);
  overflow: hidden;
}

.checkout-provider-embed {
  width: 100%;
  min-height: 320px;
  border: 0;
  background: #fff;
}

.checkout-provider-placeholder {
  margin: 0;
  padding: 0.72rem;
  color: var(--light-text);
  font-size: 0.9rem;
}

.checkout-btcpay-handoff {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.55rem;
}

.checkout-btcpay-handoff p {
  margin: 0;
}

.checkout-message {
  margin: 0.3rem 0 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.4rem 0.5rem;
  font-size: 0.87rem;
}

.checkout-message.is-ok {
  border-color: var(--status-ok-border);
  color: var(--status-ok-text);
  background: var(--status-ok-bg);
}

.checkout-message.is-warn {
  border-color: var(--status-warn-border);
  color: var(--status-warn-text);
  background: var(--status-warn-bg);
}

.checkout-message.is-error {
  border-color: var(--status-error-border);
  color: var(--status-error-text);
  background: var(--status-error-bg);
}

.checkout-order-panel {
  margin-top: 0.72rem;
  border-top: 1px solid var(--border);
  padding-top: 0.58rem;
  display: flex;
  flex-direction: column;
  gap: 0.34rem;
}

.checkout-order-row {
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  align-items: baseline;
  font-size: 0.86rem;
}

.checkout-order-row .is-ok {
  color: #14532d;
}

.checkout-order-row .is-warn {
  color: #8a6a24;
}

.checkout-order-row .is-error {
  color: #b42318;
}

.checkout-order-link {
  font-size: 0.86rem;
}

.checkout-download-links {
  margin: 0.2rem 0 0;
  padding-left: 1.1rem;
}

.checkout-download-links li {
  margin: 0.18rem 0;
}

.checkout-delivery-pass {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.28rem;
  margin-top: 0.18rem;
}

.checkout-delivery-pass small {
  color: var(--light-text);
}

.delivery-shell {
  max-width: 760px;
}

.delivery-order-panel {
  border-top: 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 0.8rem;
  padding-bottom: 0.65rem;
}

.delivery-downloads h2 {
  margin: 0 0 0.55rem;
  font-size: 1.05rem;
}

.delivery-download-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.delivery-download-row {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-raised, #fff);
  padding: 0.58rem 0.66rem;
}

.delivery-download-row > div {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  min-width: 0;
}

.delivery-download-row span,
.delivery-note {
  color: var(--light-text);
  font-size: 0.86rem;
}

.delivery-note {
  margin: 0.8rem 0 0;
}

.checkout-simulate-btn {
  align-self: flex-start;
  margin-top: 0.2rem;
}

.checkout-link-button,
.cart-page-link-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.35rem 0.65rem;
  text-decoration: none;
  color: var(--text);
  background: var(--surface-raised, #fff);
  font-size: 0.86rem;
  font-weight: 600;
}

.checkout-link-button:hover,
.checkout-link-button:focus-visible,
.cart-page-link-button:hover,
.cart-page-link-button:focus-visible {
  text-decoration: none;
  border-color: var(--accent);
}

.cart-page-link-button-primary {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  color: var(--nav-active-text, #fff);
  border-color: color-mix(in srgb, var(--accent-dark) 70%, var(--border) 30%);
}

.cart-page-empty {
  border: 1px dashed var(--border);
  border-radius: 10px;
  padding: 0.85rem;
  display: inline-flex;
  flex-direction: column;
  gap: 0.45rem;
}

.cart-page-list-wrap {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(220px, 320px);
  gap: 0.85rem;
}

.cart-page-row {
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  align-items: center;
}

.cart-page-row-main {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.cart-page-item-title {
  text-decoration: none;
  color: var(--text);
  font-weight: 600;
}

.cart-page-item-title:hover,
.cart-page-item-title:focus-visible {
  text-decoration: underline;
}

.cart-page-item-price {
  font-size: 0.86rem;
  color: var(--light-text);
}

.cart-page-row-actions {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.32rem;
}

.cart-page-row-actions button {
  min-height: 1.8rem;
  padding: 0.16rem 0.52rem;
  border-radius: 7px;
  font-size: 0.8rem;
}

.cart-page-summary {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-raised, #fff);
  padding: 0.62rem;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.cart-page-summary-row {
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  align-items: baseline;
}

.cart-page-summary-actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.38rem;
}

@media (max-width: 860px) {
  .checkout-grid,
  .cart-page-list-wrap {
    grid-template-columns: 1fr;
  }
}

.list-page-shell {
  --list-inline-grid-columns: 1.85rem 1.55rem minmax(340px, 3.4fr) minmax(180px, 1.4fr) minmax(190px, 1.25fr) minmax(96px, 0.65fr) minmax(260px, 1.55fr) minmax(82px, max-content);
  width: 100%;
  max-width: 100%;
  margin: 1.25rem auto 2.4rem;
  padding: 1.15rem 1.25rem 1rem;
  border: 1px solid #afbdd8;
  border-radius: 12px;
  background: var(--post-card-bg-single, #fdfdfb);
  box-shadow:
    0 18px 36px rgba(15, 23, 42, 0.09),
    0 1px 0 rgba(255, 255, 255, 0.82) inset;
  transition: width 420ms cubic-bezier(0.22, 1, 0.36, 1), max-width 420ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 320ms ease;
}

.list-page-shell.is-loading:not([data-prerender-painted="true"]) {
  visibility: hidden;
}

.list-page-shell.is-editing {
  width: 100%;
  max-width: min(1780px, calc(100vw - 1rem));
  margin-left: auto;
  margin-right: auto;
}

.list-page-shell[data-page-type="icon-gallery"].is-editing {
  max-width: min(1780px, calc(100vw - 1rem));
}

.list-page-head h1 {
  margin: 0 0 0.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  font-size: 2.2rem;
  line-height: 1.16;
}

.list-page-head h1.has-nav-title-row {
  flex-wrap: wrap;
  align-items: flex-start;
  row-gap: 0.22rem;
}

.list-validation {
  margin: 1rem 0 0.9rem;
}

.list-validation-block {
  border-radius: 8px;
  padding: 0.6rem 0.75rem;
  margin: 0 0 0.55rem;
  color: var(--status-error-text);
}

.list-validation-block,
.list-validation-block * {
  color: inherit !important;
  -webkit-text-fill-color: currentColor !important;
}

.list-validation-block ul {
  margin: 0.45rem 0 0;
}

.list-validation-block.is-error {
  background: #8f2b1f;
  border: 1px solid #6f1f16;
  color: #fff7f5 !important;
}

.list-validation-block.is-warn {
  background: #7a611a;
  border: 1px solid #5d4a12;
  color: #fff8e3 !important;
}

.list-validation-block strong,
.list-validation-block li {
  color: inherit !important;
}

.list-validation-block.is-warn strong,
.list-validation-block.is-warn li {
  color: inherit !important;
}

.list-admin {
  margin: 0.15rem 0 0.45rem;
  border: 0;
  background: transparent;
}

.list-admin-panel {
  margin: 0;
  display: block;
  width: 100%;
}

.list-admin-panel[open] {
  padding: 0.75rem 0.75rem 0.65rem;
}

.list-admin-summary {
  cursor: pointer;
  font-weight: 700;
  font-size: 0.95rem;
  list-style: none;
  display: block;
  width: 100%;
}

.list-admin-summary::-webkit-details-marker {
  display: none;
}

.list-admin-summary::before {
  content: '▾ ';
  color: var(--muted-text, #52617f);
}

.list-admin-panel:not([open]) .list-admin-summary::before {
  content: '▸ ';
}

.list-admin-topbar {
  display: flex;
  justify-content: flex-end;
  margin: 0.45rem 0 0.7rem;
}

.list-admin-actions {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.list-admin-actions button {
  width: fit-content;
  padding: 0.42rem 0.68rem;
  border-radius: 8px;
}

.list-admin-actions button:disabled {
  background: #d4dae6;
  border-color: #c3cada;
  color: #6d778d;
  cursor: default;
  box-shadow: none;
}

.list-admin-actions button:disabled:hover {
  background: #d4dae6;
  border-color: #c3cada;
  color: #6d778d;
}

.list-admin-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, max-content));
  gap: 0.6rem;
  margin-bottom: 0.7rem;
}

.list-admin-meta label {
  display: grid;
  flex-direction: column;
  gap: 0.18rem;
  width: fit-content;
  min-width: 13rem;
  font-size: 0.8rem;
}

.list-admin-meta label span {
  color: var(--muted-text, #4f617f);
}

.list-admin-meta input,
.list-admin-meta select {
  min-width: 13rem;
  width: 100%;
  max-width: 20rem;
  height: 2.15rem;
}

.list-inline-empty {
  margin-top: 0.75rem;
  padding: 0.7rem 0.8rem;
  border: 1px dashed var(--border);
  border-radius: 8px;
  color: var(--muted-text, #4f617f);
}

.list-admin-entries-wrap {
  position: relative;
  margin-top: 0.2rem;
  padding: 0.55rem 0.55rem 2.9rem;
  border: 1px solid var(--border, #c5d0e6);
  border-radius: 10px;
  background: var(--surface-raised-strong, #fff);
  max-width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  overscroll-behavior-x: contain;
}

.list-admin-entries-title {
  margin: 0 0 0.45rem;
  font-size: 0.92rem;
}

.list-admin-empty {
  margin: 0.2rem 0 0.1rem;
}

.list-admin-entry {
  border: 1px solid var(--border, #c5d0e6);
  border-radius: 10px;
  padding: 0.5rem;
  margin-bottom: 0.55rem;
  display: flex;
  gap: 0.5rem;
  background: #f8fbff;
}

.list-admin-entry-controls {
  display: inline-flex;
  flex-direction: column;
  gap: 0.32rem;
}

.list-admin-entry-controls button {
  width: fit-content;
  min-width: 1.9rem;
  height: 1.9rem;
  padding: 0 0.35rem;
}

.list-admin-entry-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, max-content));
  gap: 0.45rem;
}

.list-admin-entry-fields label {
  display: grid;
  gap: 0.2rem;
  width: fit-content;
  min-width: 10.5rem;
  font-size: 0.78rem;
}

.list-admin-entry-fields label span {
  color: var(--muted-text, #4f617f);
}

.list-admin-field-wide {
  min-width: 19rem !important;
}

.list-admin-eventid-details {
  grid-column: 1 / -1;
  margin-top: 0.15rem;
}

.list-admin-eventid-details summary {
  cursor: pointer;
  font-size: 0.78rem;
  color: var(--muted-text, #4f617f);
}

.list-admin-eventid-details label {
  margin-top: 0.35rem;
}

.list-admin-entry-fields input {
  min-width: 10.5rem;
  max-width: 24rem;
  width: 100%;
  height: 2.1rem;
}

.list-admin-add-fab {
  position: absolute;
  right: 0.65rem;
  bottom: 0.65rem;
  width: 2.1rem;
  min-width: 2.1rem;
  height: 2.1rem;
  padding: 0;
  border-radius: 999px;
  font-size: 1.12rem;
  line-height: 1;
}

.list-admin-save-status {
  margin-top: 0.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.35rem;
  width: 100%;
  color: var(--muted-text, #4f617f);
  min-height: 1.1rem;
  font-size: 0.82rem;
}

.list-admin-save-status.is-error {
  color: var(--save-error-text);
}

.list-page-title-actions .list-admin-save-status {
  margin: 0;
  width: auto;
  min-height: 0;
  font-size: 0.8rem;
}

.save-spinner {
  width: 0.82rem;
  height: 0.82rem;
  border-radius: 999px;
  border: 2px solid var(--spinner-track);
  border-top-color: var(--spinner-head);
  animation: list-spin 0.8s linear infinite;
}

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

.list-page-content {
  margin-top: 0.8rem;
  background: transparent;
  border: 0;
  box-shadow: none;
}

#contact-page-root.contact-edit-mode #contact-page-description {
  margin-bottom: 0.25rem;
}

#contact-page-root.contact-edit-mode .list-page-content {
  margin-top: 0.18rem;
}

.list-page-empty-state {
  margin: 1.1rem 0;
  text-align: center;
  color: var(--muted-text, #6b7a95);
  font-style: italic;
}

.list-page-admin-bar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.4rem;
}

.list-page-admin-bar button {
  width: fit-content;
  padding: 0.36rem 0.74rem;
  border-radius: 8px;
  border: 0 !important;
  border-top: 0 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  border-left: 0 !important;
  border-inline-start: 0 !important;
  border-inline-end: 0 !important;
  border-block-start: 0 !important;
  border-block-end: 0 !important;
  border-color: transparent !important;
  border-image: none !important;
  font-size: 0.92rem;
  line-height: 1.22;
  appearance: none;
  -webkit-appearance: none;
  background-clip: padding-box !important;
  -webkit-background-clip: padding-box !important;
  background-origin: padding-box !important;
  outline: none;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  clip-path: none !important;
  contain: none !important;
  overflow: visible !important;
}

.list-page-admin-bar button:not(.list-admin-primary-btn) {
  background: var(--action-soft-bg, #f5e4d7) !important;
  background-image: none !important;
  color: var(--action-soft-text, #6d3a20) !important;
  -webkit-text-fill-color: var(--action-soft-text, #6d3a20);
}

.list-page-admin-bar button:not(.list-admin-primary-btn):hover:not(:disabled),
.list-page-admin-bar button:not(.list-admin-primary-btn):focus-visible:not(:disabled) {
  background: var(--action-soft-hover-bg, #f0d7c5) !important;
  background-image: none !important;
  color: var(--action-soft-hover-text, #5b2f18) !important;
  -webkit-text-fill-color: var(--action-soft-hover-text, #5b2f18);
}

.list-page-admin-bar .list-admin-primary-btn {
  padding: 0.36rem 0.74rem;
  border-radius: 8px;
  background: var(--action-soft-bg, #f5e4d7) !important;
  background-image: none !important;
  color: var(--action-soft-text, #6d3a20) !important;
  -webkit-text-fill-color: var(--action-soft-text, #6d3a20);
  font-size: 0.92rem;
  font-weight: 400;
  line-height: 1.22;
}

.list-page-admin-bar button[data-list-action="toggle-edit"] {
  border: 0 !important;
  border-image: none !important;
  box-shadow: none !important;
}

.list-page-admin-bar button[data-list-action="toggle-edit"]:hover:not(:disabled),
.list-page-admin-bar button[data-list-action="toggle-edit"]:focus-visible:not(:disabled),
.list-page-admin-bar button[data-list-action="toggle-edit"]:active:not(:disabled) {
  border: 0 !important;
  border-image: none !important;
  box-shadow: none !important;
}

.list-page-admin-bar button[data-blog-action="toggle-page-settings"],
.list-page-admin-bar button[data-blog-action="toggle-page-settings"]:hover:not(:disabled),
.list-page-admin-bar button[data-blog-action="toggle-page-settings"]:focus-visible:not(:disabled),
.list-page-admin-bar button[data-blog-action="toggle-page-settings"]:active:not(:disabled) {
  border: 0 !important;
  border-right: 0 !important;
  border-image: none !important;
  outline: 0 !important;
  box-shadow:
    0 7px 16px rgba(48, 34, 16, 0.09),
    0 1px 0 rgba(255, 255, 255, 0.62) inset !important;
  -webkit-box-shadow:
    0 7px 16px rgba(48, 34, 16, 0.09),
    0 1px 0 rgba(255, 255, 255, 0.62) inset !important;
  background-clip: padding-box !important;
  -webkit-background-clip: padding-box !important;
}

.public-ranking-submit-toggle {
  padding: 0.36rem 0.74rem;
  border-radius: 8px;
  border: 1px solid transparent;
  background: var(--action-soft-bg, #f5e4d7) !important;
  background-image: none !important;
  color: var(--action-soft-text, #6d3a20) !important;
  -webkit-text-fill-color: var(--action-soft-text, #6d3a20);
  box-shadow: inset 0 0 0 1px var(--action-soft-border, #c58f6f);
  font-size: 0.92rem;
  font-weight: 400;
  line-height: 1.22;
}

.list-page-admin-bar .list-admin-primary-btn:hover:not(:disabled),
.list-page-admin-bar .list-admin-primary-btn:focus-visible:not(:disabled) {
  background: var(--action-soft-hover-bg, #f0d7c5) !important;
  background-image: none !important;
  border-color: var(--action-soft-hover-border, #b77753);
  color: var(--action-soft-hover-text, #5b2f18) !important;
  -webkit-text-fill-color: var(--action-soft-hover-text, #5b2f18);
  box-shadow: none;
}

.public-ranking-submit-toggle:hover:not(:disabled),
.public-ranking-submit-toggle:focus-visible:not(:disabled) {
  background: var(--action-soft-hover-bg, #f0d7c5) !important;
  background-image: none !important;
  border-color: transparent;
  color: var(--action-soft-hover-text, #5b2f18) !important;
  -webkit-text-fill-color: var(--action-soft-hover-text, #5b2f18);
  box-shadow: inset 0 0 0 1px var(--action-soft-hover-border, #b77753);
}

.list-page-admin-bar .list-admin-primary-btn:active:not(:disabled),
.list-page-admin-bar .list-admin-primary-btn:active:not(:disabled) {
  background: var(--action-soft-active-bg, #e8c9b3) !important;
  background-image: none !important;
  border-color: var(--action-soft-active-border, #a86442);
  color: var(--action-soft-active-text, #4d2614) !important;
  -webkit-text-fill-color: var(--action-soft-active-text, #4d2614);
  box-shadow: none;
}

.public-ranking-submit-toggle:active:not(:disabled) {
  background: var(--action-soft-active-bg, #e8c9b3) !important;
  background-image: none !important;
  border-color: transparent;
  color: var(--action-soft-active-text, #4d2614) !important;
  -webkit-text-fill-color: var(--action-soft-active-text, #4d2614);
  box-shadow: inset 0 0 0 1px var(--action-soft-active-border, #a86442);
}

.list-page-admin-bar button:disabled {
  background: #cfd5df;
  background-image: none !important;
  border-image: none !important;
  border-color: #b6bfce;
  color: #717c92;
  -webkit-text-fill-color: #717c92;
  cursor: not-allowed;
  box-shadow: none !important;
  text-shadow: none;
  opacity: 0.78;
}

.list-page-admin-bar button:disabled:hover {
  background: #cfd5df;
  background-image: none !important;
  border-image: none !important;
  border-color: #b6bfce;
  color: #717c92;
  -webkit-text-fill-color: #717c92;
  box-shadow: none !important;
  text-shadow: none;
}

.list-inline-edit-link {
  border: 0;
  background: transparent;
  padding: 0;
  margin-left: 0.35rem;
  font-size: 0.82rem;
  font-weight: 400;
  line-height: 1.2;
  font-family: inherit;
  display: inline-flex;
  align-items: baseline;
  border-radius: 0;
  color: #46619a;
  -webkit-text-fill-color: #46619a;
  text-decoration: none;
}

.list-inline-edit-link:hover,
.list-inline-edit-link:focus-visible {
  background: transparent !important;
  color: #46619a !important;
  -webkit-text-fill-color: #46619a;
  text-decoration: underline;
  box-shadow: none;
}

.list-page-nav-title-row-wrap {
  margin: 0 0 0.42rem;
}

.list-page-head h1.has-nav-title-row .list-page-nav-title-row-wrap {
  flex: 0 0 100%;
  margin: 0 0 0.1rem;
}

.list-page-nav-title-row {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem;
  font-size: 0.9rem;
  color: var(--muted-text, #4f617f);
}

.list-page-nav-title-label {
  font-weight: 600;
}

.list-page-nav-title-value {
  font-weight: 500;
  color: var(--text, #243046);
}

.list-page-nav-title-edit-wrap {
  display: inline-flex;
  align-items: baseline;
  gap: 0.34rem;
}

.list-page-nav-title-row .list-page-nav-title-edit-link {
  margin-left: 0.35rem;
  align-items: baseline;
}

.list-page-nav-title-input {
  width: min(18rem, 62vw);
  height: 2rem;
  font-size: 0.92rem;
  color: #111 !important;
  -webkit-text-fill-color: #111 !important;
}

.list-page-nav-title-input::placeholder {
  color: #666;
  -webkit-text-fill-color: #666;
}

.list-page-title-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-left: auto;
  margin-right: 0;
  align-self: flex-start;
  transform: translateY(-2px);
  padding: 0 0.45rem 0.4rem 0.55rem;
  font-size: 0;
  line-height: 0;
  overflow: visible;
  position: relative;
  z-index: 1;
}

.list-page-title-actions > * {
  font-size: 0.92rem;
  line-height: normal;
}

#blog-page-title .list-page-title-actions {
  flex: 0 0 auto;
  width: auto;
  white-space: nowrap;
}

#blog-page-title .blog-title-action-bar {
  display: inline-flex;
  align-items: center;
  gap: 0.34rem;
  flex: 0 0 auto;
  flex-wrap: nowrap;
}

#blog-page-title .blog-filter-toggle {
  flex: 0 0 auto;
}

.list-head-inline-input {
  width: min(30rem, 72vw);
  height: 2.2rem;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text, #223047);
  -webkit-text-fill-color: var(--text, #223047);
  text-shadow: none;
  background-clip: border-box;
  -webkit-background-clip: border-box;
}

#list-page-title,
#blog-page-title,
#contact-page-title,
#nip23-page-title,
#public-ranking-title {
  display: flex;
  width: 100%;
  align-items: baseline;
  gap: 0;
}

#list-page-title:has(.list-page-title-actions),
#blog-page-title:has(.list-page-title-actions),
#contact-page-title:has(.list-page-title-actions),
#nip23-page-title:has(.list-page-title-actions),
#public-ranking-title:has(.list-page-title-actions) {
  border-bottom: 2px solid var(--border);
  border-image: none;
  padding-bottom: 0.08rem;
}

#list-page-title:has(.list-page-title-actions) .list-page-title-text,
#list-page-title:has(.list-page-title-actions) .list-page-title-edit-wrap,
#blog-page-title:has(.list-page-title-actions) .list-page-title-text,
#blog-page-title:has(.list-page-title-actions) .list-page-title-edit-wrap,
#contact-page-title:has(.list-page-title-actions) .list-page-title-text,
#contact-page-title:has(.list-page-title-actions) .list-page-title-edit-wrap,
#nip23-page-title:has(.list-page-title-actions) .list-page-title-text,
#nip23-page-title:has(.list-page-title-actions) .list-page-title-edit-wrap,
#public-ranking-title:has(.list-page-title-actions) .list-page-title-text,
#public-ranking-title:has(.list-page-title-actions) .list-page-title-edit-wrap {
  display: block;
  flex: 1 1 auto;
  min-width: 0;
}

#list-page-title .list-inline-edit-link,
#blog-page-title .list-inline-edit-link,
#contact-page-title .list-inline-edit-link,
#nip23-page-title .list-inline-edit-link,
#public-ranking-title .list-inline-edit-link {
  margin-left: 0.62rem;
  align-self: baseline;
  color: #46619a;
  -webkit-text-fill-color: #46619a;
}

.list-head-description-input {
  display: block;
  width: 100%;
  max-width: 100%;
  min-height: 7rem;
  resize: vertical;
  font-size: 0.98rem;
  font-weight: 500;
  line-height: 1.45;
  padding: 0.5rem 0.62rem;
}

.list-page-description-edit-wrap {
  display: block;
  width: 100%;
  max-width: min(56rem, 100%);
}

.list-page-description-empty {
  color: var(--muted-text, #6b7a95);
  font-style: italic;
}

.list-inline-edit-shell {
  border: 1px solid var(--border, #c5d0e6);
  border-radius: 10px;
  background: var(--surface-raised-strong, #fff);
  padding: 0.6rem 0.65rem;
  overflow-x: auto;
}

.list-inline-edit-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8rem;
  margin-bottom: 0.45rem;
}

.list-inline-edit-title {
  font-weight: 700;
  color: var(--text);
}

.list-inline-edit-controls {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  row-gap: 0.34rem;
}

.list-inline-edit-controls label {
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0.35rem;
  font-size: 0.8rem;
  color: var(--muted-text, #4f617f);
  white-space: nowrap;
}

.list-inline-edit-controls .list-default-markers-setting {
  gap: 0.32rem;
}

.list-inline-edit-controls .list-marker-filter-setting {
  gap: 0.28rem;
}

.list-inline-edit-controls .list-marker-filter-setting input[type="checkbox"],
.list-inline-edit-controls .list-show-markers-setting input[type="checkbox"] {
  margin: 0;
}

.list-inline-edit-controls .list-alphabetize-markers-setting input[type="checkbox"] {
  margin: 0;
}

.list-inline-edit-controls .list-alphabetize-markers-setting.is-disabled {
  opacity: 0.55;
}

.list-inline-edit-controls select {
  width: auto !important;
  min-width: 0;
  height: 2.05rem;
}

.list-inline-edit-controls .list-default-markers-setting input[type="text"] {
  width: 19rem;
  min-width: 12rem;
  max-width: min(38vw, 24rem);
  height: 2.05rem;
  padding: 0.35rem 0.55rem;
  line-height: 1.2;
}

.list-inline-edit-controls button {
  width: 2.1rem;
  min-width: 2.1rem;
  height: 2.1rem;
  padding: 0;
  border-radius: 999px;
}

.list-year-group {
  margin-bottom: 1.1rem;
  width: 100%;
}

.list-year-heading {
  margin: 0.2rem 0 0.5rem;
}

.list-year-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.list-year-add {
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transform: translateX(-2px);
}

.list-inline-head {
  display: grid;
  grid-template-columns: var(--list-inline-grid-columns);
  gap: 0.32rem;
  align-items: center;
  margin: 0 0 0.5rem;
  padding: 0 0.35rem;
  font-size: 0.72rem;
  color: var(--muted-text, #4f617f);
  text-transform: none;
  letter-spacing: 0.01em;
}

.list-inline-head > span {
  justify-self: center;
  text-align: center;
}

.list-inline-head-history {
  grid-column: 1 / span 2;
  justify-self: start;
  text-align: left;
  display: inline-flex;
  align-items: center;
}

.list-inline-head-actions {
  display: inline-flex;
  justify-content: flex-end;
  justify-self: end;
  text-align: right;
}

.list-inline-add-end-row {
  margin: 0.18rem 0 0.42rem;
  padding: 0 0.35rem;
}

.list-inline-add-end {
  border: 0;
  background: transparent !important;
  background-image: none !important;
  padding: 0;
  color: var(--muted-text, #4f617f) !important;
  -webkit-text-fill-color: var(--muted-text, #4f617f);
  font-style: italic;
  font-size: 0.92rem;
  line-height: 1.25;
  text-decoration: none;
  box-shadow: none !important;
}

.list-inline-add-end:hover,
.list-inline-add-end:focus-visible {
  background: transparent !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  text-decoration: underline;
  box-shadow: none !important;
}

.list-entries-inline {
  list-style: none;
  padding: 0;
  margin: 0;
  display: block;
  width: 100%;
}

.list-entries.list-entries-inline {
  padding-left: 0;
}

.list-entry-inline {
  --list-depth-indent: calc(var(--list-depth, 0) * 1.35rem);
  display: grid;
  grid-template-columns: var(--list-inline-grid-columns);
  gap: 0.32rem;
  align-items: center;
  margin: 0 0 0.46rem;
  padding: 0 0.35rem;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.list-page-shell[data-page-type="list"] {
  --list-inline-grid-columns: 1.85rem 1.55rem minmax(0, 6fr) minmax(170px, 1.5fr) minmax(180px, 1.3fr) minmax(96px, 0.75fr) minmax(260px, 1.8fr) minmax(2.2rem, max-content);
}

.list-page-shell[data-page-type="icon-gallery"] {
  --list-inline-grid-columns: 2rem 2.1rem minmax(210px, 1.25fr) minmax(170px, 1fr) minmax(160px, 0.95fr) minmax(120px, 0.8fr) minmax(200px, 1.55fr) minmax(170px, 1.25fr) minmax(136px, max-content);
}

.list-entry-inline.is-active {
  padding: 0 0.35rem;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.list-inline-head,
.list-entries-inline,
.list-entry-inline {
  width: 100%;
  min-width: 100%;
  box-sizing: border-box;
}

.list-inline-cell {
  min-width: 0;
}

.list-inline-open {
  display: inline-block;
  border: 0;
  background: transparent;
  text-align: left;
  padding: 0.24rem 0.1rem;
  color: var(--text);
  cursor: text;
}

.list-inline-open:hover {
  background: rgba(49, 103, 189, 0.04) !important;
  border-radius: 0;
}

.list-entry-inline .list-inline-markdown a {
  cursor: text;
}

.list-entry-inline .list-inline-markdown {
  min-width: 0;
  overflow: hidden;
  padding-left: var(--list-depth-indent);
}

.list-entry-inline .list-inline-markdown .list-inline-open {
  display: block;
  width: 100%;
  min-width: 0;
}

.list-entry-inline .list-inline-post-url {
  min-width: 0;
  overflow: hidden;
}

.list-entry-inline .list-inline-post-url .list-inline-open {
  max-width: 100%;
}

.list-page-shell[data-page-type="list"] .list-entry-inline.is-editing-post-url {
  --list-inline-grid-columns: 1.85rem 1.55rem minmax(0, 6fr) minmax(0, 6fr) minmax(180px, 1.3fr) minmax(96px, 0.75fr) minmax(260px, 1.8fr) minmax(2.2rem, max-content);
}

.list-entry-inline .list-inline-markdown .list-inline-value {
  display: block;
  min-width: 0;
  font-size: 0.94rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.list-entry-inline .list-inline-markdown a {
  display: inline-block;
  max-width: 100%;
  font-size: 0.94rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.list-entry-inline .list-inline-markdown input[type="text"] {
  font-size: 0.94rem;
  line-height: 1.2;
}

.list-inline-handle {
  color: #8ca0c7;
  cursor: move;
  text-align: center;
  user-select: none;
  font-size: 0.92rem;
}

.list-inline-indent-controls {
  display: inline-flex;
  gap: 0;
}

.list-entry-inline .list-inline-indent-controls {
  transform: translateX(var(--list-depth-indent));
}

.list-inline-indent-btn {
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
}

.list-inline-indent-btn:hover,
.list-inline-indent-btn:focus-visible {
  background: var(--light-bg, #eef3ff) !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  box-shadow: none;
}

.list-inline-indent-btn:active:not(:disabled) {
  background: rgba(49, 103, 189, 0.12) !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  box-shadow: none;
}

.list-inline-indent-btn[disabled],
.list-inline-indent-btn[aria-disabled="true"] {
  opacity: 0.45;
  cursor: default;
  pointer-events: none;
}

.list-entry-inline input[type=\"text\"] {
  width: 100%;
  min-width: 0;
  height: 2rem;
  box-sizing: border-box;
  padding: 0.35rem 0.55rem;
  line-height: 1.2;
  user-select: text;
  -webkit-user-select: text;
}

.list-inline-eventid input[type="text"] {
  box-sizing: border-box;
  height: 2rem;
  padding: 0.35rem 0.55rem;
  line-height: 1.2;
}

.list-inline-actions button {
  width: 1.9rem;
  min-width: 1.9rem;
  height: 1.9rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--danger) !important;
  -webkit-text-fill-color: var(--danger);
  border-radius: 8px;
}

.list-inline-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 0.24rem;
  width: 100%;
  justify-self: end;
}

.list-inline-row-menu-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.list-inline-actions .list-inline-row-menu-trigger {
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  font-size: 0;
  line-height: 1;
}

.list-inline-row-menu-trigger .overflow-menu-icon-svg {
  width: 1rem;
  height: 1rem;
}

.list-entry-read-menu {
  display: inline-flex;
  align-items: center;
}

.list-entry-read-menu .list-inline-row-menu-trigger {
  width: 1.9rem;
  min-width: 1.9rem;
  height: 1.9rem;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  font-size: 0;
  line-height: 1;
}

.list-entry-read-inline {
  display: grid;
  grid-template-columns: minmax(14rem, 1fr) max-content;
  gap: 0.45rem;
  align-items: center;
  padding: 0.18rem 0 0.18rem calc(var(--list-depth, 0) * 1.4rem);
}

.list-entry-read-inline-input {
  min-width: 14rem;
  width: min(46rem, 100%);
  padding: 0.42rem 0.56rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--input-bg, var(--surface, #fff));
  color: var(--text);
  font: inherit;
}

.list-entry-read-inline-meta {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(8rem, 1fr));
  gap: 0.38rem;
  min-width: 0;
}

.list-entry-read-inline-detail {
  min-width: 0;
}

.list-entry-read-inline-input:focus {
  outline: 2px solid color-mix(in srgb, var(--accent, #4466ff) 45%, transparent);
  outline-offset: 1px;
}

.list-entry-read-inline-done {
  grid-column: 2;
  grid-row: 1;
  width: fit-content;
  white-space: nowrap;
}

@media (max-width: 720px) {
  .list-entry-read-inline {
    grid-template-columns: minmax(0, 1fr);
  }

  .list-entry-read-inline-done {
    grid-column: 1;
    grid-row: auto;
    justify-self: start;
  }

  .list-entry-read-inline-meta {
    grid-template-columns: minmax(0, 1fr);
  }
}

.list-inline-actions .list-inline-row-menu-trigger:hover,
.list-inline-actions .list-inline-row-menu-trigger:focus-visible,
.list-inline-actions .list-inline-row-menu-trigger:active {
  background: var(--light-bg, #eef3ff) !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
}

.list-entry-read-menu .list-inline-row-menu-trigger:hover,
.list-entry-read-menu .list-inline-row-menu-trigger:focus-visible,
.list-entry-read-menu .list-inline-row-menu-trigger:active {
  background: var(--light-bg, #eef3ff) !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
}

.list-inline-row-menu {
  position: absolute;
  top: calc(100% + 0.25rem);
  right: 0;
  z-index: 40;
  min-width: 12rem;
  padding: 0.32rem;
  border: 0;
  border-radius: 12px;
  background: var(--menu-bg);
  background-image: none !important;
  box-shadow: var(--popup-menu-shadow, var(--menu-shadow));
}

.list-inline-row-menu button {
  width: 100%;
  min-width: 0;
  height: auto;
  padding: 0.44rem 0.56rem;
  border: 0;
  border-radius: 8px;
  background: transparent !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  text-align: left;
  line-height: 1.25;
}

.list-inline-row-menu button[role="menuitem"] {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
}

.list-inline-row-menu-danger {
  color: var(--danger) !important;
  -webkit-text-fill-color: var(--danger) !important;
}

.list-inline-row-menu-danger svg {
  width: 0.9rem;
  height: 0.9rem;
  display: block;
}

.list-inline-row-menu-danger:hover,
.list-inline-row-menu-danger:focus-visible {
  background: var(--danger-soft) !important;
}

.list-inline-row-menu button:hover,
.list-inline-row-menu button:focus-visible {
  background: var(--menu-hover-bg) !important;
}

.list-inline-actions button:hover,
.list-inline-actions button:focus-visible {
  background: var(--danger-soft) !important;
  color: var(--danger) !important;
  -webkit-text-fill-color: var(--danger);
  box-shadow: none;
}

.list-inline-actions button:active {
  background: var(--danger-soft-strong) !important;
  color: var(--danger) !important;
  -webkit-text-fill-color: var(--danger);
  box-shadow: none;
}

.list-inline-actions button[data-list-inline-action="create-product"] {
  width: fit-content;
  min-width: 0;
  height: 2.08rem;
  padding: 0 0.68rem;
  border: 1px solid color-mix(in srgb, var(--accent, #3158a4) 34%, var(--border, #c8d4f3) 66%);
  background: color-mix(in srgb, var(--accent, #3158a4) 11%, transparent) !important;
  color: color-mix(in srgb, var(--accent-dark, #1f3f83) 78%, #1b2d52 22%) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--accent-dark, #1f3f83) 78%, #1b2d52 22%);
  font-size: 0.82rem;
  line-height: 1.05;
  border-radius: 8px;
}

.list-inline-actions button[data-list-inline-action="create-product"]:hover,
.list-inline-actions button[data-list-inline-action="create-product"]:focus-visible {
  background: color-mix(in srgb, var(--accent, #3158a4) 17%, transparent) !important;
  border-color: color-mix(in srgb, var(--accent, #3158a4) 46%, var(--border, #c8d4f3) 54%);
  color: color-mix(in srgb, var(--accent-dark, #1f3f83) 84%, #132549 16%) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--accent-dark, #1f3f83) 84%, #132549 16%);
}

.list-inline-actions button[data-list-inline-action="create-product"][disabled],
.list-inline-actions button[data-list-inline-action="create-product"][aria-disabled="true"] {
  opacity: 0.5;
  cursor: default;
  pointer-events: none;
}

.list-inline-action-link {
  width: 1.9rem;
  min-width: 1.9rem;
  height: 1.9rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  text-decoration: none;
  border: 1px solid color-mix(in srgb, var(--accent, #3158a4) 30%, var(--border, #c8d4f3) 70%);
  color: color-mix(in srgb, var(--accent-dark, #1f3f83) 76%, #14274a 24%);
  background: color-mix(in srgb, var(--accent, #3158a4) 8%, transparent);
}

.list-inline-action-link:hover,
.list-inline-action-link:focus-visible {
  background: color-mix(in srgb, var(--accent, #3158a4) 16%, transparent);
  border-color: color-mix(in srgb, var(--accent, #3158a4) 44%, var(--border, #c8d4f3) 56%);
}

.list-inline-eventid {
  grid-column: 3 / 8;
}

.list-inline-eventid .list-admin-eventid-details label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.list-inline-eventid .list-admin-eventid-details label input[type="text"] {
  flex: 1 1 auto;
  min-width: 0;
}

.list-inline-eventid-label {
  flex: 0 0 auto;
  font-size: 0.76rem;
  color: var(--muted-text, #4f617f);
  text-transform: none;
  letter-spacing: 0.01em;
}

.list-edit-brace {
  margin-left: 0.35rem;
  color: #6a7da6;
  font-size: 0.74rem;
  white-space: nowrap;
}

.list-entries {
  margin: 0;
  padding-left: 1.2rem;
}

.list-page-shell .list-entries:not(.list-entries-inline) {
  list-style: none;
  padding-left: 0;
}

.list-entry-line {
  margin: 0 0 0.42rem;
}

.list-group-line > .list-group-title {
  font-weight: 700;
}

.list-sub-entries {
  margin: 0.4rem 0 0.1rem;
  padding-left: 1.2rem;
  list-style-type: disc;
}

.list-inline-date-shell {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  width: 100%;
}

.list-inline-date-button {
  padding: 0.22rem 0.1rem;
  font-weight: 400;
}

.list-inline-date .list-inline-value,
.list-inline-date input[type="text"] {
  font-weight: 400;
}

.list-inline-image-url .list-inline-value,
.list-inline-image-url input[type="text"] {
  font-weight: 400;
}

.list-inline-marker input[type="text"] {
  font-weight: 400;
}

.list-inline-description .list-inline-value,
.list-inline-description input[type="text"] {
  font-weight: 400;
}

.list-inline-image-button {
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.list-inline-description-button {
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.list-inline-placeholder {
  color: var(--muted-text, #6b7a95);
  font-style: italic;
}

.nostr-page-settings-panel {
  margin: 0 0 0.58rem;
  padding: 0.46rem 0.58rem 0.5rem;
  border: 0;
  border-radius: 10px;
  background: color-mix(in srgb, var(--card-bg, #f8fbff) 90%, var(--nav-link-hover, #e8edff) 10%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.nostr-page-settings-title {
  margin: 0 0 0.34rem;
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--muted-text, #4f617f);
  letter-spacing: 0.01em;
  text-transform: none;
}

.nostr-page-settings-panel.is-entering {
  animation: nostrPageSettingsSlideIn 360ms cubic-bezier(0.22, 1, 0.36, 1);
  transform-origin: top center;
}

@keyframes nostrPageSettingsSlideIn {
  0% {
    opacity: 0;
    transform: translateY(-8px) scaleY(0.94);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scaleY(1);
  }
}


.list-inline-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 0.35rem;
  width: 100%;
  margin-bottom: 0.4rem;
}

.nostr-page-settings-panel .list-inline-toolbar {
  margin-bottom: 0;
}

.list-inline-toolbar-left,
.list-inline-toolbar-right {
  display: inline-flex;
  align-items: center;
}

.list-inline-toolbar-right {
  gap: 0.3rem;
}

.list-inline-history-controls {
  display: inline-flex;
  align-items: center;
  gap: 0.24rem;
}

.list-inline-history-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin: 0 0 0.46rem;
}

.list-inline-history-icon-btn {
  width: 2.25rem;
  min-width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent !important;
  color: var(--text, #2a3448) !important;
  -webkit-text-fill-color: var(--text, #2a3448);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.22rem;
  line-height: 1;
}

.list-inline-history-icon-btn svg {
  width: 1.16rem;
  height: 1.16rem;
  display: block;
}

.list-inline-history-icon-btn:hover:not(:disabled),
.list-inline-history-icon-btn:focus-visible:not(:disabled) {
  background: var(--light-bg, #eef3ff) !important;
  color: var(--text, #2a3448) !important;
  -webkit-text-fill-color: var(--text, #2a3448);
}

.list-inline-history-icon-btn:active:not(:disabled) {
  background: rgba(49, 103, 189, 0.12) !important;
}

.list-inline-history-icon-btn[disabled],
.list-inline-history-icon-btn[aria-disabled="true"] {
  opacity: 0.45;
  cursor: default;
  pointer-events: none;
}

.list-inline-toolbar-left {
  min-width: 0;
  flex: 1 1 auto;
}

.list-inline-toolbar-right button {
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-size: 1.2rem;
}

.list-inline-head-add {
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-size: 1.2rem;
}

.list-inline-toolbar-right button:hover:not(:disabled),
.list-inline-toolbar-right button:focus-visible:not(:disabled),
.list-inline-head-add:hover:not(:disabled),
.list-inline-head-add:focus-visible:not(:disabled),
.list-year-add:hover:not(:disabled),
.list-year-add:focus-visible:not(:disabled) {
  background: var(--light-bg, #eef3ff) !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  box-shadow: none;
}

.list-inline-toolbar-right button:active:not(:disabled),
.list-inline-head-add:active:not(:disabled),
.list-year-add:active:not(:disabled) {
  background: rgba(49, 103, 189, 0.12) !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  box-shadow: none;
}

.list-inline-toolbar-right button[disabled],
.list-inline-toolbar-right button[aria-disabled="true"],
.list-inline-head-add[disabled],
.list-inline-head-add[aria-disabled="true"],
.list-year-add[disabled],
.list-year-add[aria-disabled="true"] {
  opacity: 0.45;
  cursor: default;
  pointer-events: none;
}

.list-entry-post-link {
  display: inline-block;
  margin-right: 0.38rem;
  text-decoration: none;
}

.list-entry-first-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  column-gap: 0.38rem;
  min-width: 0;
}

.list-entry-first-line.has-votes {
  grid-template-columns: 2.1rem minmax(0, 1fr) auto;
}

.list-entry-first-line.has-votes .list-entry-vote-controls {
  grid-column: 1;
  justify-self: center;
}

.list-entry-first-line.has-votes .list-entry-main-inline {
  grid-column: 2;
}

.list-entry-first-line.has-votes .list-entry-meta-right {
  grid-column: 3;
}

.list-entry-main-inline {
  min-width: 0;
  display: inline-flex;
  align-items: baseline;
  gap: 0.38rem;
  flex-wrap: wrap;
}

.list-entry-meta-right {
  margin-left: 0;
  display: inline-grid;
  grid-auto-flow: column;
  grid-auto-columns: max-content;
  align-items: start;
  justify-content: end;
  column-gap: 0.26rem;
  justify-self: end;
  align-self: start;
}

.list-entry-meta-pills {
  min-width: 0;
  display: inline-flex;
  align-items: flex-start;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 0.32rem;
}

.list-entry-marker-pills {
  display: inline-flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 0.28rem;
}

.list-entry-marker-pill {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  position: relative;
  z-index: 1;
  cursor: default;
  user-select: none;
  -webkit-user-select: none;
  border-radius: 999px;
  border: 1px solid hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) - 10%), calc(var(--marker-pill-l, 90%) - 20%));
  background: hsl(var(--marker-pill-h, 220), var(--marker-pill-s, 56%), var(--marker-pill-l, 90%));
  color: #111 !important;
  -webkit-text-fill-color: #111 !important;
  text-shadow: none;
  padding: 0.08rem 0.44rem;
  font-size: 0.72rem;
  line-height: 1.15;
  white-space: nowrap;
}

.list-entry-first-line.has-cart-button {
  position: relative;
  padding-right: 6.6rem;
}

.list-entry-first-line.has-cart-button .list-entry-cart-btn {
  position: absolute;
  top: 0;
  right: 0;
}

.list-entry-first-line .list-entry-markdown {
  min-width: 0;
  line-height: 1.2;
}

.list-entry-list-icon {
  width: 1.28rem;
  height: 1.28rem;
  min-width: 1.28rem;
  border-radius: 4px;
  object-fit: cover;
  display: inline-block;
  align-self: center;
}

.list-entry-description-inline {
  color: var(--muted-text, #6e778a);
  -webkit-text-fill-color: var(--muted-text, #6e778a);
  font-size: 0.82rem;
  line-height: 1.2;
  opacity: 0.95;
  margin-left: 0.28rem;
}

.list-entry-description-inline :where(p) {
  margin: 0;
}

.list-entry-date-pill {
  margin-left: auto;
  flex: 0 0 auto;
  align-self: flex-start;
  padding: 0.08rem 0.5rem;
  border: 1px solid color-mix(in srgb, var(--border, #c8d4f3) 78%, var(--accent, #2f4aa6) 22%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--post-card-bg-single, #fff) 90%, var(--nav-link-hover, #e0e7ff) 10%);
  color: var(--muted-text, #5f6f92);
  -webkit-text-fill-color: var(--muted-text, #5f6f92);
  font-size: 0.74rem;
  line-height: 1.2;
  white-space: nowrap;
}

.list-entry-meta-right .list-entry-date-pill {
  margin-left: 0;
}

.list-page-shell .list-entry-line:not(.list-entry-inline) .list-entry-first-line {
  align-items: center;
  column-gap: 0.46rem;
}

.list-page-shell .list-entry-line:not(.list-entry-inline) .list-entry-main-inline {
  align-items: center;
  gap: 0.32rem;
}

.list-page-shell .list-entry-line:not(.list-entry-inline) .list-entry-markdown {
  font-size: 0.965rem;
  line-height: 1.34;
}

.list-page-shell .list-entry-line:not(.list-entry-inline) .list-entry-markdown :where(a) {
  color: color-mix(in srgb, var(--accent, #3158a4) 76%, #2f3a52 24%);
  -webkit-text-fill-color: color-mix(in srgb, var(--accent, #3158a4) 76%, #2f3a52 24%);
  line-height: 1.34;
  text-underline-offset: 0.06em;
  text-decoration-thickness: 1px;
}

.list-page-shell .list-entry-line:not(.list-entry-inline) .is-post-url-linked {
  color: color-mix(in srgb, var(--accent, #3158a4) 76%, #2f3a52 24%);
  -webkit-text-fill-color: color-mix(in srgb, var(--accent, #3158a4) 76%, #2f3a52 24%);
  text-underline-offset: 0.06em;
  text-decoration-thickness: 1px;
}

.list-page-shell .list-entry-line:not(.list-entry-inline) .list-entry-meta-right {
  align-items: start;
  gap: 0.24rem;
}

.list-page-shell .list-entry-line:not(.list-entry-inline) .list-entry-marker-pill {
  font-size: 0.69rem;
  padding: 0.06rem 0.42rem;
}

.list-page-shell .list-sub-entries {
  padding-left: 1.35rem;
}

.list-page-shell .list-entry-line:not(.list-entry-inline) {
  margin: 0;
  padding: 0.09rem 0.24rem;
}

.list-page-shell .list-entry-line[data-list-entry-href],
.list-tile[data-list-entry-href],
.list-tile-children li[data-list-entry-href] {
  cursor: pointer;
}

.list-page-shell .list-entry-line:not(.list-entry-inline) > .list-entry-first-line {
  border-radius: 7px;
  padding: 0.14rem 0.22rem;
}

.list-page-shell .list-entry-line:not(.list-entry-inline).is-row-highlight > .list-entry-first-line {
  background: color-mix(in srgb, var(--bg, #f3ebd7) 96%, #d9c7a5 4%);
}

.list-marker-filters {
  margin: 0 0 0.72rem;
}

.list-view-mode-row {
  display: flex;
  justify-content: flex-end;
  margin: 0 0 0.72rem;
}

.list-view-mode-pill {
  display: inline-flex;
  border: 1px solid var(--border, #c8d4f3);
  border-radius: 10px;
  padding: 0.12rem;
  background: color-mix(in srgb, var(--post-card-bg-single, #fff) 88%, var(--nav-link-hover, #e8edff) 12%);
}

.list-view-mode-btn {
  width: 2rem;
  min-width: 2rem;
  height: 1.9rem;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent !important;
  color: var(--muted-text, #4f617f) !important;
  -webkit-text-fill-color: var(--muted-text, #4f617f);
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.list-view-mode-btn:hover,
.list-view-mode-btn:focus-visible {
  background: color-mix(in srgb, var(--theme_dark, #172553) 8%, transparent) !important;
  color: var(--text, #253145) !important;
  -webkit-text-fill-color: var(--text, #253145);
  box-shadow: none;
}

.list-view-mode-btn.is-active {
  background: color-mix(in srgb, var(--accent, #3158a4) 22%, #ffffff 78%) !important;
  color: color-mix(in srgb, var(--accent-dark, #1f3f83) 85%, #112245 15%) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--accent-dark, #1f3f83) 85%, #112245 15%);
}

.list-view-mode-icon {
  width: 1.05rem;
  height: 1.05rem;
  display: block;
}

.list-marker-filters-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.36rem;
}

.list-marker-filter-pill {
  width: fit-content;
  border-radius: 999px !important;
  border: 1px solid hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) - 10%), calc(var(--marker-pill-l, 90%) - 20%)) !important;
  background: hsl(var(--marker-pill-h, 220), var(--marker-pill-s, 56%), var(--marker-pill-l, 90%)) !important;
  color: #111 !important;
  -webkit-text-fill-color: #111 !important;
  text-shadow: none;
  padding: calc(0.16rem + 1px) 0.58rem calc(0.16rem - 1px) !important;
  font-size: 0.79rem !important;
  font-weight: 500 !important;
  line-height: 1.18 !important;
}

.list-marker-filter-pill:hover:not(:disabled),
.list-marker-filter-pill:focus-visible:not(:disabled) {
  background: hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 4%), calc(var(--marker-pill-l, 90%) - 2%)) !important;
  color: #111 !important;
  -webkit-text-fill-color: #111 !important;
  border-color: hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 2%), calc(var(--marker-pill-l, 90%) - 18%)) !important;
}

.list-marker-filter-pill.is-include {
  background: hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 10%), 79%) !important;
  border-color: hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 4%), 50%) !important;
  color: #111 !important;
  -webkit-text-fill-color: #111 !important;
  font-weight: 700 !important;
}

.list-marker-filter-pill.is-include:hover:not(:disabled),
.list-marker-filter-pill.is-include:focus-visible:not(:disabled) {
  background: hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 10%), 79%) !important;
  border-color: hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 4%), 50%) !important;
  color: #111 !important;
  -webkit-text-fill-color: #111 !important;
}

.list-marker-filter-pill.is-exclude {
  background: color-mix(in srgb, hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 14%), 80%) 42%, #ffb8b3 58%) !important;
  border-color: color-mix(in srgb, hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 6%), 52%) 36%, #a11b14 64%) !important;
  color: #111 !important;
  -webkit-text-fill-color: #111 !important;
  font-weight: 700 !important;
}

.list-marker-filter-pill.is-exclude:hover:not(:disabled),
.list-marker-filter-pill.is-exclude:focus-visible:not(:disabled) {
  background: color-mix(in srgb, hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 14%), 80%) 42%, #ffb8b3 58%) !important;
  border-color: color-mix(in srgb, hsl(var(--marker-pill-h, 220), calc(var(--marker-pill-s, 56%) + 6%), 52%) 36%, #a11b14 64%) !important;
  color: #111 !important;
  -webkit-text-fill-color: #111 !important;
}

.list-tiles {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

.list-tile {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.65rem 0.72rem;
  background: var(--card-bg);
  box-shadow: 0 1px 1px color-mix(in srgb, var(--theme_dark, #172553) 9%, transparent);
  aspect-ratio: auto;
  min-height: 13.5rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.list-tile-content {
  flex: 0 0 auto;
  min-height: 0;
}

.list-tile-image-wrap {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 10px;
  overflow: hidden;
  background: color-mix(in srgb, var(--post-card-bg-single, #fff) 84%, var(--bg, #fff) 16%);
  margin-bottom: 0.42rem;
}

.list-tile-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.list-tile-main {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.26rem;
  min-width: 0;
  width: 100%;
  margin-top: 0.3rem;
  text-align: center;
  padding-top: 0.28rem;
}

.list-tile-label {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.16rem;
  min-width: 0;
}

.list-tile-text {
  min-width: 0;
}

.list-tile-description {
  min-width: 0;
  font-size: 0.68rem;
  line-height: 1.2;
  color: var(--muted-text, #5c6170);
}

.list-tile-cart-row {
  display: flex;
  justify-content: center;
  margin-top: 0.34rem;
}

.list-tile-date {
  margin-top: 0.38rem;
  font-size: 0.8rem;
  color: var(--muted-text, #5c6170);
}

.list-tile-children {
  margin: 0.5rem 0 0;
  padding-left: 1rem;
}

.list-tile-children li {
  margin: 0 0 0.24rem;
}

.list-tile-child-text {
  min-width: 0;
}

.list-page-shell .is-post-url-linked {
  text-decoration-line: none;
}

.list-page-shell .is-post-url-linked:hover,
.list-page-shell .is-post-url-linked:focus-visible {
  text-decoration-line: underline;
}

.list-entry-cart-btn {
  display: none !important;
  width: fit-content;
  min-width: 0;
  height: 1.72rem;
  padding: 0 0.6rem !important;
  border-radius: 999px !important;
  border: 1px solid color-mix(in srgb, var(--theme_green, #2f8a5c) 48%, var(--border, #c8d4f3) 52%) !important;
  background: color-mix(in srgb, var(--theme_green, #2f8a5c) 15%, transparent) !important;
  color: color-mix(in srgb, var(--theme_green, #2f8a5c) 80%, #15281f 20%) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--theme_green, #2f8a5c) 80%, #15281f 20%);
  font-size: 0.72rem !important;
  line-height: 1 !important;
  white-space: nowrap;
}

.list-entry-cart-btn.is-price-active {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
}

.list-entry-cart-btn:hover,
.list-entry-cart-btn:focus-visible {
  background: color-mix(in srgb, var(--theme_green, #2f8a5c) 22%, transparent) !important;
  border-color: color-mix(in srgb, var(--theme_green, #2f8a5c) 62%, var(--border, #c8d4f3) 38%) !important;
}

.list-entry-cart-btn-tile {
  margin-top: 0;
}

@media (max-width: 980px) {
  .list-tiles {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .list-entry-first-line.has-cart-button {
    padding-right: 6rem;
  }
}

@media (max-width: 640px) {
  .list-tiles {
    grid-template-columns: 1fr;
  }
}

.nostr-page-extras-editor {
  display: grid;
  gap: 0.7rem;
  margin: 0 0 0.9rem;
  padding: 0.6rem 0.7rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--card-bg);
}

.nostr-page-extras-heading {
  margin: 0;
  font-size: 0.92rem;
}

.nostr-page-extra-edit {
  display: grid;
  gap: 0.3rem;
}

.nostr-page-extra-controls {
  display: inline-flex;
  justify-content: flex-end;
}

.nostr-page-extra-edit > span:first-child {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  color: var(--muted-text, #4f617f);
  font-size: 0.8rem;
}

.nostr-page-scope-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid var(--border);
  padding: 0.06rem 0.42rem;
  font-size: 0.7rem;
  line-height: 1.15;
  letter-spacing: 0.01em;
  color: var(--muted-text, #4f617f);
  background: color-mix(in srgb, var(--card-bg) 78%, transparent);
}

.nostr-page-scope-pill.is-nostr {
  border-color: color-mix(in srgb, var(--theme_green, #2f8a5c) 45%, var(--border) 55%);
  color: color-mix(in srgb, var(--theme_green, #2f8a5c) 82%, #102b1c 18%);
  background: color-mix(in srgb, var(--theme_green, #2f8a5c) 13%, transparent);
}

.nostr-page-scope-pill.is-local {
  border-color: color-mix(in srgb, var(--accent, #2d4f8c) 36%, var(--border) 64%);
  color: color-mix(in srgb, var(--accent, #2d4f8c) 78%, #12284f 22%);
  background: color-mix(in srgb, var(--accent, #2d4f8c) 11%, transparent);
}

.nostr-page-extra-edit select {
  width: auto;
  min-width: 0;
  height: 2rem;
}

.nostr-page-extra-edit textarea {
  width: min(100%, 64rem);
  min-height: 5.2rem;
  max-height: 20rem;
  resize: vertical;
  box-sizing: border-box;
  padding: 0.45rem 0.58rem;
}

.nostr-page-extra {
  margin: 0 0 1rem;
}

.nostr-page-extra:last-child {
  margin-bottom: 0;
}

.nip23-product-card {
  margin: 0 0 1rem;
  padding: 0.68rem 0.76rem;
  border: 1px solid var(--border, #c8d4f3);
  border-radius: 10px;
  background: var(--card-bg);
}

.nip23-product-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.48rem;
}

.nip23-product-type-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent, #3158a4) 38%, var(--border, #c8d4f3) 62%);
  background: color-mix(in srgb, var(--accent, #3158a4) 10%, transparent);
  color: color-mix(in srgb, var(--accent-dark, #1f3f83) 80%, #162849 20%);
  font-size: 0.72rem;
  line-height: 1.1;
  padding: 0.08rem 0.5rem;
}

.nip23-product-prices {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, max-content));
  gap: 0.42rem 0.88rem;
  margin-bottom: 0.58rem;
}

.nip23-product-prices > div {
  display: inline-flex;
  flex-direction: column;
  gap: 0.08rem;
}

.nip23-product-prices span {
  color: var(--muted-text, #4f617f);
  font-size: 0.78rem;
}

.nip23-product-prices strong {
  font-size: 0.96rem;
}

.nip23-product-actions {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.42rem;
}

.nip23-product-btn {
  width: fit-content;
  min-width: 0;
  height: 1.98rem;
  padding: 0 0.72rem;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--theme_green, #2f8a5c) 46%, var(--border, #c8d4f3) 54%);
  background: color-mix(in srgb, var(--theme_green, #2f8a5c) 12%, transparent) !important;
  color: color-mix(in srgb, var(--theme_green, #2f8a5c) 82%, #13241b 18%) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--theme_green, #2f8a5c) 82%, #13241b 18%);
  text-decoration: none;
  font-size: 0.82rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
}

.nip23-product-btn:hover,
.nip23-product-btn:focus-visible {
  background: color-mix(in srgb, var(--theme_green, #2f8a5c) 18%, transparent) !important;
  border-color: color-mix(in srgb, var(--theme_green, #2f8a5c) 58%, var(--border, #c8d4f3) 42%);
}

.nip23-product-btn-primary {
  border-color: color-mix(in srgb, var(--accent, #3158a4) 44%, var(--border, #c8d4f3) 56%);
  background: color-mix(in srgb, var(--accent, #3158a4) 14%, transparent) !important;
  color: color-mix(in srgb, var(--accent-dark, #1f3f83) 84%, #12254a 16%) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--accent-dark, #1f3f83) 84%, #12254a 16%);
}

.nip23-product-btn-primary:hover,
.nip23-product-btn-primary:focus-visible {
  background: color-mix(in srgb, var(--accent, #3158a4) 20%, transparent) !important;
  border-color: color-mix(in srgb, var(--accent, #3158a4) 58%, var(--border, #c8d4f3) 42%);
}

.nip23-product-editor {
  margin: 0.15rem 0 0.2rem;
  padding: 0.62rem 0.68rem;
  border: 1px solid var(--border, #c8d4f3);
  border-radius: 10px;
  background: color-mix(in srgb, var(--card-bg, #fff) 88%, var(--nav-link-hover, #e8edff) 12%);
}

.nip23-product-editor h4 {
  margin: 0 0 0.52rem;
  font-size: 0.9rem;
}

.nip23-product-enable-row {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0 0 0.58rem;
  color: var(--muted-text, #4f617f);
  font-size: 0.82rem;
}

.nip23-product-enable-row input[type="checkbox"] {
  margin: 0;
}

.nip23-product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, max-content));
  gap: 0.5rem 0.78rem;
}

.nip23-product-grid label {
  display: grid;
  gap: 0.24rem;
  font-size: 0.8rem;
  color: var(--muted-text, #4f617f);
}

.nip23-product-grid input[type="text"],
.nip23-product-grid input[type="number"],
.nip23-product-grid select {
  min-width: 11.2rem;
  width: auto;
  max-width: 20rem;
  height: 2rem;
  padding: 0.35rem 0.55rem;
}

.public-ranking-shell .list-page-head {
  margin-bottom: 0.5rem;
}

#public-ranking-title {
  display: flex;
  width: 100%;
  align-items: baseline;
  gap: 0;
}

.public-ranking-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  margin: 0 0 0.85rem;
}

.public-ranking-controls label {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--muted-text, #4f617f);
  font-size: 0.84rem;
}

.public-ranking-controls select {
  width: auto;
  min-width: 9.5rem;
  height: 2rem;
}

.public-ranking-meta {
  margin: 0;
  color: var(--muted-text, #4f617f);
  font-size: 0.82rem;
}

.public-ranking-editor {
  margin: 0 0 0.9rem;
  padding: 0.46rem 0.58rem 0.5rem;
  border: 0;
  border-radius: 10px;
  background: color-mix(in srgb, var(--card-bg, #f8fbff) 90%, var(--nav-link-hover, #e8edff) 10%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.public-ranking-editor h3 {
  margin: 0 0 0.34rem;
  font-size: 0.76rem;
}

.public-ranking-editor-grid {
  display: grid;
  grid-template-columns: minmax(0, max-content);
  gap: 0.48rem;
}

.public-ranking-editor-grid label {
  display: grid;
  grid-template-columns: minmax(220px, max-content) auto;
  align-items: center;
  column-gap: 0.7rem;
  color: var(--muted-text, #4f617f);
  font-size: 0.8rem;
}

.public-ranking-editor-grid input[type="text"],
.public-ranking-editor-grid input[type="number"],
.public-ranking-editor-grid select {
  min-width: 11rem;
  width: auto;
  max-width: 18rem;
  height: 2rem;
  padding: 0.35rem 0.55rem;
}

.public-ranking-editor-grid input[type="checkbox"] {
  margin: 0;
  justify-self: start;
}

.public-ranking-editor-grid textarea {
  width: min(100%, 56rem);
  min-height: 5rem;
  padding: 0.42rem 0.58rem;
  resize: vertical;
}

.public-ranking-editor-grid .public-ranking-editor-wide {
  grid-column: 1 / -1;
}

.public-ranking-submit {
  margin: 0 0 0.95rem;
}

.public-ranking-submit-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
}

.public-ranking-submit-toolbar-left,
.public-ranking-submit-toolbar-right {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

.public-ranking-submit-toolbar-left {
  min-width: 0;
  flex-wrap: wrap;
}

.public-ranking-submit-toolbar-right {
  margin-left: auto;
  justify-content: flex-end;
}

.public-ranking-submit-label {
  color: var(--primary);
}

.public-ranking-submit-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}

.public-ranking-submit-inline {
  display: grid;
  grid-template-columns: minmax(14rem, 1fr) auto auto auto;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.48rem;
}

.public-ranking-submit-inline input[type="text"],
.public-ranking-submit-inline select {
  min-width: 0;
  width: auto;
  height: 2rem;
  padding: 0.35rem 0.55rem;
}

.public-ranking-submit-inline .list-admin-primary-btn {
  width: auto;
  min-width: 0;
}

.public-ranking-submit-inline .public-ranking-submit-add {
  height: 2rem;
  padding: 0.3rem 0.58rem;
  line-height: 1.05;
  font-size: 0.86rem;
  border-radius: 8px;
}

.list-public-submit {
  margin: 0 0 1rem;
}

.list-public-submit-top {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.list-public-submit-toggle {
  appearance: none;
  -webkit-appearance: none;
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid var(--admin-border, var(--border));
  border-radius: 999px;
  background: var(--surface-raised, var(--admin-surface, var(--post-card-bg-single)));
  color: var(--accent, #2f4aa6);
  font-size: 1.2rem;
  line-height: 1;
  font-weight: 700;
  cursor: pointer;
}

.list-public-submit-toggle:hover:not(:disabled),
.list-public-submit-toggle:focus-visible:not(:disabled) {
  border-color: var(--accent, #2f4aa6);
  background: var(--nav-link-hover, rgba(47, 74, 166, 0.1));
}

.list-public-submit-toggle:disabled {
  color: var(--muted-text, #7a8495);
  cursor: default;
  opacity: 0.65;
}

.list-public-submit-reveal {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  transform: translateY(-0.28rem);
  transition: grid-template-rows 220ms ease, opacity 180ms ease, transform 220ms ease;
}

.list-public-submit.is-expanded .list-public-submit-reveal {
  grid-template-rows: 1fr;
  opacity: 1;
  transform: translateY(0);
}

.list-public-submit-inline {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  overflow: hidden;
  padding-top: 0.58rem;
}

.list-public-submit-inline input {
  flex: 1 1 18rem;
  min-width: min(100%, 14rem);
}

.list-public-submit-add {
  width: auto;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.36rem;
  min-width: 3.35rem;
}

.list-public-submit-add.is-loading {
  cursor: wait;
}

.list-public-submit-add .save-spinner {
  width: 0.78rem;
  height: 0.78rem;
}

.list-entry-vote-controls {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.04rem;
  align-self: stretch;
  margin: -0.18rem 0;
}

.list-entry-vote-btn {
  appearance: none;
  -webkit-appearance: none;
  width: 1.55rem;
  height: 1.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent !important;
  color: var(--list-vote-idle-color, #c9ced8);
  line-height: 1;
  transition: none !important;
  animation: none !important;
  transform: none !important;
}

.list-entry-vote-btn.is-upvote.is-active,
.list-entry-vote-btn.is-upvote:hover:not(:disabled) {
  color: var(--list-vote-up-color, #2c8b6e);
  background: transparent !important;
}

.list-entry-vote-btn.is-upvote.is-stale {
  color: var(--list-vote-up-stale-color, #6e9586);
  background: transparent !important;
}

.list-entry-vote-btn.is-downvote.is-active,
.list-entry-vote-btn.is-downvote:hover:not(:disabled) {
  color: var(--list-vote-down-color, #2f4aa6);
  background: transparent !important;
}

.list-entry-vote-btn.is-downvote.is-stale {
  color: var(--list-vote-down-stale-color, #718bad);
  background: transparent !important;
}

.list-entry-vote-btn:disabled {
  color: var(--list-vote-disabled-color, #c9ced8);
  -webkit-text-fill-color: var(--list-vote-disabled-color, #c9ced8);
  cursor: default;
}

.list-entry-vote-icon {
  width: 1.05rem;
  height: 1.05rem;
  display: block;
  filter: drop-shadow(0 0.08rem 0.08rem rgba(28, 24, 18, 0.34));
}

.list-entry-score {
  min-width: 1.7rem;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-size: 0.78rem;
  line-height: 1.05;
  font-weight: 700;
  color: var(--muted-text, #4f617f);
  cursor: default;
  user-select: none;
  -webkit-user-select: none;
}

.public-ranking-submit-cancel {
  border: 0;
  background: transparent !important;
  color: var(--muted-text, #4f617f) !important;
  -webkit-text-fill-color: var(--muted-text, #4f617f);
  padding: 0.25rem 0.35rem;
  border-radius: 8px;
  line-height: 1.3;
}

.public-ranking-submit-cancel:hover,
.public-ranking-submit-cancel:focus-visible {
  background: var(--light-bg, #eef3ff) !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  box-shadow: none;
}

.public-ranking-submit-advanced-toggle {
  border: 0;
  background: transparent !important;
  color: var(--muted-text, #4f617f) !important;
  -webkit-text-fill-color: var(--muted-text, #4f617f);
  padding: 0.25rem 0.35rem;
  border-radius: 8px;
  line-height: 1.3;
  font-size: 0.84rem;
}

.public-ranking-submit-advanced-toggle:hover,
.public-ranking-submit-advanced-toggle:focus-visible {
  background: var(--light-bg, #eef3ff) !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  box-shadow: none;
}

.public-ranking-submit-advanced {
  margin-top: 0.45rem;
}

.public-ranking-submit-more {
  margin-top: 0.45rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-raised-strong, #fff);
}

.public-ranking-submit-extras {
  margin-top: 0.45rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
  align-items: flex-start;
  justify-content: flex-end;
}

.public-ranking-submit-more-compact {
  order: 1;
  flex: 0 0 auto;
  margin-top: 0;
}

.public-ranking-submit-more-compact[open] {
  order: 2;
  flex: 1 1 100%;
  width: 100%;
}

.public-ranking-submit-more > summary {
  cursor: pointer;
  list-style: none;
  padding: 0.3rem 0.46rem;
  color: var(--muted-text, #4f617f);
  font-size: 0.75rem;
  line-height: 1.2;
}

.public-ranking-submit-more > summary::-webkit-details-marker {
  display: none;
}

.public-ranking-submit-more[open] > summary {
  border-bottom: 1px solid var(--border);
}

.public-ranking-submit-grid {
  display: grid;
  grid-template-columns: minmax(220px, max-content);
  gap: 0.52rem 0.62rem;
  padding: 0.52rem;
}

.public-ranking-submit-grid label {
  display: grid;
  gap: 0.22rem;
  color: var(--muted-text, #4f617f);
  font-size: 0.8rem;
}

.public-ranking-submit-grid input[type="text"],
.public-ranking-submit-grid input[type="url"],
.public-ranking-submit-grid select {
  width: auto;
  min-width: 12rem;
  max-width: 22rem;
  height: 2rem;
  padding: 0.35rem 0.55rem;
}

.public-ranking-submit-grid textarea {
  width: min(100%, 56rem);
  min-height: 4.5rem;
  resize: vertical;
  padding: 0.42rem 0.58rem;
}

.public-ranking-submit-wide {
  grid-column: 1 / -1;
}

.public-ranking-submit-hint {
  font-size: 0.8rem;
  color: var(--muted-text, #4f617f);
}

@media (max-width: 900px) {
  .public-ranking-submit-inline {
    grid-template-columns: minmax(0, 1fr);
  }

  .public-ranking-submit-extras {
    flex-direction: column;
    align-items: stretch;
  }

  .public-ranking-submit-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.public-ranking-moderation-toast {
  margin: 0 0 0.85rem;
  border: 1px solid var(--status-warn-border, #f9a825);
  border-radius: 10px;
  background: var(--status-warn-bg, #fff8e1);
}

.public-ranking-moderation-toast > summary {
  cursor: pointer;
  list-style: none;
  padding: 0.5rem 0.6rem;
  font-weight: 700;
}

.public-ranking-moderation-toast > summary::-webkit-details-marker {
  display: none;
}

.public-ranking-pending-list {
  padding: 0 0.58rem 0.58rem;
  display: grid;
  gap: 0.54rem;
}

.public-ranking-pending-item {
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface-raised-strong, #fff);
  padding: 0.48rem 0.56rem;
  display: grid;
  gap: 0.34rem;
}

.public-ranking-pending-item header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.45rem;
}

.public-ranking-pending-item header code {
  font-size: 0.72rem;
  color: var(--muted-text, #4f617f);
}

.public-ranking-pending-item label {
  display: grid;
  gap: 0.2rem;
  color: var(--muted-text, #4f617f);
  font-size: 0.77rem;
}

.public-ranking-pending-item input[type="text"] {
  width: min(100%, 32rem);
  height: 2rem;
  padding: 0.35rem 0.55rem;
}

.public-ranking-pending-item textarea {
  width: min(100%, 42rem);
  min-height: 4rem;
  resize: vertical;
  padding: 0.42rem 0.58rem;
}

.public-ranking-pending-actions {
  display: inline-flex;
  gap: 0.44rem;
}

.public-ranking-pending-actions button {
  width: auto;
  min-width: 0;
}

.public-ranking-danger {
  border-color: var(--status-error-border, #e53935) !important;
  color: var(--status-error-text, #8f1316) !important;
}

.public-ranking-level {
  list-style: decimal;
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.52rem;
}

.public-ranking-level .public-ranking-level {
  margin-top: 0.4rem;
  padding-left: 1.25rem;
}

.public-ranking-item {
  margin: 0;
}

.public-ranking-node {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-raised-strong, #fff);
  padding: 0.52rem 0.64rem;
}

.public-ranking-node-head {
  display: flex;
  justify-content: space-between;
  gap: 0.55rem;
  align-items: center;
}

.public-ranking-node-title-wrap {
  display: inline-flex;
  gap: 0.5rem;
  align-items: center;
}

.public-ranking-node-title {
  margin: 0;
  font-size: 0.95rem;
}

.public-ranking-status {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: 0.72rem;
  padding: 0.14rem 0.46rem;
  border: 1px solid var(--border);
  color: var(--muted-text, #4f617f);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.public-ranking-status.status-pending {
  border-color: var(--status-warn-border, #f9a825);
  color: var(--status-warn-text, #7c5a00);
}

.public-ranking-status.status-rejected {
  border-color: var(--status-error-border, #e53935);
  color: var(--status-error-text, #8f1316);
}

.public-ranking-node-actions button {
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  border-radius: 8px;
  padding: 0;
}

.public-ranking-metrics {
  margin: 0.42rem 0 0;
  display: inline-grid;
  grid-template-columns: repeat(4, max-content);
  gap: 0.4rem 0.68rem;
}

.public-ranking-metrics div {
  display: inline-flex;
  gap: 0.22rem;
  align-items: baseline;
}

.public-ranking-metrics dt {
  margin: 0;
  font-size: 0.73rem;
  color: var(--muted-text, #4f617f);
}

.public-ranking-metrics dd {
  margin: 0;
  font-weight: 700;
  font-size: 0.78rem;
}

.public-ranking-node-summary {
  margin: 0.42rem 0 0;
  font-size: 0.84rem;
}

.public-ranking-node-content {
  margin-top: 0.5rem;
}

.public-ranking-node-content > :first-child {
  margin-top: 0;
}

.public-ranking-node-content > :last-child {
  margin-bottom: 0;
}

.public-ranking-node-links {
  margin: 0.48rem 0 0;
  font-size: 0.82rem;
}

.public-ranking-vote-note {
  margin: 0.4rem 0 0;
  color: var(--muted-text, #4f617f);
  font-size: 0.75rem;
}

.contact-inline-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 0.6rem;
  margin-bottom: 0.55rem;
}

.contact-inline-toolbar-spacer {
  min-height: 1px;
}

.contact-inline-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, max-content));
  gap: 0.5rem;
}

.contact-inline-meta label {
  display: grid;
  gap: 0.2rem;
  font-size: 0.8rem;
  color: var(--muted-text, #4f617f);
}

.contact-inline-meta input[type="text"] {
  min-width: 14rem;
  max-width: 28rem;
  height: 2rem;
  padding: 0.35rem 0.55rem;
}

.contact-inline-toolbar-right button {
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--text);
}

.contact-inline-toolbar-right button:hover,
.contact-inline-toolbar-right button:focus-visible {
  background: var(--light-bg, #eef3ff);
}

.contact-inline-head {
  display: grid;
  grid-template-columns: minmax(110px, 180px) 1fr minmax(150px, max-content) 2rem;
  gap: 0.45rem;
  margin: 0 0 0.45rem;
  color: var(--muted-text, #4f617f);
  font-size: 0.76rem;
}

.contact-inline-rows {
  display: grid;
  gap: 0.46rem;
}

.contact-inline-row {
  display: grid;
  grid-template-columns: minmax(110px, 180px) 1fr minmax(150px, max-content) 2rem;
  gap: 0.45rem;
  align-items: center;
}

.contact-inline-row input[type="text"],
.contact-inline-row select {
  width: 100%;
  min-width: 0;
  height: 2rem;
  padding: 0.35rem 0.55rem;
}

.contact-profile-table-wrap {
  margin: 0.38rem 0 0.2rem;
  border: 0;
  border-radius: 0;
  overflow: visible;
  background: transparent;
}

.contact-section-heading {
  display: flex;
  align-items: center;
  gap: 0.72rem;
  margin: 1.2rem 0 0.42rem;
  border-bottom: 0 !important;
  border-image: none !important;
  padding-bottom: 0;
  color: var(--text, #243046);
  font-size: 1.05rem;
  line-height: 1.24;
}

.contact-section-heading:first-child {
  margin-top: 0.1rem;
}

.contact-section-heading span {
  display: inline-block;
  flex: 0 0 auto;
  border-bottom: 2px solid var(--accent, var(--border));
  border-image-slice: 1;
  border-image-source: linear-gradient(90deg, var(--accent, var(--border)) 0%, var(--primary, var(--accent, var(--border))) 100%);
  padding-bottom: 0.08rem;
  text-decoration: none !important;
}

.contact-archived-group {
  margin: 0.56rem 0 0.2rem;
}

.contact-archived-group > summary {
  list-style: none;
}

.contact-archived-group > summary::-webkit-details-marker {
  display: none;
}

.contact-archived-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.34rem;
  cursor: pointer;
  user-select: none;
  text-align: center;
  color: var(--muted-text, #4f617f);
  font-size: 0.88rem;
  font-weight: 600;
  padding: 0.16rem 0.2rem;
}

.contact-archived-toggle::before {
  content: "▾";
  font-size: 0.86rem;
  line-height: 1;
  transform: translateY(-0.02rem);
}

.contact-profile-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

.contact-profile-head-cell {
  padding: 0.12rem 0.78rem 0.22rem;
  color: var(--muted-text, #4f617f);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  text-transform: none;
  text-align: center;
  vertical-align: bottom;
}

.contact-profile-head-cell-handle {
  width: 1.9rem;
  padding-left: 0.12rem;
  padding-right: 0;
}

.contact-profile-head-cell-platform {
  width: 7.6rem;
}

.contact-profile-head-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 8.6rem 2.2rem;
  align-items: end;
  gap: 0.7rem;
  width: 100%;
}

.contact-profile-head-grid > span {
  display: inline-block;
  text-align: center;
}

.contact-head-add-row {
  grid-column: 3;
  width: 1.78rem;
  min-width: 1.78rem;
  height: 1.78rem;
  padding: 0;
  margin-left: 0;
  justify-self: center;
}

.contact-profile-head-contact {
  grid-column: 1;
}

.contact-profile-head-qualifier {
  grid-column: 2;
  text-align: center;
}

.contact-profile-table.is-editing {
  table-layout: fixed;
}

.contact-profile-row + .contact-profile-row .contact-platform-cell,
.contact-profile-row + .contact-profile-row .contact-value-cell {
  border-top: 0;
}

.contact-platform-cell {
  width: 7.6rem;
  padding: 0.56rem 0.78rem;
  text-align: left;
  vertical-align: top;
  font-weight: 700;
  font-size: 0.96rem;
  color: var(--text, #243046);
  text-transform: lowercase;
  white-space: nowrap;
}

.contact-platform-cell::after {
  content: "";
}

.contact-platform-cell .contact-inline-open,
.contact-platform-cell .contact-inline-input {
  margin-right: 0.1rem;
}

.contact-handle-cell {
  width: 1.9rem;
  padding: 0.56rem 0 0.56rem 0.12rem;
  vertical-align: top;
}

.contact-drag-handle {
  width: 1.9rem;
  min-width: 1.9rem;
  height: 2rem;
  padding: 0;
  color: color-mix(in srgb, var(--text, #243046) 72%, transparent);
  cursor: grab;
  touch-action: none;
}

.contact-drag-handle:active {
  cursor: grabbing;
}

.contact-drag-handle:hover,
.contact-drag-handle:focus-visible {
  color: var(--text, #243046);
}

.contact-drag-handle-icon {
  display: block;
}

.contact-value-cell {
  padding: 0.56rem 0.78rem;
  vertical-align: top;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 8.6rem 2.2rem;
  align-items: start;
  gap: 0.7rem;
}

.contact-value-main {
  grid-column: 1;
  min-width: 0;
  font-size: 0.95rem;
  overflow-wrap: anywhere;
  line-height: 1.5;
}

.contact-inline-open {
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
  margin: 0;
  text-align: left;
  line-height: 1.45;
  width: fit-content;
  max-width: 100%;
  font-weight: 400;
}

.contact-platform-open,
.contact-value-open {
  width: 100%;
}

.contact-platform-open {
  font-weight: 700;
  font-size: 0.96rem;
}

.contact-value-open {
  grid-column: 1;
  font-size: 0.95rem;
}

.contact-inline-open-value {
  display: inline-block;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.contact-inline-open:hover .contact-inline-open-value,
.contact-inline-open:focus-visible .contact-inline-open-value {
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.contact-platform-open:hover .contact-inline-open-value,
.contact-platform-open:focus-visible .contact-inline-open-value,
.contact-value-open:hover .contact-inline-open-value,
.contact-value-open:focus-visible .contact-inline-open-value {
  text-decoration: none;
}

.contact-inline-open:hover,
.contact-inline-open:focus-visible {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.contact-inline-input {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  height: 2rem;
  padding: 0.35rem 0.55rem;
}

.contact-value-inline-input {
  grid-column: 1;
  font-size: 0.95rem;
}

.contact-inline-select {
  width: fit-content;
  min-width: 8.2rem;
  max-width: 100%;
  height: 2rem;
}

.contact-qualifier-select {
  grid-column: 2;
  justify-self: stretch;
  width: 100%;
  min-width: 0;
}

.contact-row-delete {
  grid-column: 3;
  justify-self: center;
  width: 1.78rem;
  min-width: 1.78rem;
  height: 1.78rem;
  transform: translateY(-2px);
  padding: 0;
  margin-left: 0;
}

.contact-delete-icon {
  display: block;
  width: 1.02rem;
  height: 1.02rem;
  line-height: 1;
}

.contact-profile-row {
  transition: background-color 0.15s ease;
}

.contact-profile-row.is-drag-over {
  position: relative;
  background: transparent;
}

.contact-profile-row.is-drag-over-before {
  box-shadow: inset 0 2px 0 var(--accent, #2f4aa6);
}

.contact-profile-row.is-drag-over-after {
  box-shadow: inset 0 -2px 0 var(--accent, #2f4aa6);
}

.contact-profile-row.is-dragging {
  opacity: 0.55;
}

.contact-value-link {
  color: var(--link, #2f4aa6);
  text-decoration: underline;
  text-decoration-thickness: 0.06em;
  text-underline-offset: 0.12em;
}

button.contact-value-link {
  appearance: none;
  display: inline;
  width: fit-content;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.contact-value-link:hover,
.contact-value-link:focus-visible {
  color: var(--accent, #2f4aa6);
}

.contact-qualifier-pill {
  grid-column: 2;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: center;
  width: fit-content;
  text-align: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent, #2f4aa6) 34%, var(--table-border, #d2def3) 66%);
  background: color-mix(in srgb, var(--accent, #2f4aa6) 9%, transparent);
  color: color-mix(in srgb, var(--text, #243046) 82%, var(--accent, #2f4aa6) 18%);
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1.2;
  padding: 0.17rem 0.5rem;
  white-space: nowrap;
}

.contact-qualifier-open {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.contact-qualifier-pill[data-qualifier="preferred"],
.contact-qualifier-pill[data-qualifier="primary"] {
  border-color: color-mix(in srgb, var(--green, #60a5fa) 62%, var(--table-border, #d2def3) 38%);
  background: color-mix(in srgb, var(--green, #60a5fa) 20%, transparent);
  color: color-mix(in srgb, var(--text, #243046) 72%, var(--green, #60a5fa) 28%);
}

.contact-qualifier-pill[data-qualifier="public"],
.contact-qualifier-pill[data-qualifier="secondary"] {
  border-color: color-mix(in srgb, var(--teal, #2563eb) 56%, var(--table-border, #d2def3) 44%);
  background: color-mix(in srgb, var(--teal, #2563eb) 15%, transparent);
  color: color-mix(in srgb, var(--text, #243046) 74%, var(--teal, #2563eb) 26%);
}

.contact-qualifier-pill[data-qualifier="unpreferred"] {
  border-color: color-mix(in srgb, var(--feed-rss-start, #f8a31f) 58%, var(--table-border, #d2def3) 42%);
  background: color-mix(in srgb, var(--feed-rss-start, #f8a31f) 16%, transparent);
  color: color-mix(in srgb, var(--text, #243046) 72%, var(--feed-rss-end, #ea6b0f) 28%);
}

.contact-qualifier-pill[data-qualifier="archive"] {
  border-color: color-mix(in srgb, var(--purple, #4338ca) 54%, var(--table-border, #d2def3) 46%);
  background: color-mix(in srgb, var(--violet, #a5b4fc) 20%, transparent);
  color: color-mix(in srgb, var(--text, #243046) 72%, var(--purple, #4338ca) 28%);
}

.contact-qualifier-pill[data-qualifier="emergency"] {
  border-color: color-mix(in srgb, var(--danger, #b42318) 62%, var(--table-border, #d2def3) 38%);
  background: color-mix(in srgb, var(--danger, #b42318) 14%, transparent);
  color: color-mix(in srgb, var(--text, #243046) 70%, var(--danger, #b42318) 30%);
}

.secure-chat-panel {
  margin-top: 0;
  margin-bottom: 1rem;
  padding: 1rem;
  border: 1px solid color-mix(in srgb, var(--admin-border, #c7d2fe) 78%, white 22%);
  border-radius: 18px;
  background-color: var(--post-card-bg-single, #fdfdfb);
  background-image: var(--secure-chat-paper-surface);
  background-size: auto, auto, var(--lapidarist-parchment-size, 640px 640px);
  background-position: center, center, center;
  box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
}

.secure-chat-panel:not(.is-chat-started) {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 8.4rem;
}

.secure-chat-panel.is-file-drop-over {
  border-color: color-mix(in srgb, var(--accent, #2f4aa6) 58%, white 42%);
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--accent, #2f4aa6) 18%, transparent),
    0 14px 32px rgba(15, 23, 42, 0.08);
}

.secure-chat-body {
  min-width: 0;
}

.secure-chat-body-inner {
  min-width: 0;
}

.secure-chat-body.is-opening {
  max-height: 42rem;
  overflow: hidden;
  transform-origin: top;
  animation: secure-chat-slide-open 220ms ease-out both;
}

.secure-chat-body.is-opening > .secure-chat-body-inner {
  min-height: 0;
  overflow: hidden;
}

.secure-chat-body.is-closing {
  max-height: 42rem;
  overflow: hidden;
  transform-origin: top;
  animation: secure-chat-slide-close 220ms ease-in both;
}

.secure-chat-body.is-closing > .secure-chat-body-inner {
  min-height: 0;
  overflow: hidden;
}

@keyframes secure-chat-slide-open {
  from {
    max-height: 0;
    opacity: 0;
    transform: translateY(-0.35rem);
  }

  to {
    max-height: 42rem;
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes secure-chat-slide-close {
  from {
    max-height: 42rem;
    opacity: 1;
    transform: translateY(0);
  }

  to {
    max-height: 0;
    opacity: 0;
    transform: translateY(-0.25rem);
  }
}

.secure-chat-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.9rem;
  margin-bottom: 0.95rem;
  overflow: visible;
}

.secure-chat-panel:not(.is-chat-started) .secure-chat-head {
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-bottom: 0;
}

.secure-chat-close-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  min-width: 0;
  flex: 0 0 auto;
  box-sizing: border-box;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--admin-border, #c7d2fe) 70%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--post-card-bg-single, #fff) 80%, white 20%);
  color: var(--muted, #5d4a2f);
  cursor: pointer;
  box-shadow: none;
}

.secure-chat-close-btn svg {
  width: 1rem;
  height: 1rem;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
}

.secure-chat-close-btn:hover,
.secure-chat-close-btn:focus-visible {
  border-color: var(--action-soft-hover-border, #b77753);
  background: var(--action-soft-hover-bg, #f0d7c5);
  color: var(--action-soft-hover-text, #5b2f18);
  outline: 0;
}

.secure-chat-start-gate {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.58rem;
  align-self: center;
  flex: 0 1 auto;
  min-width: 0;
}

.secure-chat-saved-hint {
  color: var(--muted, #6f625d);
  font-size: 0.86rem;
  line-height: 1.25;
  text-align: right;
  white-space: nowrap;
}

.secure-chat-login-gate {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.58rem;
  text-align: center;
}

.secure-chat-login-note {
  margin: 0;
  color: var(--muted, #6f625d);
  font-size: 0.95rem;
  line-height: 1.35;
}

.secure-chat-login-btn,
.secure-chat-attach-button {
  width: fit-content;
}

.secure-chat-login-btn {
  align-self: center;
  padding: 0.36rem 0.74rem !important;
  border-radius: 8px !important;
  border: 1px solid var(--action-soft-border, #c58f6f) !important;
  background: var(--action-soft-bg, #f5e4d7) !important;
  background-image: none !important;
  color: var(--action-soft-text, #6d3a20) !important;
  -webkit-text-fill-color: var(--action-soft-text, #6d3a20);
  box-shadow: none !important;
  font-size: 0.92rem !important;
  font-weight: 400 !important;
  line-height: 1.22 !important;
  min-width: 0 !important;
}

.secure-chat-login-btn:hover:not(:disabled),
.secure-chat-login-btn:focus-visible:not(:disabled) {
  background: var(--action-soft-hover-bg, #f0d7c5) !important;
  border-color: var(--action-soft-hover-border, #b77753) !important;
  color: var(--action-soft-hover-text, #5b2f18) !important;
  -webkit-text-fill-color: var(--action-soft-hover-text, #5b2f18);
}

.secure-chat-login-btn:active:not(:disabled) {
  background: var(--action-soft-active-bg, #e8c9b3) !important;
  border-color: var(--action-soft-active-border, #a86442) !important;
  color: var(--action-soft-active-text, #4d2614) !important;
  -webkit-text-fill-color: var(--action-soft-active-text, #4d2614);
}

.secure-chat-loading {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  align-self: flex-start;
  flex: 0 0 auto;
  width: max-content;
  max-width: 100%;
  padding-right: 0.14rem;
  overflow: visible;
  color: var(--admin-muted, #5f6f92);
  font-size: 0.92rem;
  line-height: 1.22;
  white-space: nowrap;
}

.secure-chat-loading-spinner {
  flex: 0 0 auto;
  box-sizing: border-box;
}

.secure-chat-empty {
  margin: 0;
  color: var(--admin-muted, #5f6f92);
}

.secure-chat-banner {
  margin: 0 0 0.9rem;
  padding: 0.58rem 0.7rem;
  border-radius: 12px;
  border: 1px solid transparent;
  font-size: 0.92rem;
}

.secure-chat-banner.is-error {
  background: var(--danger-soft, rgba(180, 35, 24, 0.14));
  border-color: color-mix(in srgb, var(--danger, #b42318) 36%, white 64%);
  color: var(--danger, #b42318);
}

.secure-chat-banner.is-warn {
  background: color-mix(in srgb, #f6d79c 32%, white 68%);
  border-color: color-mix(in srgb, #8a6a24 40%, white 60%);
  color: #6d531b;
}

.secure-chat-thread {
  display: flex;
  flex-direction: column;
  gap: 0.72rem;
  max-height: 26rem;
  padding: 0.2rem 0.1rem 0.1rem;
  overflow-y: auto;
  overflow-anchor: none;
}

.secure-chat-simplex-info {
  position: sticky;
  top: 0.18rem;
  z-index: 4;
  flex: 0 0 auto;
  align-self: stretch;
  padding: 0.72rem 2.7rem 0.72rem 0.82rem;
  border: 1px solid color-mix(in srgb, #77a9d9 44%, white 56%);
  border-radius: 12px;
  background:
    linear-gradient(180deg, rgba(227, 244, 255, 0.96), rgba(210, 234, 250, 0.96)),
    var(--secure-chat-paper-texture);
  background-size: auto, var(--lapidarist-parchment-size, 640px 640px);
  background-position: center, center;
  color: color-mix(in srgb, var(--admin-text, #0b132b) 82%, #1f6fa8 18%);
  box-shadow: 0 10px 22px rgba(31, 111, 168, 0.14);
}

.secure-chat-simplex-info p {
  margin: 0;
  max-width: 58rem;
  font-size: 0.9rem;
  line-height: 1.45;
}

.secure-chat-simplex-info a {
  color: #1f6fa8;
  font-weight: 600;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.14em;
}

.secure-chat-simplex-dismiss {
  position: absolute;
  top: 0.48rem;
  right: 0.48rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.82rem;
  height: 1.82rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #245f8f;
  cursor: pointer;
}

.secure-chat-simplex-dismiss:hover {
  background: rgba(255, 255, 255, 0.94);
}

.secure-chat-simplex-dismiss:focus-visible {
  outline: 2px solid color-mix(in srgb, #1f6fa8 58%, white 42%);
  outline-offset: 2px;
}

.secure-chat-simplex-dismiss svg {
  width: 1rem;
  height: 1rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
}

.secure-chat-message {
  display: flex;
}

.secure-chat-message.is-outgoing {
  justify-content: flex-end;
}

.secure-chat-bubble {
  max-width: min(34rem, 100%);
  padding: 0.72rem 0.84rem 0.66rem;
  border-radius: 16px;
  background-color: var(--post-card-bg-single, #fdfdfb);
  background-image: none;
  border: 1px solid color-mix(in srgb, var(--admin-border, #c7d2fe) 72%, white 28%);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.05);
}

.secure-chat-message.is-outgoing .secure-chat-bubble {
  background-color: #fff7ef;
  background-image: none;
  border-color: color-mix(in srgb, var(--action-soft-border, #c58f6f) 72%, white 28%);
}

.secure-chat-text {
  margin: 0;
}

.secure-chat-attachment {
  display: grid;
  gap: 0.38rem;
  margin-top: 0.5rem;
  font-size: 0.94rem;
  color: var(--admin-text, #0b132b);
}

.secure-chat-attachment-media {
  display: block;
  width: 100%;
  max-width: min(28rem, 72vw);
  max-height: 22rem;
  border-radius: 10px;
  object-fit: contain;
  background: color-mix(in srgb, var(--admin-surface, #ffffff) 72%, transparent);
}

.secure-chat-attachment-video .secure-chat-attachment-media {
  aspect-ratio: 16 / 9;
}

.secure-chat-attachment-audio {
  display: block;
  width: min(28rem, 100%);
  max-width: 100%;
}

.secure-chat-attachment-file {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  padding: 0.18rem 0;
  color: inherit;
  text-decoration: none;
}

.secure-chat-attachment-file:hover {
  color: var(--accent, #2f4aa6);
}

.secure-chat-attachment-line {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.12rem 0.45rem;
  max-width: 100%;
  min-width: 0;
}

.secure-chat-attachment-name {
  font-weight: 650;
  min-width: 0;
  overflow-wrap: anywhere;
}

.secure-chat-attachment span,
.secure-chat-attachment-meta {
  color: var(--admin-muted, #5f6f92);
}

.secure-chat-attachment-meta {
  flex: 0 0 auto;
}

.secure-chat-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.7rem;
  margin-top: 0.52rem;
  font-size: 0.8rem;
  color: var(--admin-muted, #5f6f92);
}

.secure-chat-status {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
  min-width: 0;
}

.secure-chat-status.is-delivered,
.secure-chat-status.is-sent {
  color: #16803c;
  font-weight: 700;
  letter-spacing: 0;
}

.secure-chat-status-check {
  line-height: 1;
}

.secure-chat-status-spinner {
  width: 0.74rem;
  height: 0.74rem;
  flex: 0 0 auto;
  box-sizing: border-box;
}

.secure-chat-uploads {
  display: grid;
  gap: 0.58rem;
  margin-top: 0.95rem;
  padding-top: 0.95rem;
  border-top: 1px solid color-mix(in srgb, var(--admin-border, #c7d2fe) 68%, white 32%);
}

.secure-chat-upload-row {
  display: grid;
  gap: 0.22rem;
}

.secure-chat-upload-name {
  font-size: 0.94rem;
  font-weight: 600;
}

.secure-chat-upload-meta {
  display: flex;
  justify-content: space-between;
  gap: 0.65rem;
  color: var(--admin-muted, #5f6f92);
  font-size: 0.82rem;
}

.secure-chat-upload-bar {
  height: 0.42rem;
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--light-bg, #e0e7ff) 78%, white 22%);
}

.secure-chat-upload-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #d77f3b, #b55a23);
}

.secure-chat-compose {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid color-mix(in srgb, var(--admin-border, #c7d2fe) 68%, white 32%);
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-items: start;
  gap: 0.5rem;
}

.secure-chat-input-wrap {
  position: relative;
  min-width: 0;
  grid-column: 1;
  grid-row: 1;
}

.secure-chat-input-wrap::after {
  content: "";
  position: absolute;
  left: 1px;
  right: 1px;
  bottom: 1px;
  height: 3.05rem;
  border-radius: 0 0 13px 13px;
  background: rgba(255, 255, 252, 0.98);
  pointer-events: none;
  z-index: 1;
}

.secure-chat-input {
  display: block;
  width: 100%;
  min-height: 6.2rem;
  resize: vertical;
  padding: 0.72rem 0.82rem 3.72rem;
  scroll-padding-bottom: 3.72rem;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--admin-border, #c7d2fe) 80%, white 20%);
  background-color: rgba(255, 255, 252, 0.96);
  background-image: none;
  color: var(--admin-text, #0b132b);
}

.secure-chat-input-wrap.has-pending-files .secure-chat-input {
  min-height: 8.2rem;
  padding-top: 3.62rem;
}

.secure-chat-pending-files {
  position: absolute;
  top: 0.58rem;
  left: 0.62rem;
  right: 0.62rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.38rem;
  max-height: 2.55rem;
  overflow: auto;
  z-index: 2;
}

.secure-chat-pending-file {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  min-width: 0;
  gap: 0.34rem;
  padding: 0.26rem 0.28rem 0.26rem 0.54rem;
  border: 1px solid color-mix(in srgb, var(--admin-border, #c7d2fe) 78%, white 22%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--light-bg, #e0e7ff) 54%, white 46%);
  color: var(--admin-text, #0b132b);
  font-size: 0.82rem;
  line-height: 1.1;
}

.secure-chat-pending-file-name {
  min-width: 0;
  max-width: 12rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 600;
}

.secure-chat-pending-file-meta {
  flex: 0 0 auto;
  color: var(--admin-muted, #5f6f92);
}

.secure-chat-pending-file-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 1.28rem;
  height: 1.28rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--admin-muted, #5f6f92);
  cursor: pointer;
}

.secure-chat-pending-file-remove:hover,
.secure-chat-pending-file-remove:focus-visible {
  background: rgba(255, 255, 255, 0.88);
}

.secure-chat-pending-file-remove svg {
  width: 0.9rem;
  height: 0.9rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.35;
  stroke-linecap: round;
}

.secure-chat-send-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  right: 0.58rem;
  bottom: 0.58rem;
  width: 2.24rem;
  height: 2.24rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: var(--accent, #2f4aa6);
  color: #fff;
  box-shadow: 0 8px 18px color-mix(in srgb, var(--accent, #2f4aa6) 24%, transparent);
  cursor: pointer;
  z-index: 2;
  transition: background-color 0.16s ease, transform 0.16s ease, box-shadow 0.16s ease;
}

.secure-chat-voice-btn {
  appearance: none;
  -webkit-appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  right: 3.08rem;
  bottom: 0.58rem;
  width: 2.08rem;
  height: 2.08rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  background-image: none;
  box-shadow: none;
  color: var(--admin-text, #0b132b);
  cursor: pointer;
  z-index: 2;
  transition: background-color 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.secure-chat-voice-btn:hover:not(:disabled),
.secure-chat-voice-btn:focus-visible:not(:disabled) {
  background: color-mix(in srgb, var(--light-bg, #e0e7ff) 72%, white 28%);
  color: var(--accent, #2f4aa6);
}

.secure-chat-voice-btn.is-locked {
  color: var(--admin-muted, #5f6f92);
}

.secure-chat-voice-btn.is-recording {
  background: transparent;
  color: var(--danger, #b42318);
  transform: scale(1.03);
}

.secure-chat-mic-icon {
  width: 1.04rem;
  height: 1.04rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  pointer-events: none;
}

.secure-chat-send-btn:hover:not(:disabled),
.secure-chat-send-btn:focus-visible:not(:disabled) {
  background: color-mix(in srgb, var(--accent, #2f4aa6) 86%, white 14%);
  box-shadow: 0 10px 22px color-mix(in srgb, var(--accent, #2f4aa6) 30%, transparent);
}

.secure-chat-send-btn:active:not(:disabled) {
  transform: translateY(1px);
}

.secure-chat-send-btn:disabled {
  cursor: progress;
  opacity: 0.78;
}

.secure-chat-send-spinner {
  flex: 0 0 auto;
  width: 0.9rem;
  height: 0.9rem;
  --spinner-track: rgba(255, 255, 255, 0.42);
  --spinner-head: #fff;
}

.secure-chat-send-icon {
  width: 1.08rem;
  height: 1.08rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.secure-chat-attach-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 0.58rem;
  bottom: 0.58rem;
  width: 2.08rem;
  height: 2.08rem;
  padding: 0;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: var(--admin-text, #0b132b);
  cursor: pointer;
  z-index: 2;
  transition: background-color 0.16s ease, color 0.16s ease;
}

.secure-chat-file-input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

.secure-chat-attach-button:hover,
.secure-chat-attach-button:focus-within {
  background: color-mix(in srgb, var(--light-bg, #e0e7ff) 72%, white 28%);
  color: var(--accent, #2f4aa6);
}

.secure-chat-attach-icon {
  width: 1.08rem;
  height: 1.08rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  pointer-events: none;
}

.secure-chat-emoji-button {
  appearance: none;
  -webkit-appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 2.88rem;
  bottom: 0.58rem;
  width: 2.08rem;
  height: 2.08rem;
  padding: 0;
  border-radius: 999px;
  border: 0;
  background: transparent;
  background-image: none;
  box-shadow: none;
  color: var(--admin-text, #0b132b);
  cursor: pointer;
  z-index: 2;
  transition: background-color 0.16s ease, color 0.16s ease;
}

.secure-chat-emoji-button:hover,
.secure-chat-emoji-button:focus-visible {
  background: color-mix(in srgb, var(--light-bg, #e0e7ff) 72%, white 28%);
  color: var(--accent, #2f4aa6);
}

.secure-chat-emoji-icon {
  width: 1.12rem;
  height: 1.12rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  pointer-events: none;
}

.secure-chat-emoji-popover {
  position: absolute;
  left: 0.58rem;
  bottom: 3.08rem;
  z-index: 8;
  width: min(24rem, calc(100vw - 2.2rem));
  max-height: min(31rem, calc(100vh - 7.5rem));
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 0.42rem;
  padding: 0.46rem;
  border: 1px solid color-mix(in srgb, var(--admin-border, #c7d2fe) 82%, white 18%);
  border-radius: 13px;
  background: rgba(255, 255, 252, 0.98);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
}

.secure-chat-emoji-status {
  margin: 0.28rem 0;
  color: var(--admin-muted, #5f6f92);
  font-size: 0.86rem;
}

.secure-chat-emoji-status.is-error {
  color: var(--danger, #b42318);
}

.secure-chat-emoji-search-wrap {
  min-width: 0;
}

.secure-chat-emoji-search {
  width: 100%;
  min-width: 0;
  height: 2.15rem;
  padding: 0 0.72rem;
  border: 0;
  border-radius: 8px;
  background: color-mix(in srgb, var(--light-bg, #e0e7ff) 54%, white 46%);
  color: var(--admin-text, #0b132b);
  font-size: 0.94rem;
}

.secure-chat-emoji-scroll {
  min-width: 0;
  min-height: 17rem;
  height: min(22rem, calc(100vh - 13rem));
  overflow: auto;
  overscroll-behavior: contain;
  padding: 0.12rem 0.08rem 0.34rem;
}

.secure-chat-emoji-section {
  min-width: 0;
  scroll-margin-top: 0.4rem;
}

.secure-chat-emoji-section + .secure-chat-emoji-section {
  margin-top: 0.44rem;
}

.secure-chat-emoji-section h3 {
  position: sticky;
  top: 0;
  z-index: 1;
  margin: 0;
  padding: 0.2rem 0 0.32rem;
  background: rgba(255, 255, 252, 0.98);
  color: var(--admin-muted, #5f6f92);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0;
}

.secure-chat-emoji-grid {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 0.1rem;
}

.secure-chat-emoji-choice {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1;
  min-width: 0;
  width: 100%;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent;
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
  font-size: 1.68rem;
  line-height: 1;
  cursor: pointer;
}

.secure-chat-emoji-choice:hover,
.secure-chat-emoji-choice:focus-visible {
  background: color-mix(in srgb, var(--light-bg, #e0e7ff) 72%, white 28%);
}

.secure-chat-emoji-empty {
  margin: 0.14rem 0 0.32rem;
  color: var(--admin-muted, #5f6f92);
  font-size: 0.86rem;
}

.secure-chat-emoji-section-tabs {
  display: grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  align-items: center;
  gap: 0;
  min-width: 0;
  padding: 0.22rem;
  border-top: 1px solid color-mix(in srgb, var(--admin-border, #c7d2fe) 64%, white 36%);
  border-radius: 0 0 10px 10px;
  background: color-mix(in srgb, var(--light-bg, #e0e7ff) 36%, white 64%);
}

.secure-chat-emoji-section-tabs button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  width: auto;
  height: 2rem;
  padding: 0;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: var(--admin-muted, #5f6f92);
  line-height: 1;
  cursor: pointer;
}

.secure-chat-emoji-section-tabs svg {
  width: 1.14rem;
  height: 1.14rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.secure-chat-emoji-section-tabs button:hover,
.secure-chat-emoji-section-tabs button:focus-visible,
.secure-chat-emoji-section-tabs button.is-active {
  background: rgba(255, 255, 255, 0.94);
  color: var(--accent, #2f4aa6);
}

.secure-chat-compose-hint {
  color: var(--admin-muted, #5f6f92);
  font-size: 0.82rem;
}

.secure-chat-send-shortcut {
  display: inline-flex;
  align-items: center;
  gap: 0.38rem;
  grid-column: 1 / -1;
  grid-row: 2;
  width: fit-content;
}

.secure-chat-send-shortcut input {
  margin: 0;
}

@media (max-width: 760px) {
  .contact-platform-cell {
    width: 7.1rem;
    padding: 0.5rem 0.62rem;
  }

  .contact-handle-cell {
    padding: 0.5rem 0 0.5rem 0.08rem;
  }

  .contact-value-cell {
    padding: 0.5rem 0.62rem;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.4rem;
  }

  .contact-qualifier-select,
  .contact-row-delete,
  .contact-qualifier-pill {
    grid-column: 1;
  }

  .contact-row-delete {
    justify-self: start;
  }

  .contact-qualifier-pill {
    justify-self: start;
  }

  .secure-chat-panel {
    padding: 0.88rem;
    border-radius: 16px;
  }

  .secure-chat-head {
    flex-direction: column;
    align-items: stretch;
  }

  .secure-chat-panel.is-chat-started .secure-chat-head {
    flex-direction: row;
    align-items: flex-start;
  }

  .secure-chat-start-gate {
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .secure-chat-panel:not(.is-chat-started) .secure-chat-start-gate {
    justify-content: center;
  }

  .secure-chat-saved-hint {
    text-align: left;
    white-space: normal;
  }

  .secure-chat-panel:not(.is-chat-started) .secure-chat-saved-hint {
    text-align: center;
  }

  .secure-chat-bubble {
    max-width: 100%;
  }

}

@media (prefers-reduced-motion: reduce) {
  .secure-chat-body.is-opening,
  .secure-chat-body.is-closing {
    animation: none;
    max-height: none;
    overflow: visible;
  }
}

.nav-overflow-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
  margin-left: 0.08rem;
  flex: 0 0 auto;
}

.nav-overflow-menu[hidden] {
  display: none !important;
}

.nav-menu-btn.nav-overflow-btn {
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--button-secondary-bg, var(--nav-button-bg, var(--light-bg)));
  color: var(--text);
  line-height: 1;
  padding: 0;
  min-width: 2.05rem;
  height: 2.05rem;
  width: 2.05rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.nav-menu-btn.nav-overflow-btn svg {
  width: 0.95rem;
  height: 0.95rem;
  position: relative;
  z-index: 1;
}

.nav-overflow-count {
  position: absolute;
  top: 0.08rem;
  right: -0.18rem;
  min-width: 1.12rem;
  height: 1rem;
  padding: 0 0.22rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--tag-muted-bg, #f2f2ef);
  box-shadow: 0 0 0 2px var(--button-secondary-bg, var(--nav-button-bg, var(--light-bg)));
  color: var(--text);
  font-size: 0.63rem;
  font-weight: 700;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
  pointer-events: none;
}

.nav-overflow-count[hidden] {
  display: none;
}

.nav-menu-btn.nav-overflow-btn:hover,
.nav-menu-btn.nav-overflow-btn:focus-visible {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--light-bg);
}

.nav-menu-btn.nav-overflow-btn:hover .nav-overflow-count,
.nav-menu-btn.nav-overflow-btn:focus-visible .nav-overflow-count {
  border-color: currentColor;
  color: currentColor;
  background: var(--light-bg);
  box-shadow: 0 0 0 2px rgba(15, 23, 42, 0.10);
}

.nav-overflow-panel {
  left: auto;
  right: 0;
  max-height: min(60vh, 22rem);
  overflow-y: auto;
  z-index: 70;
}

.nav-overflow-panel.is-viewport-positioned {
  position: fixed;
  right: auto;
  width: max-content;
  min-width: min(10rem, calc(100vw - 1rem));
  max-height: min(60vh, 22rem);
  z-index: 1300;
}

.nav-center a.is-nav-overflow-hidden {
  display: none !important;
}

.nav-user-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.nav-menu-btn {
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--text);
  font-size: 1.2rem;
  line-height: 1;
  font-weight: 600;
  letter-spacing: 0;
  padding: 0;
  width: 2.1rem;
  min-width: 2.1rem;
  height: 2.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: translateY(-1px);
}

.nav-user-menu > .nav-menu-btn,
.post-page-menu-trigger {
  font-size: 0;
  position: relative;
}

.nav-user-menu > .nav-menu-btn > svg,
.post-page-menu-trigger > svg {
  width: 1.05rem;
  height: 1.05rem;
  display: block;
}

.overflow-menu-icon-svg {
  display: block;
  flex: 0 0 auto;
}

.nav-menu-btn:hover {
  background: var(--light-bg);
  color: var(--accent);
  border: 0 !important;
  box-shadow: none !important;
}

.nav-menu-btn:focus-visible {
  outline: 0;
  background: var(--light-bg);
  border: 0 !important;
  box-shadow: none !important;
}

.nav-menu-panel {
  position: absolute;
  top: calc(100% + 0.35rem);
  right: 0;
  min-width: 10rem;
  background: var(--menu-bg);
  background-image: none !important;
  border: 0;
  border-radius: 12px;
  box-shadow: var(--popup-menu-shadow, var(--menu-shadow));
  padding: 0.32rem;
  z-index: 1300;
}

.nav-menu-panel .nav-menu-item,
.nav-login-menu .nav-menu-item,
.nav-menu-item {
  display: block;
  width: 100%;
  border: 0 !important;
  border-radius: 7px;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  color: var(--text) !important;
  -webkit-text-fill-color: currentColor !important;
  text-decoration: none;
  text-align: left;
  padding: 0.44rem 0.58rem;
  font-size: 0.88rem;
  font-weight: 600;
}

.nav-menu-panel .nav-menu-item:hover,
.nav-menu-panel .nav-menu-item:focus-visible,
.nav-login-menu .nav-menu-item:hover,
.nav-login-menu .nav-menu-item:focus-visible {
  border: 0 !important;
  background: var(--menu-hover-bg) !important;
  background-image: none !important;
  color: var(--text) !important;
  -webkit-text-fill-color: currentColor !important;
  text-decoration: none;
  box-shadow: none !important;
  outline: 0;
}

.nav-menu-item-danger {
  color: var(--menu-danger-text);
  -webkit-text-fill-color: currentColor;
}

.nav-menu-panel .nav-menu-item-danger:hover,
.nav-menu-panel .nav-menu-item-danger:focus-visible {
  border: 0 !important;
  background: var(--menu-danger-hover-bg) !important;
  background-image: none !important;
  color: var(--menu-danger-text) !important;
  -webkit-text-fill-color: currentColor !important;
  box-shadow: none !important;
}

.nav-username {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--nav-username-color);
  white-space: nowrap;
  cursor: pointer;
}

.nav-username.active {
  text-decoration: none;
  padding: 0.36rem 0.92rem;
  line-height: 1.15;
  border-radius: var(--nav-pill-radius);
}

.nav-username:not(.active):hover,
.nav-username:not(.active):focus-visible {
  color: var(--nav-username-color) !important;
  background: transparent !important;
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.15em;
}

/* Theme settings panel */
.theme-panel {
  margin: 1.5rem 0 2rem;
  padding: 1.25rem 1.5rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--light-bg);
  box-shadow: 0 12px 30px var(--shadow);
}

.theme-panel label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--text);
}

.theme-panel select {
  width: 100%;
  max-width: 320px;
  padding: 0.6rem 0.75rem;
  border-radius: 8px;
  border: 1px solid var(--select-border);
  background: var(--select-bg);
  color: var(--select-text);
  -webkit-text-fill-color: var(--select-text);
  color-scheme: var(--select-color-scheme);
  font-family: var(--font-family);
  font-size: 0.95rem;
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.06);
}

.theme-panel select[multiple],
.theme-panel select[size] {
  background: var(--select-option-bg);
  color: var(--select-text);
  -webkit-text-fill-color: var(--select-text);
}

.theme-panel select[multiple] option,
.theme-panel select[size] option {
  color: var(--select-text);
  -webkit-text-fill-color: var(--select-text);
}

.theme-panel select option {
  background: var(--select-option-bg);
  color: var(--select-option-text);
  -webkit-text-fill-color: var(--select-option-text);
}

.theme-panel select option:disabled {
  color: var(--select-option-disabled-text);
  -webkit-text-fill-color: var(--select-option-disabled-text);
}

.theme-panel select option:checked {
  background: var(--select-option-selected-bg);
  color: var(--select-option-selected-text);
  -webkit-text-fill-color: var(--select-option-selected-text);
}

.theme-panel select:focus {
  outline: 2px solid transparent;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2);
}

.theme-panel .theme-hint {
  margin: 0.75rem 0 0;
  font-size: 0.9rem;
  color: var(--light-text);
}

/* Login Button in Navigation */
.btn-login {
  display: inline-block;
  background-image: var(--button-primary-overlay), linear-gradient(135deg, var(--button-primary-start) 0%, var(--button-primary-end) 100%);
  color: var(--button-primary-text) !important;
  padding: 0.5rem 1.2rem;
  border-radius: 6px;
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: none !important;
  transition: background 0.2s ease;
  cursor: pointer;
  border: 1px solid var(--button-primary-border);
}

nav.site-nav .btn-login {
  font-size: var(--nav-pill-font-size);
  line-height: var(--nav-pill-line-height);
  /* Match active nav pill total height: nav pills have no border, login has 1px border. */
  padding-block: calc(var(--nav-pill-pad-y) - 1px);
}

.btn-login:hover {
  background-image: var(--button-primary-overlay), linear-gradient(135deg, var(--button-primary-hover-start) 0%, var(--button-primary-hover-end) 100%);
  text-decoration: none;
}

.nav-login-split {
  position: relative;
  display: inline-flex;
  align-items: stretch;
  border-radius: 6px;
  overflow: visible;
  box-shadow: none;
}

.btn-login-main {
  border-radius: 6px 0 0 6px;
  height: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: var(--nav-pill-line-height);
  padding: 0 1rem;
}

.btn-login-caret {
  border-radius: 0 6px 6px 0;
  min-width: 1.42rem;
  width: 1.48rem;
  height: auto;
  padding: calc(var(--nav-pill-pad-y) - 1px) 0;
  border-left: 1px solid var(--button-primary-end);
  font-size: 0.69rem;
  font-weight: 700;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.nav-login-split .btn-login {
  border-color: var(--button-primary-end);
}

.nav-login-menu {
  position: absolute;
  top: calc(100% + 0.35rem);
  right: 0;
  min-width: 14.5rem;
  background: var(--menu-bg);
  background-image: none !important;
  border: 0;
  border-radius: 12px;
  box-shadow: var(--popup-menu-shadow, var(--menu-shadow));
  padding: 0.32rem;
  z-index: 1300;
}

.nav-top-toast-host {
  position: fixed;
  top: calc(3.2rem + env(safe-area-inset-top, 0px));
  left: 50%;
  transform: translateX(-50%);
  z-index: 1500;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  pointer-events: none;
}

.nav-top-toast {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: min(92vw, 34rem);
  padding: 0.52rem 0.82rem;
  border-radius: 10px;
  border: 1px solid var(--toast-info-border);
  background: var(--toast-info-bg);
  color: var(--toast-info-text);
  box-shadow: var(--menu-shadow);
  font-size: 0.9rem;
  font-weight: 600;
  text-align: center;
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity 0.22s ease, transform 0.22s ease;
}

.nav-top-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.nav-top-toast.is-closing {
  opacity: 0;
  transform: translateY(-7px);
}

.nav-top-toast.is-ok {
  border-color: var(--status-ok-border);
  background: var(--status-ok-bg);
  color: var(--status-ok-text);
}

.nav-top-toast.is-warn {
  border-color: var(--status-warn-border);
  background: var(--status-warn-bg);
  color: var(--status-warn-text);
}

.nav-top-toast.is-error {
  border-color: var(--status-error-border);
  background: var(--status-error-bg);
  color: var(--status-error-text);
}

.nav-top-toast.list-vote-error-toast {
  gap: 0.6rem;
  justify-content: space-between;
  pointer-events: auto;
}

.list-vote-error-toast-message {
  min-width: 0;
}

.list-vote-error-toast-copy {
  width: fit-content;
  min-width: max-content;
  padding: 0.24rem 0.5rem;
  border: 1px solid color-mix(in srgb, currentColor 48%, transparent);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.14) !important;
  color: currentColor !important;
  -webkit-text-fill-color: currentColor;
  box-shadow: none !important;
  font: inherit;
  font-size: 0.78rem;
  line-height: 1.1;
}

.list-vote-error-toast-copy:hover,
.list-vote-error-toast-copy:focus-visible {
  background: rgba(255, 255, 255, 0.24) !important;
}

.auth-modal[hidden] {
  display: none;
}

.auth-modal {
  position: fixed;
  inset: 0;
  z-index: 1100;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.18s ease;
}

.auth-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

.auth-modal-backdrop {
  position: absolute;
  inset: 0;
  background: var(--surface-overlay);
  opacity: 0;
  transition: opacity 0.18s ease;
}

.auth-modal.is-open .auth-modal-backdrop {
  opacity: 1;
}

.auth-modal-panel {
  position: relative;
  width: min(560px, calc(100vw - 1.5rem));
  margin: min(6vh, 3rem) auto 0;
  background: var(--modal-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: var(--modal-shadow);
  opacity: 0;
  transform: translateY(10px) scale(0.985);
  transition: opacity 0.2s ease, transform 0.2s ease;
  overflow: hidden;
}

.auth-modal.is-open .auth-modal-panel {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.auth-modal-scroll {
  max-height: calc(100vh - 4rem);
  overflow: auto;
  border-radius: inherit;
  padding: 0.95rem 0.95rem 1rem;
  scrollbar-gutter: stable;
}

.auth-modal-close {
  position: absolute;
  top: 0.68rem;
  right: 0.82rem;
  z-index: 2;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--light-text);
  font-size: 1.4rem;
  line-height: 1;
  width: 2rem;
  height: 2rem;
  padding: 0;
}

.auth-modal-close:hover,
.auth-modal-close:focus-visible {
  background: color-mix(in srgb, var(--border) 28%, transparent);
  color: var(--text);
}

.auth-modal-panel h2 {
  margin: 0.1rem 2.2rem 0.35rem 0;
}

.auth-modal-help {
  margin: 0.25rem 0 0.7rem;
  color: var(--light-text);
  font-size: 0.92rem;
}

.auth-platform-grid {
  margin: 0.62rem 0 0.58rem;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.42rem;
}

.auth-platform-card {
  appearance: none;
  border: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 92%, var(--bg, #f7efe0) 8%);
  color: var(--text);
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 0.45rem;
  min-height: 3.25rem;
  padding: 0.5rem 0.55rem;
  text-align: left;
  box-shadow: none;
}

.auth-platform-card:hover,
.auth-platform-card:focus-visible {
  border-color: color-mix(in srgb, var(--link) 42%, var(--border));
  background: color-mix(in srgb, var(--link) 7%, var(--surface-raised-strong, #fff));
}

.auth-platform-card.is-active {
  border-color: color-mix(in srgb, var(--link) 56%, var(--border));
  background: color-mix(in srgb, var(--link) 12%, var(--surface-raised-strong, #fff));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--link) 34%, transparent);
}

.auth-platform-card-muted {
  opacity: 0.86;
}

.auth-platform-icon {
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  color: color-mix(in srgb, var(--link) 75%, var(--text));
  background: color-mix(in srgb, var(--link) 10%, #fff);
  font-size: 1.05rem;
  font-weight: 800;
}

.auth-platform-icon svg {
  width: 1.16rem;
  height: 1.16rem;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.85;
}

.auth-platform-copy {
  min-width: 0;
  display: grid;
  gap: 0.12rem;
}

.auth-platform-copy strong {
  font-size: 0.88rem;
  line-height: 1.1;
}

.auth-platform-copy span {
  color: var(--light-text);
  font-size: 0.78rem;
  line-height: 1.2;
}

.auth-advanced-toggle {
  appearance: none;
  border: 0;
  background: transparent;
  color: color-mix(in srgb, var(--link) 72%, var(--text));
  cursor: pointer;
  display: block;
  font-size: 0.84rem;
  font-weight: 700;
  margin: -0.24rem 0 0.72rem auto;
  padding: 0.16rem 0.1rem;
  text-decoration: underline;
  text-underline-offset: 0.16em;
  width: fit-content;
}

.auth-advanced-toggle:hover,
.auth-advanced-toggle:focus-visible,
.auth-advanced-toggle.is-active {
  background: transparent !important;
  color: var(--link);
}

.auth-reco-card {
  margin: 0.1rem 0 0.8rem;
  border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 94%, var(--bg, #f7efe0) 6%);
  padding: 0.64rem 0.72rem;
  box-shadow: none;
}

.auth-reco-group {
  display: grid;
  gap: 0.42rem;
  padding-top: 0.58rem;
  margin-top: 0.58rem;
  border-top: 1px solid color-mix(in srgb, var(--border) 68%, transparent);
}

.auth-reco-group:first-of-type {
  padding-top: 0;
  margin-top: 0;
  border-top: 0;
}

.auth-reco-card h3 {
  margin: 0 0 0.42rem;
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  color: var(--text);
  font-size: 0.98rem;
}

.auth-apps-icon {
  width: 1.85rem;
  height: 1.85rem;
  border-radius: 10px;
  display: inline-grid;
  place-items: center;
  background: linear-gradient(135deg, #2563eb, #0f766e 64%, #14b8a6);
  color: #fff;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.18);
}

.auth-apps-icon svg {
  width: 1.02rem;
  height: 1.02rem;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.9;
}

.auth-reco-summary,
.auth-zap-summary {
  margin: 0 0 0.48rem;
  color: var(--light-text);
  font-size: 0.8rem;
  font-weight: 650;
  line-height: 1.2;
}

.auth-zap-updated {
  margin: 0.62rem 0 0;
  color: color-mix(in srgb, var(--light-text) 72%, #94a3b8);
  font-size: 0.72rem;
  line-height: 1.2;
  text-align: center;
}

.auth-reco-apps,
.auth-zap-apps {
  list-style: none;
  margin: 0.46rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.42rem;
}

.auth-reco-apps li,
.auth-zap-apps li {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.auth-reco-app-link,
.auth-zap-app-link {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  color: var(--text);
  text-decoration: none;
}

.auth-reco-app-link:hover,
.auth-reco-app-link:focus-visible,
.auth-zap-app-link:hover,
.auth-zap-app-link:focus-visible {
  text-decoration: underline;
}

.auth-reco-app-icon,
.auth-zap-app-icon {
  width: 1.75rem;
  height: 1.75rem;
  border: 1px solid color-mix(in srgb, var(--link) 16%, var(--border));
  border-radius: 9px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  overflow: hidden;
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 88%, var(--link) 12%);
  color: color-mix(in srgb, var(--link) 82%, var(--text));
}

.auth-reco-app-img,
.auth-zap-app-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.auth-reco-app-icon svg,
.auth-zap-app-icon svg {
  width: 1.12rem;
  height: 1.12rem;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.85;
}

.auth-reco-app-icon svg path,
.auth-zap-app-icon svg path,
.auth-reco-app-icon svg circle,
.auth-zap-app-icon svg circle {
  vector-effect: non-scaling-stroke;
}

.auth-reco-app-link strong,
.auth-zap-app-link strong {
  font-size: 0.9rem;
}

.auth-reco-app-label {
  display: inline-flex;
  flex-direction: column;
  gap: 0.08rem;
  line-height: 1.08;
}

.auth-reco-app-purpose {
  color: color-mix(in srgb, var(--light-text) 76%, var(--text));
  font-size: 0.68rem;
  font-weight: 650;
  letter-spacing: 0.012em;
  text-decoration: none;
}

.auth-reco-platform {
  width: fit-content;
  border: 1px solid color-mix(in srgb, var(--link) 20%, var(--border));
  border-radius: 999px;
  padding: 0.08rem 0.34rem;
  background: color-mix(in srgb, var(--link) 8%, var(--surface-raised-strong, #fff));
  color: color-mix(in srgb, var(--link) 72%, var(--text));
  font-size: 0.66rem;
  font-weight: 750;
  line-height: 1.1;
}

.auth-reco-store-links,
.auth-zap-store-links {
  color: color-mix(in srgb, var(--link) 72%, var(--text));
  font-size: 0.78rem;
}

.auth-reco-store-links a,
.auth-zap-store-links a {
  color: inherit;
  text-decoration: underline;
}

.auth-reco-note,
.auth-zap-note {
  margin: -0.24rem 0 0;
  color: color-mix(in srgb, var(--light-text) 82%, var(--text));
  font-size: 0.74rem;
  line-height: 1.35;
}

.auth-tab-frame {
  margin-top: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0;
}

.auth-input {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.55rem 0.7rem;
  background: var(--surface-raised-strong, #fff);
  color: var(--text);
}

.auth-username-input {
  width: min(22rem, 100%);
}

.auth-key-input {
  min-height: 86px;
  resize: vertical;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 0.84rem;
}

.auth-key-row {
  display: flex;
  align-items: stretch;
  gap: 0.6rem;
}

.auth-key-row .auth-key-input {
  flex: 1;
  margin: 0;
}

.auth-key-or {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.8rem;
  color: #64748b;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: lowercase;
}

.auth-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  margin-top: 0.7rem;
  flex-wrap: wrap;
}

.auth-actions-primary {
  margin-top: 0.42rem;
}

.auth-actions-stack {
  display: grid;
  gap: 0.45rem;
}

.auth-action-row {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.auth-action-reco {
  color: #475569;
  font-size: 0.84rem;
}

.auth-action-reco .auth-inline-link {
  font-size: 0.84rem;
}

.auth-intent {
  margin: 0.4rem 0 0.62rem;
  border: 1px solid #d7e2f6;
  border-radius: 10px;
  background: #f1f6ff;
  padding: 0.6rem 0.72rem;
  display: grid;
  gap: 0.45rem;
}

.auth-intent-row {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
  color: #1f335f;
  font-size: 0.88rem;
}

.auth-intent-row label {
  display: inline-flex;
  align-items: center;
  gap: 0.36rem;
  margin: 0;
  font-weight: 600;
}

.auth-intent-days label {
  font-weight: 700;
}

.auth-days-input {
  width: 6.3rem;
  min-width: 6.3rem;
}

.auth-panel {
  margin-top: 0;
  border-top: 0;
  padding-top: 0;
  display: grid;
  gap: 0.45rem;
}

.auth-panel[hidden] {
  display: none !important;
}

.auth-info-modal-panel {
  width: min(520px, calc(100vw - 2rem));
}

.auth-qr {
  width: fit-content;
  min-width: 12.9rem;
  min-height: 12.9rem;
  margin: 0.2rem auto 0.35rem;
  border: 1px solid rgba(30, 64, 175, 0.14);
  border-radius: 18px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(239, 245, 255, 0.92)),
    var(--surface-raised-strong, #fff);
  padding: 0.72rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: center;
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.14);
}

.auth-qr img,
.auth-qr canvas {
  display: block;
  max-width: 196px;
  height: auto;
  border-radius: 8px;
}

.auth-nip46-pairing {
  display: grid;
  grid-template-columns: max-content max-content;
  align-items: center;
  justify-content: center;
  gap: 0.65rem 0.85rem;
  max-width: 100%;
}

.auth-nip46-pairing .auth-qr {
  margin: 0;
}

.auth-nip46-pairing .auth-qr[hidden] {
  display: none;
}

.auth-nip46-controls {
  display: grid;
  justify-items: start;
  align-content: center;
  gap: 0.45rem;
  min-width: 0;
}

.auth-nip46-controls .auth-actions {
  justify-content: flex-start;
  margin-top: 0;
}

.auth-nip46-steps {
  display: grid;
  gap: 0.34rem;
  list-style: none;
  margin: 0 0 0.1rem;
  padding: 0;
  width: fit-content;
}

.auth-nip46-steps li {
  display: grid;
  grid-template-columns: 1.35rem max-content;
  gap: 0.08rem 0.42rem;
  align-items: center;
  color: var(--text);
}

.auth-nip46-steps li > span {
  grid-row: span 2;
  display: inline-grid;
  place-items: center;
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--link) 12%, var(--surface-raised-strong, #fff));
  color: color-mix(in srgb, var(--link) 78%, var(--text));
  font-size: 0.72rem;
  font-weight: 800;
}

.auth-nip46-steps strong {
  font-size: 0.82rem;
  line-height: 1.1;
}

.auth-nip46-steps small {
  color: var(--light-text);
  font-size: 0.73rem;
  line-height: 1.15;
}

.auth-nip46-uri {
  margin: 0.2rem 0 0;
  border: 1px solid #d8e1f5;
  border-radius: 8px;
  background: var(--surface-raised-strong, #fff);
  padding: 0.46rem 0.56rem;
  color: #334155;
  font-size: 0.78rem;
  line-height: 1.35;
  overflow-wrap: anywhere;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.auth-nip46-uri[hidden] {
  display: none;
}

.machine-string-box {
  position: relative;
  display: block;
}

.machine-string-box > .auth-nip46-uri {
  margin: 0.2rem 0 0;
  padding-right: 3.05rem;
}

.machine-string-box > textarea {
  padding-right: 3.05rem;
}

.machine-string-copy {
  position: absolute;
  top: 0.48rem;
  right: 0.48rem;
  display: inline-grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: #1f3d8c;
  cursor: pointer;
  box-shadow: none;
}

.machine-string-copy:hover,
.machine-string-copy:focus-visible {
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 88%, var(--link) 12%);
  color: #122b66;
}

.machine-copy-icon {
  width: 1.05rem;
  height: 1.05rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.85;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.auth-nip46-link-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.42rem 0.58rem;
  justify-content: flex-start;
}

.auth-nip46-link-actions[hidden] {
  display: none;
}

.auth-nip46-link-actions .machine-string-copy {
  position: static;
  flex: 0 0 auto;
  aspect-ratio: 1;
  min-width: 0;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
  background: var(--surface-raised-strong, #fff);
}

.auth-nip46-open-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  text-decoration: none;
  white-space: nowrap;
}

.auth-nip46-diagnostics {
  width: fit-content;
  margin: 0;
  border: 1px solid rgba(30, 64, 175, 0.14);
  border-radius: 999px;
  background: rgba(30, 64, 175, 0.06);
  padding: 0.34rem 0.66rem;
  color: #1e3a8a;
  font-size: 0.76rem;
  font-weight: 650;
  line-height: 1.2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.38rem;
}

.auth-nip46-diagnostics::before {
  content: "";
  width: 0.52rem;
  height: 0.52rem;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 0 0.24rem color-mix(in srgb, currentColor 12%, transparent);
  opacity: 0.86;
}

.auth-nip46-diagnostics:empty {
  display: none;
}

.auth-nip46-diagnostics.is-waiting::before {
  box-shadow:
    0 0 0 0.22rem color-mix(in srgb, currentColor 12%, transparent),
    0 0 0 0.48rem color-mix(in srgb, currentColor 6%, transparent);
}

.auth-nip46-diagnostics.is-ok {
  background: rgba(22, 101, 52, 0.1);
  color: #14532d;
}

.auth-nip46-diagnostics.is-warn {
  background: rgba(146, 64, 14, 0.12);
  color: #713f12;
}

.auth-nip46-diagnostics.is-error {
  background: rgba(153, 27, 27, 0.1);
  color: #7f1d1d;
}

.auth-manual-grid {
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  gap: 0.3rem 0.55rem;
  align-items: center;
}

.auth-manual-grid label {
  margin: 0;
  color: #1f335f;
  font-size: 0.82rem;
}

.auth-manual-grid .auth-input {
  min-height: 0;
}

.auth-passkey-inline-message {
  display: none;
  color: #92400e;
  font-size: 0.86rem;
  line-height: 1.3;
}

.auth-passkey-inline-message.is-visible {
  display: inline;
}

.auth-register-inline-message {
  display: none;
  font-size: 0.85rem;
  line-height: 1.25;
}

.auth-register-inline-message.is-visible {
  display: inline;
}

.auth-register-inline-message.is-warn {
  color: #92400e;
}

.auth-register-inline-message.is-error {
  color: #b91c1c;
}

.auth-register-inline-message.is-ok {
  color: #166534;
}

.auth-primary-btn,
.auth-secondary-btn {
  border: 1px solid var(--admin-border, var(--border));
  border-radius: 8px;
  background: var(--surface-raised, var(--admin-surface, var(--post-card-bg-single)));
  background-image: none;
  color: var(--admin-text, var(--text));
  font-size: 0.9rem;
  font-weight: 600;
  padding: 0.45rem 0.8rem;
  box-shadow: none;
}

.auth-primary-btn:hover:not(:disabled),
.auth-primary-btn:focus-visible:not(:disabled),
.auth-secondary-btn:hover:not(:disabled),
.auth-secondary-btn:focus-visible:not(:disabled) {
  border-color: color-mix(in srgb, var(--admin-border, var(--border)) 68%, var(--admin-accent, var(--accent)) 32%);
  background: var(--admin-hover, var(--nav-link-hover));
  background-image: none;
  color: var(--admin-text, var(--text));
}

.auth-primary-btn:disabled,
.auth-secondary-btn:disabled {
  opacity: 0.58;
  cursor: not-allowed;
}

.auth-inline-link {
  color: var(--accent);
  text-decoration: underline;
  font-size: 0.9rem;
}

.auth-modal-message {
  display: block;
  overflow: hidden;
  max-height: 0;
  margin: 0;
  border: 1px solid rgba(37, 99, 235, 0.2);
  border-radius: 12px;
  background: rgba(239, 246, 255, 0.96);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
  padding: 0 0.78rem;
  color: #1e3a8a;
  font-size: 0.91rem;
  font-weight: 650;
  line-height: 1.35;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-0.28rem);
  transition:
    max-height 190ms ease,
    margin 190ms ease,
    padding 190ms ease,
    opacity 170ms ease,
    transform 170ms ease;
}

.auth-modal-message.is-visible {
  max-height: 8rem;
  margin: 0.66rem 0 0.72rem;
  padding: 0.68rem 0.78rem;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.auth-modal-message.is-warn {
  border-color: rgba(217, 119, 6, 0.26);
  background: rgba(255, 251, 235, 0.98);
  color: #92400e;
}

.auth-modal-message.is-plain {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  color: #475569;
  font-weight: 520;
}

.auth-modal-message.is-visible.is-plain {
  margin: 0.42rem 0 0.56rem;
  padding: 0;
}

.auth-modal-message.is-error {
  border-color: rgba(185, 28, 28, 0.28);
  background: rgba(254, 242, 242, 0.98);
  color: #b91c1c;
}

.auth-modal-message.is-ok {
  border-color: rgba(22, 101, 52, 0.24);
  background: rgba(240, 253, 244, 0.98);
  color: #166534;
}

.auth-register-details {
  margin-top: 0.7rem;
  border-top: 1px solid #d8e1f5;
  padding-top: 0.6rem;
}

.auth-register-details summary {
  cursor: pointer;
  font-weight: 600;
  color: #1e3a8a;
}

.auth-drop-zone {
  border: 1px dashed #9fb3e9;
  border-radius: 10px;
  width: 110px;
  min-width: 110px;
  min-height: 110px;
  padding: 0.55rem;
  color: #475569;
  text-align: center;
  background: #eef4ff;
  font-size: 0.86rem;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.25;
}

.auth-drop-zone.is-over {
  background: #dbe8ff;
  border-color: #4f74d9;
}

@media (max-width: 640px) {
  .auth-modal-panel {
    width: calc(100vw - 1rem);
    margin: 0.75rem auto 0;
    max-height: calc(100vh - 1.5rem);
    padding: 0;
    border-radius: 12px;
  }

  .auth-intent-row {
    gap: 0.45rem;
  }

  .auth-intent-row label {
    width: 100%;
  }

  .auth-intent-days {
    align-items: flex-start;
  }

  .auth-days-input {
    width: 100%;
    min-width: 0;
  }

  .auth-actions-primary {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.45rem;
  }

  .auth-actions-primary .auth-primary-btn,
  .auth-actions-primary .auth-secondary-btn,
  #auth-manual-submit,
  #auth-manual-start {
    width: 100%;
  }

  .auth-action-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.32rem;
  }

  .auth-qr {
    min-width: min(100%, 13rem);
    max-width: 100%;
  }

  .auth-nip46-pairing {
    grid-template-columns: max-content minmax(0, max-content);
    gap: 0.5rem;
  }

  .auth-nip46-pairing .auth-qr {
    min-width: 9rem;
    min-height: 9rem;
    padding: 0.48rem;
  }

  .auth-nip46-pairing .auth-qr img,
  .auth-nip46-pairing .auth-qr canvas {
    max-width: 132px;
  }

  .auth-nip46-controls {
    gap: 0.38rem;
  }

  .auth-nip46-uri {
    font-size: 0.75rem;
  }

  .auth-nip46-diagnostics {
    font-size: 0.75rem;
  }

  .auth-nip46-steps {
    gap: 0.28rem;
  }

  .auth-nip46-steps li {
    grid-template-columns: 1.25rem max-content;
    column-gap: 0.36rem;
  }

  .auth-nip46-steps li > span {
    width: 1.25rem;
    height: 1.25rem;
  }

  .auth-key-row {
    flex-direction: column;
  }

  .auth-key-or {
    width: 100%;
  }

  .auth-drop-zone {
    width: 100%;
    min-width: 0;
    min-height: 84px;
  }

  .auth-manual-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .auth-nip46-pairing {
    grid-template-columns: minmax(0, 1fr);
  }

  .auth-nip46-controls {
    order: -1;
    justify-items: center;
  }

  .auth-nip46-pairing .auth-qr {
    order: 2;
  }

  .auth-nip46-controls .auth-actions,
  .auth-nip46-link-actions {
    justify-content: center;
  }
}

.nav-right {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  transition: transform 0.3s ease;
}

.nav-right.slide-left .nav-search {
  transform: translateX(-80px);
  margin-right: 0;
  margin-left: calc(auto - 80px);
}

.nav-right.slide-left .nav-user-menu {
  transform: translateX(-80px);
}

/* Responsive adjustments for navigation */
@media (max-width: 768px) {
  .site-nav {
    gap: 1rem; /* Reduce space between center and right sections */
  }
  
  .nav-right {
    gap: 0.5rem;
  }
  
  .nav-search {
    margin-left: auto;
    margin-right: auto;
  }
  
  .nav-search input[type="text"] {
    width: 140px;
  }
}

@media (max-width: 600px) {
  .site-nav {
    padding: 0.75rem 1rem;
    gap: 0.5rem; /* Further reduce space on very small screens */
  }
  
  .nav-center {
    gap: 0.25rem; /* Tighten center links */
  }
  
  .nav-right {
    gap: 0.25rem;
  }
  
  .nav-search {
    margin-left: auto;
    margin-right: auto;
  }
  
  .nav-search input[type="text"] {
    width: 100px;
  }
  
  .nav-center a,
  .btn-login {
    padding: 0.4rem 0.8rem;
    font-size: 0.85rem;
  }
}

@media (max-width: 480px) {
  .nav-right {
    gap: 0;
  }
  
  .nav-search {
    margin-left: 0.5rem;
    margin-right: auto;
  }
  
  .nav-search {
    margin-left: 0;
    margin-right: 1rem;
  }
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  color: var(--primary);
  margin-top: 2rem;
  margin-bottom: 1rem;
  line-height: 1.3;
}

h1 {
  font-size: 2.5rem;
  margin-top: 0;
}

h2 {
  font-size: 1.8rem;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.5rem;
}

h3 {
  font-size: 1.4rem;
}

a {
  color: var(--accent);
  text-decoration: none;
  cursor: pointer;
}

a:hover {
  text-decoration: underline;
}

/* Ordinary text links should not get hover background fills. */
a:not(.tag):not(.feed-link):not(.footer-feed-link):not(.btn-login):not(.btn-login-main):not(.btn-login-caret):not(.nav-menu-item):not(.nav-link-button):hover,
a:not(.tag):not(.feed-link):not(.footer-feed-link):not(.btn-login):not(.btn-login-main):not(.btn-login-caret):not(.nav-menu-item):not(.nav-link-button):focus-visible {
  background: transparent !important;
}

/* Post Listing */
.post-list {
  list-style: none;
  padding: 0;
  display: grid;
  gap: 1.15rem;
  margin-top: 1rem;
  justify-items: center;
}

.post-item {
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 0;
  padding: 1.15rem 1.2rem 0.55rem;
  border: 1px solid #b7bfce;
  border-radius: 16px;
  background: var(--post-card-bg-single, var(--post-card-bg, #fdfdfb));
  display: flex;
  flex-direction: column;
  min-height: 210px;
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.08);
}

.post-item.blog-post-resizable {
  box-sizing: border-box;
  width: var(--blog-post-resizable-width, auto);
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  justify-self: center;
  touch-action: pan-y;
}

body.blog-post-resizing {
  cursor: ew-resize;
  user-select: none;
}

.post-single-item {
  margin: 1rem auto 0.95rem;
  width: clamp(30rem, 92vw, 60rem);
  max-width: 100%;
  min-height: 22rem;
  padding: 1.75rem 3.25rem 1.55rem;
  background: var(--post-body-bg, var(--post-card-bg-single, #fdfdfb));
  border-color: color-mix(in srgb, var(--border, #c7d2fe) 78%, var(--bg, #ffffff) 22%);
  box-shadow:
    0 14px 28px rgba(15, 23, 42, 0.07),
    0 1px 0 rgba(255, 255, 255, 0.82) inset;
}

.post-single-item.post-single-has-wide-content {
  width: clamp(26rem, 96vw, 72rem);
}

.post-single-item.blog-post-resizable {
  width: var(--blog-post-resizable-width, clamp(30rem, 92vw, 60rem));
}

.post-single-item.post-single-has-wide-content.blog-post-resizable {
  width: var(--blog-post-resizable-width, clamp(26rem, 96vw, 72rem));
}

.post-single-item .post-head {
  margin-bottom: 0.95rem;
  padding-bottom: 0.58rem;
}

.post-single-item .post-single-body {
  margin-top: 0.18rem;
  margin-left: 0;
  margin-right: 0;
  max-inline-size: none;
  width: 100%;
  font-size: clamp(1rem, 0.97rem + 0.2vw, 1.08rem);
  line-height: 1.82;
  color: color-mix(in srgb, var(--text, #0b132b) 94%, black 6%);
  text-wrap: pretty;
  background: transparent;
  border-radius: 0;
  padding: 0.85rem 0 0.72rem;
  --post-prose-measure: 72ch;
}

.post-single-item .post-single-body,
.post-single-item .post-single-body * {
  max-width: 100%;
}

.post-single-item .post-single-body {
  overflow-wrap: break-word;
}

.post-single-item .post-single-body a {
  overflow-wrap: anywhere;
}

.post-single-item .post-single-body table {
  display: block;
  width: max-content;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-collapse: collapse;
}

.post-single-item .post-single-body th,
.post-single-item .post-single-body td {
  overflow-wrap: normal;
}

.post-single-item .post-single-body pre {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.post-single-item .post-single-body img,
.post-single-item .post-single-body video,
.post-single-item .post-single-body iframe {
  max-width: 100%;
  height: auto;
}

.post-single-item .post-single-body > :first-child {
  margin-top: 0.35rem;
}

.post-single-item .post-single-body p {
  margin: 0 0 1.08em;
}

.post-single-item .post-single-body p:last-child {
  margin-bottom: 0;
}

.post-single-item .post-single-body ul,
.post-single-item .post-single-body ol {
  margin: 0.5em 0 1.05em 1.15em;
}

.post-single-item .post-single-body > :where(p, ul, ol, dl, blockquote, h2, h3, h4, h5, h6, hr) {
  max-inline-size: var(--post-prose-measure);
  margin-inline: auto;
}

.post-single-item .post-single-body > hr,
.post-content > hr,
.list-entry-markdown > hr,
.nostr-page-extra > hr,
.post-single-item .post-single-body > .markdown-separator,
.post-content > .markdown-separator,
.list-entry-markdown > .markdown-separator,
.nostr-page-extra > .markdown-separator {
  border: 0;
  height: auto;
  margin-block: 2.15rem;
  text-align: center;
}

.post-single-item .post-single-body > .markdown-separator,
.post-content > .markdown-separator,
.list-entry-markdown > .markdown-separator,
.nostr-page-extra > .markdown-separator {
  letter-spacing: 0.18em;
}

.post-single-item .post-single-body > hr::before,
.post-content > hr::before,
.list-entry-markdown > hr::before,
.nostr-page-extra > hr::before {
  content: "***";
  display: inline-block;
  color: var(--muted-text, currentColor);
  font: inherit;
  letter-spacing: 0.18em;
}

.post-single-item .post-single-body table,
.post-single-item .post-single-body pre {
  width: 100%;
  max-inline-size: none;
  margin-left: 0;
  margin-right: 0;
}

.post-single-item .post-single-body table {
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.post-single-item .tag {
  filter: none;
  background: var(--post-tag-standard-bg);
  background-color: var(--post-tag-standard-bg);
  border-color: var(--post-tag-standard-border);
  color: var(--post-tag-standard-text);
}

.post-single-item .tag:hover {
  background: var(--post-tag-standard-bg);
  background-color: var(--post-tag-standard-bg);
  color: var(--post-tag-standard-text);
  filter: none;
}

.post-single-item .blog-type-pill,
.post-single-item .blog-type-pill:hover,
.post-single-item .blog-type-pill:focus-visible {
  border-color: var(--post-tag-type-border);
  background: var(--post-tag-type-bg);
  background-color: var(--post-tag-type-bg);
  color: var(--post-tag-type-text);
}

.post-single-item .blog-year-pill,
.post-single-item .blog-year-pill:hover,
.post-single-item .blog-year-pill:focus-visible {
  border-color: var(--post-tag-year-border);
  background: var(--post-tag-year-bg);
  background-color: var(--post-tag-year-bg);
  color: var(--post-tag-year-text);
}

@media (max-width: 720px) {
  .post-single-item {
    width: 100%;
    min-height: 15.5rem;
    padding: 1.12rem 1.18rem 1rem;
  }

  .post-single-item .post-single-body {
    padding: 0;
  }
}

.post-head {
  position: relative;
  display: block;
  margin-bottom: 0.18rem;
}

.post-single-item .post-head-main {
  order: 1;
  flex: 1 1 auto;
}

.post-single-item .post-page-menu {
  order: 2;
  align-self: flex-start;
}

.post-head-main {
  width: 100%;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.post-head-main .post-title {
  padding-right: 2.45rem;
}

.post-single-item .post-head-main .post-title {
  padding-right: 5.4rem;
}

.blog-post-item .post-page-menu {
  position: absolute;
  top: 0;
  right: 0;
  left: auto;
  align-self: auto;
  margin-left: auto;
}

.post-title {
  font-size: 1.65rem;
  margin: 0;
  border-bottom: none;
  padding-bottom: 0;
}

.post-title a {
  color: var(--primary);
}

.blog-post-item .post-title a:hover {
  text-decoration: none;
}

.post-head-divider {
  order: 2;
  width: 100%;
  border-top: 1px solid var(--border);
  margin: 0.4rem 0 0.34rem;
}

.blog-post-item .post-title {
  font-size: 1.58rem;
}

.post-author {
  margin-top: 0;
  color: var(--light-text);
  font-size: 0.82rem;
  font-weight: 400;
  line-height: 1.25;
  white-space: nowrap;
}

.post-byline {
  order: 3;
  width: 100%;
}

.post-byline-top {
  margin-top: 0.22rem;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  column-gap: 0.7rem;
}

.post-byline-bottom {
  margin-top: 0.02rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: baseline;
  column-gap: 0.7rem;
}

.post-meta {
  color: var(--light-text);
  font-size: 0.82rem;
  font-weight: 400;
  margin: 0;
  text-align: right;
  white-space: nowrap;
}

.post-byline-bottom .post-reading-inline,
.post-single-item .post-reading-inline {
  color: var(--light-text);
  font-family: var(--ui-font-family, "Avenir Next", "Segoe UI", "Helvetica Neue", Arial, sans-serif);
  font-size: 0.74rem;
  font-weight: 400;
  line-height: 1.25;
  white-space: nowrap;
  text-align: center;
}

.post-byline-bottom .post-author {
  grid-column: 1;
  justify-self: start;
}

.post-byline-bottom .post-reading-inline {
  grid-column: 2;
  justify-self: center;
}

.post-byline-bottom .post-date,
.post-byline-bottom .post-date-published,
.post-byline-top .post-date,
.post-byline-top .post-date-published {
  grid-column: 3;
  justify-self: end;
  color: var(--light-text);
  font-size: 0.82rem;
  font-weight: 400;
  line-height: 1.25;
  white-space: nowrap;
  text-align: right;
}

.post-page-menu {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 80;
  align-self: auto;
}

.post-page-menu-trigger {
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--text);
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  line-height: 1;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.post-page-menu-trigger {
  font-size: 0;
}

.post-page-menu-trigger:hover,
.post-page-menu-trigger:focus-visible {
  background: var(--light-bg);
}

.post-page-menu-panel {
  position: absolute;
  top: calc(100% + 0.35rem);
  right: 0;
  min-width: 12rem;
  background: var(--menu-bg);
  background-image: none !important;
  border: 0;
  border-radius: 12px;
  box-shadow: var(--popup-menu-shadow, var(--menu-shadow));
  padding: 0.32rem;
  z-index: 60;
}

.post-page-menu-panel button {
  width: 100%;
  border: 0 !important;
  border-radius: 0;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  color: var(--text) !important;
  -webkit-text-fill-color: currentColor !important;
  text-align: left;
  padding: 0.45rem 0.58rem;
  font-size: 0.86rem;
  transform: none !important;
}

.post-page-menu-panel button:hover,
.post-page-menu-panel button:focus-visible {
  background: var(--menu-hover-bg) !important;
  background-image: none !important;
  box-shadow: none !important;
  outline: none;
  transform: none !important;
}

.post-page-menu-separator {
  height: 0;
  margin: 0.18rem 0;
  background: transparent;
}

.post-page-menu-panel .post-page-menu-delete {
  color: var(--menu-danger-text) !important;
  -webkit-text-fill-color: currentColor !important;
}

.post-page-menu-panel .post-page-menu-delete:hover,
.post-page-menu-panel .post-page-menu-delete:focus-visible {
  background: var(--menu-danger-hover-bg) !important;
  background-image: none !important;
  box-shadow: none !important;
}

.post-page-modal-shell {
  position: fixed;
  inset: 0;
  z-index: 1700;
}

.post-page-modal-backdrop {
  position: absolute;
  inset: 0;
  background: var(--surface-overlay, rgba(15, 23, 42, 0.56));
  backdrop-filter: blur(3px);
}

.post-page-modal-panel {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.75rem;
  width: min(30rem, calc(100vw - 2rem));
  margin: min(14vh, 6rem) auto 1rem;
  padding: 1rem;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--menu-bg, var(--post-card-bg-single, #fffaf0));
  color: var(--text);
  box-shadow: var(--menu-shadow, 0 18px 44px rgba(15, 23, 42, 0.2));
}

.post-page-modal-panel h3 {
  margin: 0;
  font-size: 1.05rem;
}

.post-page-modal-field {
  display: grid;
  gap: 0.32rem;
  font-size: 0.9rem;
  font-weight: 700;
}

.post-page-modal-field small {
  font-weight: 500;
  color: var(--light-text);
}

.post-page-modal-field input,
.post-page-modal-field select {
  box-sizing: border-box;
  width: 100%;
  min-height: 2.15rem;
  padding: 0.38rem 0.58rem;
  border: 1px solid var(--border);
  border-radius: 9px;
  background: var(--surface-raised, #fff);
  color: var(--text);
  font: inherit;
  font-weight: 500;
}

.post-page-modal-field input:focus,
.post-page-modal-field select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);
}

.post-page-modal-status {
  margin: 0;
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  font-size: 0.9rem;
  line-height: 1.35;
  background: color-mix(in srgb, var(--surface-raised, #fff) 75%, var(--accent) 25%);
}

.post-page-modal-status.is-error {
  background: #fff1f0;
  color: #8e1c1a;
}

.post-page-modal-status.is-ok {
  background: #ecfdf3;
  color: #17633a;
}

.post-page-modal-actions {
  display: inline-flex;
  justify-content: flex-end;
  gap: 0.45rem;
}

.post-page-modal-primary {
  border-color: color-mix(in srgb, var(--accent) 70%, var(--border) 30%);
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  font-weight: 760;
}

.post-date {
  font-weight: 400;
  color: var(--light-text);
  font-size: 0.82rem;
  line-height: 1.25;
}

.blog-post-item .post-card-footer {
  margin-top: auto;
  padding-top: 0.72rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: center;
  row-gap: 0.35rem;
  justify-items: center;
}

.blog-post-item .post-card-footer .tags {
  grid-column: 1;
  margin-top: 0;
  padding-top: 0;
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  gap: 0.24rem 0.32rem;
  align-items: center;
  justify-content: center;
  min-width: 0;
}

.blog-post-item .post-card-footer .post-card-meta-tags > .tag {
  margin: 0;
}

.blog-post-item .post-card-comments-count {
  grid-column: 1;
  justify-self: center;
  margin-left: 0;
  color: var(--light-text);
  font-size: 0.78rem;
  white-space: nowrap;
}

.post-summary {
  margin: 0.95rem auto 0;
  max-inline-size: 62ch;
  font-size: 0.97rem;
  line-height: 1.6;
  text-align: left;
  white-space: pre-wrap;
}

.post-summary > :first-child {
  margin-top: 0;
}

.post-summary > :last-child {
  margin-bottom: 0;
}

.post-summary-read-more {
  display: inline-block;
  width: fit-content;
  margin: 0.35rem 0 0;
  font-weight: 600;
}

/* Tags */
.tags {
  margin-top: auto;
  padding-top: 0.9rem;
  text-align: center;
}

.tag {
  display: inline-block;
  background: var(--tag-bg);
  color: var(--tag-text);
  padding: 0.14rem 0.62rem;
  margin: 0.2rem 0.2rem 0.05rem 0;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 500;
  line-height: 1.2;
  text-decoration: none;
  border: 1px solid var(--tag-border);
  cursor: pointer;
}

a.tag,
button.tag,
.tag[role="button"] {
  cursor: pointer;
}

.tag:hover {
  background: var(--accent);
  color: var(--nav-active-text);
  text-decoration: none;
}

.post-item .tag {
  background: var(--tag-muted-bg);
  border-color: var(--tag-muted-border);
  color: var(--tag-muted-text);
}

.blog-post-item .tag,
.blog-type-pill,
.blog-year-pill {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 0.74rem;
  font-weight: 400;
  padding: 0.1rem 0.52rem;
  background: var(--post-tag-standard-bg);
  background-color: var(--post-tag-standard-bg);
  border-color: var(--post-tag-standard-border);
  color: var(--post-tag-standard-text);
}

.post-item .tag:hover {
  background: var(--tag-muted-bg);
  color: var(--tag-muted-text);
}

.blog-post-item .tag:hover,
.blog-post-item .tag:focus-visible,
.blog-type-pill:hover,
.blog-year-pill:hover,
.blog-type-pill:focus-visible,
.blog-year-pill:focus-visible {
  background: var(--post-tag-standard-bg);
  background-color: var(--post-tag-standard-bg);
  border-color: var(--post-tag-standard-border);
  color: var(--post-tag-standard-text);
}

.post-item .tag:focus-visible {
  filter: none;
}

/* Post Content */
.post-content {
  margin-top: 2rem;
}

.post-content :where(img, video, iframe, canvas, svg),
.post-summary :where(img, video, iframe, canvas, svg),
.post-single-item .post-single-body :where(img, video, iframe, canvas, svg) {
  max-width: 100%;
  height: auto;
}

.post-content img,
.post-summary img,
.post-single-item .post-single-body img {
  display: block;
}

.post-header {
  margin-bottom: 2rem;
}

.post-header h1 {
  margin-bottom: 0.5rem;
}

/* Post Navigation */
.post-nav {
  display: flex;
  justify-content: space-between;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--border);
}

.post-nav-prev,
.post-nav-next {
  flex: 1;
}

.post-nav-next {
  text-align: right;
}

.post-nav a {
  color: var(--accent);
  font-weight: 500;
}

/* Revision History */
.revision-notice {
  background: var(--light-bg);
  border-left: 4px solid var(--accent);
  padding: 1rem;
  margin: 2rem 0;
}

.revision-notice strong {
  color: var(--primary);
}

.revision-history {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--border);
}

.revision-history h3 {
  margin-top: 0;
}

.revision-item {
  margin: 1rem 0;
  padding: 0.5rem 0;
}

/* Pagination */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 3rem 0;
  gap: 1rem;
}

.pagination a,
.pagination span {
  padding: 0.5rem 1rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  color: var(--accent);
  text-decoration: none;
}

.pagination a:hover {
  background: transparent;
  text-decoration: none;
}

.pagination .current {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
}

/* Code */
code {
  background: var(--code-bg);
  padding: 0.2rem 0.4rem;
  border-radius: 3px;
  font-size: 0.9em;
  font-family: 'Courier New', Courier, monospace;
}

pre {
  background: var(--code-bg);
  padding: 1rem;
  border-radius: 5px;
  overflow-x: auto;
  border: 1px solid var(--border);
}

pre code {
  background: none;
  padding: 0;
}

/* Blockquotes */
blockquote {
  border-left: 4px solid var(--border);
  padding-left: 1.5rem;
  margin-left: 0;
  color: var(--light-text);
  font-style: italic;
}

/* Footer */
footer {
  margin-top: 4rem;
  padding-top: 2rem;
  border-top: 2px solid var(--border);
  text-align: center;
  color: var(--light-text);
  font-size: 0.9rem;
}

.site-footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.45rem 1rem;
  margin-top: auto;
  padding-top: 1.4rem;
  padding-bottom: 0.35rem;
  border-top: 0;
  text-align: center;
}

.footer-pages {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.45rem 1rem;
  margin: 0;
}

.footer-page-link,
.footer-page-link:visited {
  color: var(--light-text);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 600;
}

.footer-page-link:hover,
.footer-page-link:focus-visible {
  color: var(--text);
  text-decoration: underline;
}

.footer-feeds {
  display: inline-flex;
  gap: 0.85rem;
  align-items: center;
}

.footer-feed-link {
  display: inline-flex;
  gap: 0.35rem;
  align-items: center;
  color: var(--amethyst, #6a4fa3);
  text-decoration: none;
  font-size: 0.86rem;
  font-weight: 600;
}

.footer-feed-link svg {
  color: var(--amethyst, #6a4fa3);
}

.footer-feed-link:hover {
  color: var(--amethyst-dark, #553f83);
  text-decoration: none;
}

.footer-feed-link:hover svg,
.footer-feed-link:focus-visible svg {
  color: var(--amethyst-dark, #553f83);
}

.site-footer a[href$="/rss.xml"],
.site-footer a[href$="/rss.xml"]:visited,
.site-footer a[href$="/atom.xml"],
.site-footer a[href$="/atom.xml"]:visited {
  color: var(--amethyst, #6a4fa3) !important;
}

.site-footer a[href$="/rss.xml"] svg,
.site-footer a[href$="/atom.xml"] svg {
  color: var(--amethyst, #6a4fa3) !important;
}

.site-footer a[href$="/rss.xml"]:hover,
.site-footer a[href$="/rss.xml"]:focus-visible,
.site-footer a[href$="/atom.xml"]:hover,
.site-footer a[href$="/atom.xml"]:focus-visible {
  color: var(--amethyst-dark, #553f83) !important;
}

.site-footer a[href$="/rss.xml"]:hover svg,
.site-footer a[href$="/rss.xml"]:focus-visible svg,
.site-footer a[href$="/atom.xml"]:hover svg,
.site-footer a[href$="/atom.xml"]:focus-visible svg {
  color: var(--amethyst-dark, #553f83) !important;
}

.software-map-external {
  color: var(--light-text);
  font-family: Georgia, 'Times New Roman', serif;
}

/* About Page */
.about-content {
  margin-top: 2rem;
}

/* Tag Index */
.tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 2rem 0;
}

.tag-cloud .tag {
  cursor: pointer;
}

.tag-cloud .tag:hover,
.tag-cloud .tag:focus-visible {
  text-decoration: underline;
}

.tag-cloud .tag.tag-selected {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent-dark);
}

.tag-count {
  color: var(--light-text);
  font-size: 0.85rem;
}

.tag-filter-hint {
  margin: 0.15rem 0 0.85rem;
  color: #6b7280;
  font-size: 0.86rem;
}

.tag-results {
  margin-top: 1rem;
}

.blog-page {
  margin-top: 0.65rem;
  background: transparent;
  background-image: none;
}

#blog-page-root,
.blog-layout {
  background: transparent;
  background-image: none;
}

.blog-layout {
  --blog-filter-gutter: 2.2rem;
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  column-gap: 0;
  align-items: start;
  width: min(100%, var(--site-content-width));
  margin-left: auto;
  margin-right: auto;
}

.blog-filter-column {
  grid-column: 1;
  grid-row: 1;
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  position: absolute;
  top: 0.14rem;
  right: 0;
  z-index: 5;
  padding-top: 0;
  width: 1.9rem;
}

.blog-main-column {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
  width: 100%;
}

.blog-draft-notice {
  margin: 0.25rem 0 0.85rem;
}

.blog-draft-notice-card {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.55rem;
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 0.78rem 1rem;
  background: var(--post-card-bg, var(--bg));
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.08);
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.25;
}

.blog-draft-notice-main {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 0;
  flex: 1 1 auto;
}

.blog-draft-notice-all-link {
  margin-left: auto;
  flex: 0 0 auto;
  white-space: nowrap;
}

.blog-draft-notice-close {
  appearance: none;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 1.72rem;
  min-width: 1.72rem;
  height: 1.72rem;
  min-height: 1.72rem;
  margin: -0.2rem -0.26rem -0.2rem 0;
  padding: 0 !important;
  border: 0;
  border-radius: 999px;
  background: transparent;
  background-image: none;
  box-shadow: none;
  color: #050505;
  -webkit-text-fill-color: currentColor;
  cursor: pointer;
  line-height: 1;
}

.blog-draft-notice-close:hover,
.blog-draft-notice-close:focus-visible {
  background: rgba(15, 23, 42, 0.10);
  background-image: none;
  box-shadow: none;
  color: #000000;
}

.blog-draft-notice-close:focus-visible {
  outline: 2px solid color-mix(in srgb, #000000 64%, var(--accent, #2563eb) 36%);
  outline-offset: 2px;
}

.blog-draft-notice-close-svg {
  display: block;
  width: 1.1rem;
  height: 1.1rem;
  color: currentColor;
  stroke: currentColor;
}

.blog-draft-notice-link {
  color: var(--link-color, var(--accent));
  text-decoration: underline;
  text-underline-offset: 0.13em;
}

.blog-draft-notice-link:hover,
.blog-draft-notice-link:focus-visible {
  color: var(--link-hover-color, var(--accent-dark));
  background: transparent !important;
}

.blog-draft-notice-continue {
  appearance: none;
  border: 0;
  margin: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
  text-align: left;
}

.blog-draft-notice-continue strong {
  color: var(--accent);
}

.blog-draft-notice-continue:hover strong,
.blog-draft-notice-continue:focus-visible strong {
  color: var(--accent-dark);
  text-decoration: underline;
}

.blog-draft-notice-continue-link:hover,
.blog-draft-notice-continue-link:focus-visible {
  background: transparent !important;
}

@media (max-width: 640px) {
  .blog-draft-notice-card {
    flex-wrap: wrap;
  }
  .blog-draft-notice-all-link {
    margin-left: 0;
  }
  .blog-draft-notice-close {
    margin-left: auto;
  }
}

#blog-page-admin {
  overflow: hidden;
}

#blog-page-admin .blog-page-settings-panel {
  max-height: 0;
  opacity: 0;
  transform: translateY(-8px);
  transition: max-height 240ms ease, opacity 200ms ease, transform 200ms ease;
}

#blog-page-admin.is-open .blog-page-settings-panel {
  max-height: 6.5rem;
  opacity: 1;
  transform: translateY(0);
}

#blog-page-admin .blog-page-settings-panel label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.86rem;
  color: var(--muted-text, #4f617f);
}

#blog-page-admin .blog-page-settings-panel select {
  width: auto;
  min-width: 12rem;
}

.blog-main-column .post-list {
  margin-top: 0;
  width: 100%;
  min-width: 0;
  justify-items: stretch;
}

.blog-main-column .post-list > .blog-post-item.blog-post-resizable {
  width: 100%;
  max-width: 100%;
}

#blog-empty.placeholder {
  animation: none !important;
  transition: none !important;
  transform: none !important;
}

.blog-filter-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  min-width: 1.9rem;
  height: 1.9rem;
  padding: 0;
  border: 0 !important;
  border-top: 0 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  border-left: 0 !important;
  border-inline-start: 0 !important;
  border-inline-end: 0 !important;
  border-block-start: 0 !important;
  border-block-end: 0 !important;
  border-color: transparent !important;
  border-image: none !important;
  border-radius: 8px;
  appearance: none;
  -webkit-appearance: none;
  background: transparent !important;
  background-image: none !important;
  background-clip: padding-box !important;
  -webkit-background-clip: padding-box !important;
  background-origin: padding-box !important;
  color: var(--admin-text, var(--text));
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  clip-path: inset(0 round 8px);
  contain: paint;
  overflow: hidden;
  transition: background-color 0.16s ease, color 0.16s ease;
}

.blog-filter-toggle .blog-filter-icon {
  width: 1rem;
  height: 1rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.blog-filter-toggle:hover,
.blog-filter-toggle:focus-visible,
.blog-filter-toggle[aria-expanded="true"] {
  background: var(--admin-hover, var(--nav-link-hover)) !important;
  color: var(--admin-text, var(--text));
}

.blog-clear-filters {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: 0;
  border-radius: 10px;
  border: 1px solid var(--button-primary-border);
  padding: 0.42rem 0.75rem;
  font-size: 0.88rem;
  font-weight: 600;
  background-color: var(--button-primary-start);
  background-image: var(--button-primary-overlay), linear-gradient(140deg, var(--button-primary-start) 0%, var(--button-primary-end) 100%);
  color: var(--button-primary-text);
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.blog-clear-filters:hover {
  background-color: var(--button-primary-hover-start);
  background-image: var(--button-primary-overlay), linear-gradient(140deg, var(--button-primary-hover-start) 0%, var(--button-primary-hover-end) 100%);
  color: var(--button-primary-text);
}

.blog-filter-panel {
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: color-mix(in srgb, var(--post-card-bg-single) 84%, transparent);
  padding: 0 0.88rem;
  margin: 0.18rem 0 0.95rem;
  max-height: 0;
  opacity: 0;
  transform: translateY(-2px);
  transition:
    max-height 0.38s cubic-bezier(0.4, 0, 0.2, 1),
    padding 0.32s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.26s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
}

.blog-filter-panel.is-open {
  max-height: 32rem;
  padding: 0.88rem;
  opacity: 1;
  transform: translateY(0);
}

.blog-filter-grid {
  display: grid;
  gap: 0.88rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.blog-filter-group h3 {
  margin: 0 0 0.42rem;
  font-size: 0.92rem;
  font-weight: 700;
  border: 0;
  padding: 0;
}

.blog-filter-options {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.blog-filter-chip {
  display: inline-flex;
  align-items: center;
  width: auto;
  min-width: 0;
  border-radius: 999px;
  border: 1px solid var(--tag-border);
  background: var(--tag-muted-bg);
  color: var(--tag-muted-text);
  padding: 0.28rem 0.58rem;
  font-size: 0.82rem;
  line-height: 1.2;
}

.blog-filter-chip:hover {
  background: var(--tag-muted-hover-bg);
  color: var(--tag-muted-hover-text);
}

.blog-filter-chip.is-active {
  border-color: var(--button-primary-border);
  background-color: var(--button-primary-start);
  background-image: var(--button-primary-overlay), linear-gradient(140deg, var(--button-primary-start) 0%, var(--button-primary-end) 100%);
  color: var(--button-primary-text);
}

.blog-filter-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  margin-top: 0.82rem;
}

.blog-filter-hint {
  margin: 0;
  color: var(--light-text);
  font-size: 0.79rem;
}

.blog-filter-hint kbd {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0.04rem 0.3rem;
  background: color-mix(in srgb, var(--post-card-bg-single) 70%, transparent);
  font-family: 'Courier New', Courier, monospace;
  font-size: 0.76rem;
}

.blog-clear-filters {
  padding: 0.34rem 0.62rem;
  font-size: 0.8rem;
}

.blog-post-item .blog-meta-row {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  margin-top: 0.6rem;
}

.blog-post-item .blog-meta-row-with-comments {
  display: flex;
  width: 100%;
}

.blog-post-item .blog-meta-row-with-comments .post-card-comments-count {
  margin-left: auto;
}

@media (max-width: 640px) {
  .blog-post-item .post-card-footer {
    grid-template-columns: minmax(0, 1fr);
  }

  .blog-post-item .post-card-footer .tags,
  .blog-post-item .post-card-comments-count {
    grid-column: 1;
    justify-self: center;
  }
}

.blog-type-pill,
.blog-year-pill {
  display: inline-flex;
  align-items: center;
  width: auto;
  min-width: 0;
  border-radius: 999px;
  padding: 0.1rem 0.52rem;
  margin: 0.2rem 0.2rem 0.05rem 0;
  appearance: none;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 0.74rem;
  font-weight: 400;
  line-height: 1.2;
  border: 1px solid color-mix(in srgb, var(--tag-muted-border) 58%, transparent);
  background: var(--post-tag-standard-bg);
  background-color: var(--post-tag-standard-bg);
  color: var(--post-tag-standard-text);
  cursor: pointer;
  text-decoration: none;
}

.blog-type-pill:hover,
.blog-year-pill:hover,
.blog-type-pill:focus-visible,
.blog-year-pill:focus-visible {
  background: var(--post-tag-standard-bg);
  background-color: var(--post-tag-standard-bg);
  color: var(--post-tag-standard-text);
  text-decoration: none;
}

.blog-type-pill,
.blog-type-pill:hover,
.blog-type-pill:focus-visible {
  border-color: var(--post-tag-type-border);
  background: var(--post-tag-type-bg);
  background-color: var(--post-tag-type-bg);
  color: var(--post-tag-type-text);
}

.blog-year-pill,
.blog-year-pill:hover,
.blog-year-pill:focus-visible {
  border-color: var(--post-tag-year-border);
  background: var(--post-tag-year-bg);
  background-color: var(--post-tag-year-bg);
  color: var(--post-tag-year-text);
}

.blog-inline-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: 0;
  flex: 0 0 auto;
  text-decoration: none;
}

.blog-inline-tag:hover {
  text-decoration: none;
}

.blog-compose-fab {
  position: fixed;
  right: 1.35rem;
  bottom: 1.25rem;
  z-index: 60;
  width: 2.6rem;
  min-width: 2.6rem;
  height: 2.6rem;
  padding: 0;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.42rem;
  line-height: 1;
}

.blog-compose-fab[hidden] {
  display: none !important;
}

.blog-compose-fab .blog-compose-fab-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1em;
  height: 1em;
  line-height: 1;
  transform: none;
}

.blog-compose-fab.is-open .blog-compose-fab-icon {
  transform: rotate(45deg);
}

.blog-compose-fab,
.blog-compose-card [data-compose-action="publish"] {
  border: 1px solid var(--action-soft-border, #c58f6f);
  background: var(--action-soft-bg, #f5e4d7) !important;
  color: var(--action-soft-text, #6d3a20) !important;
  -webkit-text-fill-color: var(--action-soft-text, #6d3a20);
}

.blog-compose-fab:hover:not(:disabled),
.blog-compose-fab:focus-visible:not(:disabled),
.blog-compose-card [data-compose-action="publish"]:hover:not(:disabled),
.blog-compose-card [data-compose-action="publish"]:focus-visible:not(:disabled) {
  background: var(--action-soft-hover-bg, #f0d7c5) !important;
  border-color: var(--action-soft-hover-border, #b77753);
  color: var(--action-soft-hover-text, #5b2f18) !important;
  -webkit-text-fill-color: var(--action-soft-hover-text, #5b2f18);
}

.blog-compose-slot {
  overflow: visible;
  max-height: var(--compose-slot-open-max-height, 2200px);
  opacity: 0;
  transform-origin: top center;
  transform: scaleY(0.86);
  transition: transform 320ms ease-in-out, opacity 260ms ease-in-out, margin-bottom 260ms ease-in-out;
  margin-bottom: 0;
  pointer-events: none;
}

.blog-compose-slot[hidden] {
  display: none !important;
}

.blog-compose-slot.is-open {
  max-height: var(--compose-slot-open-max-height, 2200px);
  opacity: 1;
  transform: scaleY(1);
  margin-bottom: 0.85rem;
  pointer-events: auto;
}

.blog-compose-card {
  margin: 0;
  max-width: min(980px, 100%);
  background: var(--post-card-bg, var(--bg));
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.08);
  background-clip: padding-box;
  position: relative;
}

.blog-compose-card.is-drop-hover::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 2px dashed color-mix(in srgb, var(--button-primary-start, #2f5fb8) 58%, var(--border, #c7d2fe) 42%);
  background: color-mix(in srgb, var(--button-primary-start, #2f5fb8) 14%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, #fff 35%, transparent);
  pointer-events: none;
}

.blog-compose-card.is-wide-preview {
  max-width: min(1320px, 100%);
}

.blog-compose-head {
  align-items: flex-start;
  gap: 0.75rem;
}

.blog-compose-head-actions {
  grid-area: actions;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  justify-self: end;
  align-self: start;
  gap: 0.12rem;
}

.blog-compose-card .blog-compose-head-actions .unobtrusive-icon-button {
  width: 2.08rem;
  min-width: 2.08rem;
  height: 2.08rem;
  padding: 0;
  border-radius: 999px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted-text, #4f617f);
}

.blog-compose-card .blog-compose-head-actions .unobtrusive-icon-button:hover:not(:disabled),
.blog-compose-card .blog-compose-head-actions .unobtrusive-icon-button:focus-visible:not(:disabled) {
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 56%, var(--light-bg, #eef3ff) 44%) !important;
  color: var(--text);
}

.blog-compose-card .blog-compose-head-actions .unobtrusive-icon-button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--button-primary-start) 42%, transparent);
  outline-offset: 1px;
}

.blog-compose-btn {
  width: auto;
  min-width: 0;
  padding: 0.34rem 0.82rem !important;
  font-size: 0.94rem !important;
  line-height: 1.15 !important;
}

.blog-compose-body {
  display: grid;
  gap: 0.68rem;
}

.blog-compose-card .blog-compose-head-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "type actions"
    "targets actions";
  align-items: start;
  gap: 0.56rem;
}

.blog-compose-card .field-row {
  display: grid;
  gap: 0.26rem;
}

.blog-compose-card .field-row[hidden] {
  display: none !important;
}

.blog-compose-card .field-row > label,
.blog-compose-card .field-row > strong {
  font-size: 0.86rem;
  color: var(--muted-text, #4f617f);
}

.blog-compose-card .compose-post-type-control {
  display: flex;
  align-items: center;
  min-width: 0;
  gap: 0.34rem;
  grid-area: type;
  width: 100%;
}

.blog-compose-card .compose-post-type-current-btn {
  width: 2.24rem;
  min-width: 2.24rem;
  height: 2.24rem;
  border: 1px solid color-mix(in srgb, var(--button-primary-start, #2f5fb8) 46%, var(--border) 54%) !important;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #111 !important;
  color: color-mix(in srgb, #111 88%, var(--text, #111) 12%) !important;
  -webkit-text-fill-color: #111 !important;
  -webkit-text-fill-color: color-mix(in srgb, #111 88%, var(--text, #111) 12%) !important;
  background: #f6f2e8 !important;
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 92%, #000 8%) !important;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--surface-raised-strong, #fff) 42%, transparent);
  opacity: 0;
  pointer-events: none;
  transform: scale(0.92);
  transition: opacity 220ms ease, transform 220ms ease;
}

.blog-compose-card .compose-post-type-current-btn .compose-post-type-icon {
  width: 1.36rem;
  height: 1.36rem;
  min-width: 1.36rem;
  min-height: 1.36rem;
  display: block;
  opacity: 1;
  color: #2f2517 !important;
  color: color-mix(in srgb, #111 88%, var(--text, #111) 12%) !important;
  stroke: #2f2517 !important;
  stroke: color-mix(in srgb, #111 88%, var(--text, #111) 12%) !important;
  fill: none;
  stroke-width: 2.08;
  vector-effect: non-scaling-stroke;
}

.blog-compose-card .compose-post-type-current-btn .compose-post-type-icon :where(path, circle, rect, line, polyline, polygon, ellipse):not([stroke="none"]) {
  stroke: currentColor !important;
}

.blog-compose-card .compose-post-type-current-btn .compose-post-type-icon [fill="currentColor"] {
  fill: currentColor !important;
}

.blog-compose-card .compose-post-type-toolbar-wrap {
  min-width: 0;
  flex: 1 1 100%;
  max-height: 2.5rem;
  opacity: 1;
  transform-origin: top left;
  transform: translateY(0);
  transition: transform 240ms ease, max-height 240ms ease, max-width 240ms ease;
  max-width: 100%;
}

.blog-compose-card .compose-post-type-row {
  margin: 0;
  overflow-x: auto;
  padding-bottom: 0.06rem;
  scrollbar-width: none;
}

.blog-compose-card .compose-post-type-row::-webkit-scrollbar {
  display: none;
}

.blog-compose-card .compose-post-type-control.is-collapsed .compose-post-type-current-btn {
  opacity: 1;
  pointer-events: auto;
  transform: scale(1);
}

.blog-compose-card .compose-post-type-control.is-collapsed .compose-post-type-toolbar-wrap {
  opacity: 1;
  transform: translateY(-0.5rem);
  max-height: 0;
  width: 0;
  max-width: 0;
  overflow: hidden;
  pointer-events: none;
}

.blog-compose-card .compose-post-type-toolbar {
  display: flex;
  width: 100%;
  flex-wrap: nowrap;
  gap: 0;
  align-items: stretch;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 88%, var(--light-bg, #eef3ff) 12%);
  overflow: hidden;
}

.blog-compose-card .compose-post-type-pill {
  flex: 1 1 0;
  min-width: 0;
  height: 2.18rem;
  padding: 0;
  border: 0;
  border-right: 1px solid var(--border);
  border-radius: 0;
  background: transparent;
  color: var(--text, #2f2517);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.blog-compose-card .compose-post-type-pill:last-child {
  border-right: 0;
}

.blog-compose-card .compose-post-type-pill .compose-post-type-icon {
  width: 1.34rem;
  height: 1.34rem;
  flex: 0 0 auto;
  stroke: currentColor;
  stroke-width: 2.02;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
}

.blog-compose-card .compose-post-type-pill:hover:not(:disabled),
.blog-compose-card .compose-post-type-pill:focus-visible:not(:disabled) {
  background: color-mix(in srgb, var(--light-bg, #eef3ff) 64%, transparent);
}

.blog-compose-card .compose-post-type-pill.is-active {
  background: color-mix(in srgb, var(--button-primary-start) 24%, var(--surface-raised-strong, #fff) 76%);
  color: var(--button-primary-text);
}

.blog-compose-card .compose-post-type-pill.is-disabled,
.blog-compose-card .compose-post-type-pill:disabled {
  opacity: 0.44;
  cursor: not-allowed;
}

.blog-compose-card .compose-nostr-target-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.34rem;
  min-width: 0;
  grid-area: targets;
}

.blog-compose-card .compose-preview-toggle-icon {
  width: 1.38rem;
  height: 1.38rem;
  stroke: currentColor;
  fill: none;
  pointer-events: none;
}

.blog-compose-card .blog-compose-preview-toggle[aria-pressed="true"],
.blog-compose-card .blog-compose-preview-toggle.is-active {
  background: color-mix(in srgb, var(--button-primary-start, #2f5fb8) 18%, var(--surface-raised-strong, #fff) 82%) !important;
  color: color-mix(in srgb, var(--button-primary-start, #2f5fb8) 74%, var(--text, #111) 26%) !important;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--button-primary-start, #2f5fb8) 40%, transparent);
}

.blog-compose-card .blog-compose-preview-toggle[aria-pressed="true"]:hover:not(:disabled),
.blog-compose-card .blog-compose-preview-toggle[aria-pressed="true"]:focus-visible:not(:disabled),
.blog-compose-card .blog-compose-preview-toggle.is-active:hover:not(:disabled),
.blog-compose-card .blog-compose-preview-toggle.is-active:focus-visible:not(:disabled) {
  background: color-mix(in srgb, var(--button-primary-start, #2f5fb8) 26%, var(--surface-raised-strong, #fff) 74%) !important;
}

.blog-compose-card .compose-close-icon {
  width: 1.14rem;
  height: 1.14rem;
  stroke: currentColor;
  fill: none;
  pointer-events: none;
}

.blog-compose-card.blog-compose-type-only .blog-compose-head-row {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas: "type";
}

.blog-compose-card.blog-compose-type-only .blog-compose-type-title {
  margin: 0 0 0.16rem;
  font-size: 0.96rem;
  color: var(--text);
}

.blog-compose-card.blog-compose-type-only {
  min-height: 0;
  padding-bottom: 2em;
}

.blog-compose-card.blog-compose-type-only .blog-compose-body {
  gap: 0.42rem;
}

.blog-compose-card.blog-compose-type-only .compose-post-type-control {
  width: 100%;
}

.blog-compose-card.blog-compose-type-only .compose-post-type-control.is-choose-mode {
  gap: 0;
  margin-top: 1em;
  margin-bottom: -1em;
}

.blog-compose-card.blog-compose-type-only .compose-post-type-current-btn {
  display: none;
}

.blog-compose-card.blog-compose-type-only .compose-post-type-toolbar-wrap {
  max-height: none;
  width: 100%;
  flex: 1 1 100%;
}

.blog-compose-card.blog-compose-type-only .compose-post-type-row {
  overflow-x: visible;
  padding-bottom: 0;
}

.blog-compose-card.blog-compose-type-only .compose-post-type-pill {
  height: 2.74rem;
}

.blog-compose-card.blog-compose-type-only .compose-post-type-pill .compose-post-type-icon {
  width: 1.78rem;
  height: 1.78rem;
}

.blog-compose-main-shell {
  display: block;
}

.blog-compose-islands {
  --blog-compose-wide-max: 1480px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.74fr);
  width: min(var(--blog-compose-wide-max), calc(100vw - 1.25rem));
  max-width: none;
  margin-left: 50%;
  transform: translateX(-50%);
  justify-content: stretch;
  align-items: start;
  gap: 0.82rem;
}

.blog-compose-islands .blog-compose-card {
  max-width: 100%;
}

.blog-compose-preview-card {
  margin: 0;
  max-width: 100%;
  min-height: 0;
}

.blog-compose-preview-card .blog-compose-preview-card-body {
  display: grid;
  gap: 0.36rem;
}

.blog-compose-preview-card .preview-box {
  margin-top: 0.08rem;
}

.blog-compose-inline-preview {
  margin-top: 0.24rem;
}

.blog-compose-card.is-wide-preview .blog-compose-main-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.82fr);
  gap: 0.78rem;
  align-items: start;
}

.blog-compose-side-preview {
  min-width: 0;
}

.blog-compose-side-preview .preview-box {
  margin-top: 0.08rem;
}

.blog-compose-card .blog-compose-head-row.is-type-collapsed {
  grid-template-columns: auto minmax(0, 1fr) auto;
  grid-template-areas: "type targets actions";
  align-items: center;
}

.blog-compose-card .blog-compose-head-row.is-type-collapsed .compose-post-type-control {
  width: auto;
  min-width: 2.06rem;
}

.blog-compose-card .nostr-target-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.15rem 0.48rem;
  border-radius: 999px;
  border: 1px solid var(--admin-border, #c7d6f3);
  background: var(--admin-surface-alt, #f5f8ff);
  color: var(--admin-text, #3b4a63);
  font-size: 0.75rem;
  line-height: 1.1;
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}

.blog-compose-card .nostr-page-kind-badge {
  display: inline-flex;
  align-items: center;
  align-self: center;
  border-radius: 999px;
  border: 1px solid var(--admin-border, #c7d6f3);
  background: var(--admin-surface-alt, #f5f8ff);
  color: var(--admin-text, #3b4a63);
  font-size: 0.75rem;
  line-height: 1.1;
  padding: 0.15rem 0.48rem;
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}

.blog-compose-card .nostr-page-kind-badge.is-type-blog {
  border-color: color-mix(in srgb, #2563eb 35%, var(--admin-border, #c7d6f3) 65%);
  background: color-mix(in srgb, #2563eb 12%, var(--admin-surface-alt, #f5f8ff) 88%);
  color: #1f3f77;
}

.blog-compose-card .nostr-page-kind-badge.is-type-nip23 {
  border-color: color-mix(in srgb, #7c3aed 35%, var(--admin-border, #c7d6f3) 65%);
  background: color-mix(in srgb, #7c3aed 11%, var(--admin-surface-alt, #f5f8ff) 89%);
  color: #5e3d9a;
}

.blog-compose-card .nostr-page-kind-badge.is-type-public-ranking {
  border-color: color-mix(in srgb, #0f766e 38%, var(--admin-border, #c7d6f3) 62%);
  background: color-mix(in srgb, #0f766e 11%, var(--admin-surface-alt, #f5f8ff) 89%);
  color: #1c5d57;
}

.blog-compose-card .nostr-page-kind-badge.is-type-contact {
  border-color: color-mix(in srgb, #92400e 34%, var(--admin-border, #c7d6f3) 66%);
  background: color-mix(in srgb, #f59e0b 13%, var(--admin-surface-alt, #f5f8ff) 87%);
  color: #7a3f18;
}

.blog-compose-card .nostr-page-kind-badge.is-type-list {
  border-color: color-mix(in srgb, #4b5563 30%, var(--admin-border, #c7d6f3) 70%);
  background: color-mix(in srgb, #94a3b8 10%, var(--admin-surface-alt, #f5f8ff) 90%);
  color: #495464;
}

.blog-compose-card .nostr-page-kind-badge.is-type-icon-gallery {
  border-color: color-mix(in srgb, #2563eb 34%, var(--admin-border, #c7d6f3) 66%);
  background: color-mix(in srgb, #3b82f6 12%, var(--admin-surface-alt, #f5f8ff) 88%);
  color: #1f4b8a;
}

.blog-compose-card .nostr-page-kind-badge.is-type-overworld {
  border-color: color-mix(in srgb, #2f6f54 36%, var(--admin-border, #c7d6f3) 64%);
  background: color-mix(in srgb, #2f6f54 12%, var(--admin-surface-alt, #f5f8ff) 88%);
  color: #24513f;
}

.blog-compose-card .compose-media-tools {
  display: grid;
  gap: 0.36rem;
  padding: 0.46rem 0.5rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 84%, var(--light-bg, #eef3ff) 16%);
}

.blog-compose-card .compose-media-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.28rem;
}

.blog-compose-card .compose-mode-panel {
  margin: 0.06rem 0 0.12rem;
}

.blog-compose-card .compose-media-btn {
  width: auto;
  min-width: 0;
  padding: 0.28rem 0.5rem;
  border-radius: 8px;
  font-size: 0.78rem;
  line-height: 1.15;
}

.blog-compose-card .compose-media-btn-primary {
  font-weight: 700;
  border-width: 1px;
}

.blog-compose-card .compose-camera-panel {
  gap: 0.5rem;
}

.blog-compose-card .compose-camera-shell {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #05070d;
  overflow: hidden;
  aspect-ratio: 16 / 9;
}

.blog-compose-card .compose-camera-preview {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.blog-compose-card .compose-camera-status {
  font-size: 0.78rem;
  color: var(--light-text);
}

body.blog-camera-mode-active {
  overflow: hidden;
}

.blog-compose-camera-overlay {
  position: fixed;
  inset: 0;
  z-index: 1400;
  background: color-mix(in srgb, #04070f 68%, transparent);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.blog-compose-camera-overlay-shell {
  width: min(96vw, 1120px);
  display: grid;
  gap: 0.56rem;
}

.blog-compose-camera-overlay-stage {
  width: 100%;
  border: 1px solid color-mix(in srgb, var(--border, #c8d4f3) 68%, #fff 32%);
  border-radius: 14px;
  background: #05070d;
  overflow: hidden;
  aspect-ratio: 16 / 9;
}

.blog-compose-camera-overlay-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.blog-compose-camera-overlay-controls {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.42rem;
}

.blog-compose-camera-control,
.blog-compose-camera-capture {
  width: auto;
  min-width: 0;
}

.blog-compose-camera-control {
  color: var(--surface-raised-strong, #fff) !important;
  border-radius: 999px !important;
  padding: 0.38rem 0.75rem !important;
}

.blog-compose-camera-overlay-status {
  text-align: center;
  font-size: 0.82rem;
  color: color-mix(in srgb, var(--surface-raised-strong, #fff) 88%, #9fb7ef 12%);
}

.blog-compose-card .compose-link-fields {
  display: grid;
  gap: 0.28rem;
}

.blog-compose-card .compose-link-fields textarea {
  min-height: 4.4rem;
}

.blog-compose-shortform-meter {
  margin-top: 0.2rem;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.3rem;
}

.blog-compose-shortform-corner {
  position: absolute;
  right: 0.56rem;
  bottom: 0.42rem;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.34rem;
  z-index: 2;
  pointer-events: none;
}

.blog-compose-shortform-corner .blog-compose-shortform-meter {
  margin-top: 0;
  pointer-events: auto;
}

.blog-compose-shortform-limit-btn {
  width: auto;
  min-width: 0;
  padding: 0.14rem 0.42rem;
  border-radius: 8px;
  font-size: 0.74rem;
  line-height: 1.16;
  color: var(--light-text);
}

.blog-compose-shortform-limit-input {
  width: 5.6rem;
  min-width: 0;
  padding: 0.18rem 0.35rem;
  font-size: 0.74rem;
  line-height: 1.2;
}

.blog-compose-card .compose-audio-panel {
  gap: 0.5rem;
}

.blog-compose-card .compose-audio-status {
  font-size: 0.78rem;
  color: var(--light-text);
}

.blog-compose-title-row {
  grid-template-columns: minmax(0, 1fr);
  align-items: center;
  column-gap: 0;
}

.blog-compose-card .compose-post-filename-row {
  gap: 0.34rem;
}

.blog-compose-card .compose-post-filename-display {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.blog-compose-card .compose-post-filename-value {
  display: inline-block;
  padding: 0.14rem 0.46rem;
  border-radius: 7px;
  border: 1px solid color-mix(in srgb, var(--border, #c7d2fe) 72%, transparent);
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 88%, var(--light-bg, #eef3ff) 12%);
  color: var(--light-text, #475569);
  font-size: 0.8rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.blog-compose-card .compose-post-filename-edit-wrap {
  display: inline-flex;
  align-items: center;
  gap: 0.24rem;
  flex-wrap: nowrap;
}

.blog-compose-card .compose-post-filename-prefix,
.blog-compose-card .compose-post-filename-suffix {
  color: var(--light-text, #475569);
  font-size: 0.8rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  white-space: nowrap;
}

.blog-compose-card .compose-post-filename-edit-wrap input[type="text"] {
  width: min(24rem, 100%);
  max-width: 100%;
}

.blog-compose-card input[type="text"],
.blog-compose-card input[type="datetime-local"] {
  width: min(30rem, 100%);
  max-width: 100%;
}

.blog-compose-card input[data-compose-field="title"] {
  height: 2.26rem;
  padding: 0.34rem 0.58rem;
}

.blog-compose-card input[data-post-inline-field="title"],
.blog-compose-card input[data-post-inline-field="tags"],
.blog-compose-card input[data-post-inline-field="post_filename"] {
  height: 2.26rem;
  padding: 0.34rem 0.58rem;
}

.blog-compose-editor-shell {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-raised-strong, #fff);
  overflow: hidden;
}

.blog-compose-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.24rem;
  padding: 0.34rem 0.42rem;
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface-raised-strong, #fff) 76%, var(--light-bg, #eef3ff) 24%);
}

.blog-compose-toolbar .toolbar-button {
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: color-mix(in srgb, var(--button-primary-start, #2f5fb8) 88%, var(--text) 12%);
  font-size: 0.8rem;
  font-weight: 650;
  padding: 0;
  box-shadow: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.blog-compose-toolbar .toolbar-button:hover,
.blog-compose-toolbar .toolbar-button:focus-visible {
  outline: 0;
  background: color-mix(in srgb, var(--button-primary-start, #2f5fb8) 18%, var(--surface-raised-strong, #fff) 82%);
  color: var(--text);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--button-primary-start, #2f5fb8) 40%, var(--border) 60%);
}

.blog-compose-toolbar .tb-icon {
  width: 1.05rem;
  height: 1.05rem;
  stroke: currentColor;
  flex: 0 0 auto;
  pointer-events: none;
}

.blog-compose-toolbar .tb-glyph {
  display: inline-block;
  line-height: 1;
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0;
  color: currentColor;
  pointer-events: none;
  user-select: none;
}

.blog-compose-toolbar .tb-glyph-italic {
  font-style: italic;
  font-family: Georgia, 'Times New Roman', serif;
}

.blog-compose-toolbar .tb-glyph-heading {
  font-size: 0.72rem;
  letter-spacing: 0.02em;
}

.blog-compose-toolbar .tb-glyph-code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
  font-size: 0.72rem;
  font-weight: 700;
}

.blog-compose-toolbar .tb-glyph-quote {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 0.92rem;
  font-weight: 700;
}

.blog-compose-toolbar .tb-glyph-list {
  font-size: 0.78rem;
}

.blog-compose-editor-shell textarea[data-compose-field="content"],
.blog-compose-editor-shell textarea[data-post-inline-field="content"] {
  width: 100%;
  border: 0;
  border-radius: 0;
  background: transparent;
  min-height: 16rem;
  resize: vertical;
  padding-bottom: 1.7rem;
}

.blog-compose-editor-shell .compose-editor-autosave {
  position: absolute;
  right: 0.56rem;
  bottom: 0.42rem;
  margin: 0;
  min-height: 0.88rem;
  font-size: 0.72rem;
  line-height: 1;
  pointer-events: none;
  z-index: 2;
}

.blog-compose-editor-shell .compose-editor-autosave.is-shortform-corner {
  position: static;
  right: auto;
  bottom: auto;
}

.blog-compose-upload-list {
  margin-top: 0.5rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  display: grid;
  gap: 0.28rem;
}

.blog-compose-upload-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(14rem, 24rem);
  align-items: center;
  gap: 0.64rem;
}

.blog-compose-upload-name {
  font-size: 0.78rem;
  line-height: 1.2;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.blog-compose-upload-progress {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.42rem;
}

.blog-compose-upload-state {
  font-size: 0.72rem;
  color: var(--muted-text, #4f617f);
  white-space: nowrap;
  min-width: 2.8rem;
  text-align: right;
}

.blog-compose-upload-row.is-error .blog-compose-upload-state {
  color: var(--status-error-text, #991b1b);
}

.blog-compose-upload-row.is-done .blog-compose-upload-state {
  color: var(--muted-text, #4f617f);
}

.blog-compose-upload-track {
  width: 100%;
  height: 0.34rem;
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--border, #c8d4f3) 52%, var(--light-bg, #eef3ff) 48%);
}

.blog-compose-upload-fill {
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: color-mix(in srgb, var(--button-primary-start, #2f5fb8) 54%, #9fd3ff 46%);
  transition: width 140ms linear;
}

.blog-compose-upload-row.is-error .blog-compose-upload-fill {
  background: linear-gradient(90deg, var(--status-error-text, #991b1b) 0%, color-mix(in srgb, var(--status-error-text, #991b1b) 72%, #000 28%) 100%);
}

.blog-compose-upload-row.is-done .blog-compose-upload-fill {
  background: color-mix(in srgb, var(--button-primary-start, #2f5fb8) 54%, #9fd3ff 46%);
}

@media (max-width: 720px) {
  .blog-compose-upload-row {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.28rem;
  }
}

.blog-compose-card .grid-two {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.68rem;
}

.blog-compose-preview-split {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
  align-items: start;
}

.blog-compose-split-editor,
.blog-compose-split-preview {
  min-width: 0;
}

.blog-compose-split-preview .preview-box {
  margin-top: 0.08rem;
}

.blog-compose-card .tag-editor {
  width: min(30rem, 100%);
  max-width: 100%;
}

.blog-compose-card .tag-token-editor {
  width: 100%;
  min-height: 2.2rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.24rem 0.42rem;
  background: var(--surface-raised-strong, #fff);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.32rem;
  cursor: text;
}

.blog-compose-card .tag-token-editor:focus-within {
  outline: 0;
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent, #3158a4) 32%, transparent);
  border-color: color-mix(in srgb, var(--accent, #3158a4) 62%, var(--border, #c7d2fe) 38%);
}

.blog-compose-card .tag-token {
  display: inline-flex;
  align-items: center;
  gap: 0.24rem;
  max-width: 100%;
  border-radius: 999px;
  border: 1px solid var(--tag-border, #c8d4f3);
  background: var(--tag-bg, #e8eeff);
  color: var(--tag-text, #2f4aa6);
  padding: 0.12rem 0.22rem 0.12rem 0.48rem;
  font-size: 0.77rem;
  line-height: 1.2;
  user-select: none;
}

.blog-compose-card .tag-token-label {
  overflow-wrap: anywhere;
}

.blog-compose-card .tag-token-remove {
  appearance: none;
  display: inline-grid;
  place-items: center;
  width: 1.08rem;
  height: 1.08rem;
  min-width: 1.08rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: currentColor;
  font: inherit;
  line-height: 1;
  cursor: pointer;
}

.blog-compose-card .tag-token-remove:hover,
.blog-compose-card .tag-token-remove:focus-visible {
  outline: 0;
  background: color-mix(in srgb, currentColor 14%, transparent);
}

.blog-compose-card .tag-token.is-selected {
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent, #3158a4) 34%, transparent);
  border-color: color-mix(in srgb, var(--accent, #3158a4) 68%, var(--tag-border, #c8d4f3) 32%);
}

.blog-compose-card .tag-token-editor-input {
  flex: 1 1 9rem;
  min-width: min(100%, 8rem);
  height: 1.55rem;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  font: inherit;
  font-size: 0.86rem;
  outline: none;
  color: var(--text);
}

.blog-compose-card .tag-token-editor-input:focus {
  outline: none;
}

.blog-compose-card .compose-tags-toggle {
  width: auto;
  min-width: 0;
  justify-self: start;
  padding: 0.2rem 0.5rem;
  border-radius: 8px;
  font-size: 0.76rem;
  line-height: 1.2;
}

.blog-compose-card .mode-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.68rem;
  align-items: center;
  font-size: 0.86rem;
}

.blog-compose-card .mode-row label {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}

.blog-compose-card .scheduled-row.is-hidden {
  display: none;
}

.blog-compose-card .compose-release-row {
  position: relative;
}

.blog-compose-card .compose-scheduled-picker-hidden {
  position: absolute;
  top: 0;
  left: 0;
  width: 1px !important;
  min-width: 1px !important;
  height: 1px !important;
  min-height: 1px !important;
  opacity: 0.001;
  pointer-events: none;
  z-index: 1;
}

.blog-compose-card .compose-scheduled-value {
  margin-top: 0.12rem;
  font-size: 0.78rem;
  color: var(--muted-text, #4f617f);
}

.blog-compose-preview {
  margin: 0;
}

.blog-compose-footer {
  margin-top: 0.6rem;
  display: grid;
  gap: 0.22rem;
}

.blog-compose-footer-actions {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.blog-compose-publish-stack {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.16rem;
}

.blog-compose-publish-row {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.34rem;
  flex-wrap: wrap;
}

.blog-compose-delete {
  border: 0 !important;
  background: transparent !important;
  color: var(--danger) !important;
  -webkit-text-fill-color: var(--danger) !important;
  width: 2.15rem !important;
  min-width: 2.15rem !important;
  height: 2.05rem !important;
  padding: 0 !important;
  border-radius: 8px !important;
}

.blog-compose-delete .trash-icon-svg {
  width: 1.16rem;
  height: 1.16rem;
}

.blog-compose-delete:hover:not(:disabled),
.blog-compose-delete:focus-visible:not(:disabled) {
  background: var(--danger-soft) !important;
  color: var(--danger) !important;
  -webkit-text-fill-color: var(--danger) !important;
}

.blog-compose-status-row {
  display: grid;
  gap: 0.35rem;
}

.blog-compose-status-row .output {
  margin: 0;
  min-height: 0;
}

.blog-compose-status-row .output:empty {
  display: none;
}

@keyframes blog-compose-fade-in {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .blog-compose-slot {
    transition: none;
  }
}

@media (max-width: 900px) {
  .blog-layout {
    margin-left: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .blog-main-column {
    grid-column: 1;
  }

  .blog-filter-grid {
    grid-template-columns: 1fr;
  }

  .blog-filter-footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .blog-compose-fab {
    right: 0.8rem;
    bottom: 0.9rem;
  }

  .blog-compose-card .compose-post-type-pill {
    flex: 1 1 0;
    min-width: 0;
    height: 2.04rem;
  }

  .blog-compose-card .blog-compose-head-row {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "type actions"
      "targets actions";
    row-gap: 0.42rem;
  }

  .blog-compose-card .compose-post-type-control {
    grid-area: type;
  }

  .blog-compose-card .compose-nostr-target-row {
    grid-area: targets;
  }

  .blog-compose-card .blog-compose-head-actions {
    grid-area: actions;
  }

  .blog-compose-preview-split {
    grid-template-columns: minmax(0, 1fr);
  }

  .blog-compose-islands {
    width: 100%;
    margin-left: 0;
    transform: none;
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 640px) {
  .blog-compose-card .blog-compose-head-row.is-type-collapsed {
    grid-template-columns: auto minmax(0, 1fr) auto;
    grid-template-areas: "type targets actions";
  }

  .blog-compose-card .blog-compose-title-row {
    grid-template-columns: 1fr;
    gap: 0.44rem;
  }

  .blog-compose-card .compose-media-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.28rem;
  }

  .blog-compose-card .compose-media-btn {
    justify-content: center;
  }

  .blog-compose-card .compose-post-type-pill {
    flex: 1 1 0;
    min-width: 0;
    height: 1.96rem;
  }
}

.tag-results-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0.6rem;
}

.tag-result-item {
  margin: 0;
  padding: 0.55rem 0.65rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.65);
}

.tag-result-item a {
  font-weight: 600;
}

@media (min-width: 980px) {
  #tag-cloud {
    display: grid;
    grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
  }

  #tag-cloud .tag-cloud {
    margin: 0;
    padding: 0.8rem;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.64);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.45rem;
    max-height: calc(100vh - 8.5rem);
    overflow: auto;
    position: sticky;
    top: 0.7rem;
  }

  #tag-cloud .tag-cloud .tag {
    width: auto;
    max-width: 100%;
    display: inline-flex;
  }

  #tag-cloud .tag-results {
    margin-top: 0;
    grid-column: 2;
    grid-row: 1 / span 2;
  }

  #tag-cloud .tag-filter-hint {
    margin: 0.5rem 0 0;
    grid-column: 1;
    grid-row: 2;
  }
}

.loading-tags {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: var(--light-text);
  font-style: italic;
}

.loading-spinner {
  width: 0.95rem;
  height: 0.95rem;
  border: 2px solid #cfd6e3;
  border-top-color: var(--accent);
  border-radius: 999px;
  animation: spin 0.75s linear infinite;
}

.zaps-runtime-action.is-loading {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  cursor: progress;
}

.zaps-runtime-action.is-loading .loading-spinner {
  width: 0.85rem;
  height: 0.85rem;
  border-width: 2px;
}

/* Responsive */
@media (max-width: 600px) {
  body {
    padding: 1rem;
  }
  
  h1 {
    font-size: 2rem;
  }
  
  h2 {
    font-size: 1.5rem;
  }
  
  .post-nav {
    flex-direction: column;
    gap: 1rem;
  }
  
  .post-nav-next {
    text-align: left;
  }
}

/* Info Boxes */
.info-box {
  background: var(--light-bg);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 1rem;
  margin: 1.5rem 0;
}

.info-box strong {
  color: var(--primary);
}

/* Search Box */
.search-box {
  margin: 2rem 0;
  padding: 1.5rem;
  background: var(--light-bg);
  border: 1px solid var(--border);
  border-radius: 5px;
}

.search-box form {
  display: flex;
  gap: 0.5rem;
}

.search-box input[type="text"] {
  flex: 1;
  padding: 0.75rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  font-size: 1rem;
}

.search-box button {
  padding: 0.75rem 1.5rem;
  background-image: var(--button-primary-overlay), linear-gradient(135deg, var(--button-primary-start) 0%, var(--button-primary-end) 100%);
  color: var(--button-primary-text);
  border: 1px solid var(--button-primary-border);
  border-radius: 3px;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 500;
}

.search-box button:hover {
  background-image: var(--button-primary-overlay), linear-gradient(135deg, var(--button-primary-hover-start) 0%, var(--button-primary-hover-end) 100%);
}

/* Search Form (in results page) */
.search-form {
  margin: 2rem 0;
  padding: 1.5rem;
  background: var(--light-bg);
  border: 1px solid var(--border);
  border-radius: 5px;
}

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

.search-form input[type="text"] {
  flex: 1;
  padding: 0.75rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  font-size: 1rem;
}

.search-form button {
  padding: 0.75rem 1.5rem;
  background-image: var(--button-primary-overlay), linear-gradient(135deg, var(--button-primary-start) 0%, var(--button-primary-end) 100%);
  color: var(--button-primary-text);
  border: 1px solid var(--button-primary-border);
  border-radius: 3px;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 500;
}

.search-form button:hover {
  background-image: var(--button-primary-overlay), linear-gradient(135deg, var(--button-primary-hover-start) 0%, var(--button-primary-hover-end) 100%);
}

/* Search Results */
.search-results {
  margin: 2rem 0;
}

.search-results h2 {
  margin-bottom: 1.5rem;
}

/* Pagination */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  margin: 3rem 0;
  padding: 1rem 0;
}

.page-link {
  padding: 0.5rem 1rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  color: var(--accent);
  text-decoration: none;
  font-weight: 500;
}

.page-link:hover:not(.disabled) {
  background: transparent;
  text-decoration: none;
}

.page-link.disabled {
  color: var(--light-text);
  cursor: not-allowed;
  opacity: 0.5;
}

.page-info {
  padding: 0.5rem 1rem;
  color: var(--text);
  font-weight: 500;
}

/* Authentication Page Styles */
.demo-box {
  background: linear-gradient(145deg, #f8f9fa 0%, #ffffff 100%);
  border: 2px solid var(--accent);
  border-radius: 12px;
  padding: 2rem;
  margin: 2rem 0;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
}

.demo-box h2 {
  margin-top: 0;
  color: var(--primary);
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

/* Button Styles - Default Unobtrusive */
button,
input[type="button"],
input[type="submit"],
input[type="reset"],
[role="button"],
.btn {
  background: transparent;
  background-image: none;
  color: var(--text);
  border: 1px solid var(--border);
  padding: 0.875rem 1.75rem;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 520;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
  text-decoration: none;
  display: inline-block;
}

input[type="button"],
input[type="submit"],
input[type="reset"],
[role="button"] {
  cursor: pointer;
}

button:hover:not(:disabled),
input[type="button"]:hover:not(:disabled),
input[type="submit"]:hover:not(:disabled),
input[type="reset"]:hover:not(:disabled),
[role="button"]:hover:not([aria-disabled="true"]),
.btn:hover:not(:disabled) {
  background: var(--nav-link-hover);
  background-image: none;
  border-color: color-mix(in srgb, var(--border) 65%, var(--accent) 35%);
  color: var(--text);
}

button:active:not(:disabled),
input[type="button"]:active:not(:disabled),
input[type="submit"]:active:not(:disabled),
input[type="reset"]:active:not(:disabled),
[role="button"]:active:not([aria-disabled="true"]),
.btn:active:not(:disabled) {
  background: color-mix(in srgb, var(--nav-link-hover) 80%, var(--bg) 20%);
  background-image: none;
  border-color: color-mix(in srgb, var(--border) 58%, var(--accent) 42%);
  color: var(--text);
}

button:disabled,
input[type="button"]:disabled,
input[type="submit"]:disabled,
input[type="reset"]:disabled,
[role="button"][aria-disabled="true"],
.btn:disabled {
  opacity: 0.56;
  cursor: default;
  background: color-mix(in srgb, var(--surface-raised, #fff) 58%, var(--light-bg, #eef3ff) 42%);
  background-image: none;
  border-color: color-mix(in srgb, var(--border, #c7d2fe) 78%, #a9b4cc 22%);
  color: color-mix(in srgb, var(--light-text, #64748b) 88%, #7f8aa3 12%);
  box-shadow: none;
  filter: saturate(0.58) contrast(0.92);
}

button:disabled:hover,
input[type="button"]:disabled:hover,
input[type="submit"]:disabled:hover,
input[type="reset"]:disabled:hover,
[role="button"][aria-disabled="true"]:hover,
.btn:disabled:hover {
  background: color-mix(in srgb, var(--surface-raised, #fff) 58%, var(--light-bg, #eef3ff) 42%);
  background-image: none;
  border-color: color-mix(in srgb, var(--border, #c7d2fe) 78%, #a9b4cc 22%);
  color: color-mix(in srgb, var(--light-text, #64748b) 88%, #7f8aa3 12%);
  box-shadow: none;
}

/* Keep content-area buttons no taller than nav controls. */
main button:not(.unobtrusive-icon-button):not(.nav-menu-btn):not(.post-page-menu-trigger):not(.admin-nav-item):not(.contact-value-link):not([role="menuitem"]),
main input[type="button"],
main input[type="submit"],
main input[type="reset"],
main [role="button"]:not(.list-inline-open):not(.admin-nav-item),
main .btn {
  padding: 0.34rem 0.82rem;
  line-height: 1.15;
}

/* Keep page-head edit links unobtrusive (override global button chrome). */
button.list-inline-edit-link,
.list-page-head button.list-inline-edit-link,
.list-page-head .list-inline-edit-link,
.list-page-nav-title-row .list-page-nav-title-edit-link {
  border: 0;
  background: transparent;
  background-image: none;
  padding: 0;
  min-height: 0;
  border-radius: 0;
  font-size: 0.82rem;
  font-weight: 400;
  line-height: 1.2;
  color: #46619a;
  -webkit-text-fill-color: #46619a;
  box-shadow: none;
  display: inline-flex;
  align-items: baseline;
}

button.list-inline-edit-link:hover:not(:disabled),
button.list-inline-edit-link:focus-visible:not(:disabled),
.list-page-head button.list-inline-edit-link:hover:not(:disabled),
.list-page-head button.list-inline-edit-link:focus-visible:not(:disabled),
.list-page-head .list-inline-edit-link:hover,
.list-page-head .list-inline-edit-link:focus-visible,
.list-page-nav-title-row .list-page-nav-title-edit-link:hover,
.list-page-nav-title-row .list-page-nav-title-edit-link:focus-visible {
  border: 0;
  background: transparent !important;
  color: #46619a !important;
  -webkit-text-fill-color: #46619a;
  text-decoration: underline;
  box-shadow: none;
}

/* Keep icon-only controls unobtrusive. */
.nav-menu-btn,
.post-page-menu-trigger,
.unobtrusive-icon-button {
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  color: inherit;
  box-shadow: none;
}

.nostr-page-drag-handle {
  color: var(--admin-text, var(--text)) !important;
  -webkit-text-fill-color: var(--admin-text, var(--text)) !important;
}

.nav-menu-btn:hover:not(:disabled),
.nav-menu-btn:active:not(:disabled),
.post-page-menu-trigger:hover:not(:disabled),
.post-page-menu-trigger:active:not(:disabled),
.unobtrusive-icon-button:hover:not(:disabled),
.unobtrusive-icon-button:active:not(:disabled) {
  background-image: none !important;
}

/* List inline editor cells use role=button for keyboard support; keep them text-like, not primary buttons. */
.list-page-shell [role="button"].list-inline-open {
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0.24rem 0.1rem !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text) !important;
  font-size: inherit !important;
  font-weight: 400 !important;
  cursor: text !important;
  display: inline-block !important;
}

.list-page-shell .list-entry-inline [role="button"].list-inline-open.list-inline-markdown {
  padding-left: calc(0.1rem + var(--list-depth-indent)) !important;
}

.list-page-shell [role="button"].list-inline-open:hover,
.list-page-shell [role="button"].list-inline-open:focus-visible,
.list-page-shell [role="button"].list-inline-open:active {
  background: rgba(49, 103, 189, 0.04) !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Keep inline list text inputs compact; do not inherit oversized generic field sizing. */
.list-page-shell .list-entry-inline input[type="text"],
.list-page-shell .list-entry-read-inline input[type="text"],
.list-page-shell .list-inline-eventid input[type="text"] {
  height: 2rem !important;
  min-height: 2rem !important;
  padding: 0.35rem 0.55rem !important;
  line-height: 1.2 !important;
}

/* Input Fields */
input[type="text"],
input[type="email"],
input[type="password"],
textarea {
  width: 100%;
  padding: 0.875rem 1rem;
  border: 2px solid var(--border);
  border-radius: 8px;
  font-size: 1rem;
  transition: all 0.3s ease;
  background: white;
  font-family: inherit;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.1);
}

/* Form Groups */
.form-group {
  margin-bottom: 1.5rem;
}

.form-group label {
  display: block;
  margin-bottom: 0.5rem;
  color: var(--primary);
  font-weight: 500;
}

.help-text {
  font-size: 0.9rem;
  color: var(--light-text);
  margin-bottom: 1rem;
  line-height: 1.5;
}

.divider {
  margin: 2rem 0;
  border: none;
  border-top: 1px solid var(--border);
}

/* Output/Message Boxes */
.output {
  min-height: 20px;
  margin-top: 1rem;
  animation: fadeIn 0.3s ease;
}

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

.zap-inline-host {
  display: block;
}

.post-head > .zap-inline-host.is-compact {
  position: absolute;
  top: 0;
  right: 2.45rem;
  z-index: 55;
}

.zap-inline-host.is-compact .zap-compact-btn {
  width: calc(2rem - 1px);
  min-width: calc(2rem - 1px);
  height: calc(2rem - 1px);
  min-height: calc(2rem - 1px);
  padding: 0;
  border-radius: 50%;
  line-height: 1;
  box-shadow: none;
}

.zap-inline-host.is-compact .zap-compact-btn .zap-icon {
  transform: translate(-0.5px, 0);
}

.zap-inline-host.is-compact .zap-compact-btn:hover,
.zap-inline-host.is-compact .zap-compact-btn:focus-visible {
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.1);
}

.zap-inline-card {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.9rem;
  width: fit-content;
  max-width: 100%;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 1rem;
  background: linear-gradient(145deg, rgba(252, 243, 218, 0.96), rgba(255, 255, 255, 0.94));
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
}

.zap-inline-copy {
  display: grid;
  gap: 0.18rem;
}

.zap-inline-kicker {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-transform: none;
  color: #8a5a00;
}

.zap-inline-title {
  font-size: 1rem;
  line-height: 1.3;
}

.zap-inline-meta {
  font-size: 0.86rem;
  color: rgba(17, 24, 39, 0.72);
}

.zap-inline-actions {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}

.zap-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  width: fit-content;
  max-width: 100%;
  min-height: 2.55rem;
  padding: 0.72rem 1rem;
  border: 1px solid rgba(17, 24, 39, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: inherit;
  font: inherit;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  transition: box-shadow 160ms ease, border-color 160ms ease, background-color 160ms ease;
}

.zap-icon {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 1.18em;
  height: 1.18em;
}

.zap-icon svg {
  display: block;
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.zap-action-btn:hover:not(:disabled),
.zap-action-btn:focus-visible {
  border-color: rgba(17, 24, 39, 0.25);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.1);
}

.zap-action-btn:disabled,
.zap-action-btn[aria-disabled="true"] {
  cursor: default;
  opacity: 0.62;
  transform: none;
  box-shadow: none;
}

.zap-action-btn-primary {
  border-color: rgba(116, 57, 204, 0.45);
  background: linear-gradient(135deg, #7c3aed, #a855f7 58%, #d946ef);
  color: #fff;
  text-shadow: 0 1px 1px rgba(43, 19, 92, 0.3);
}

.zap-dialog-shell {
  position: fixed;
  inset: 0;
  z-index: 1600;
}

.zap-dialog-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(4px);
}

.zap-dialog-panel {
  position: relative;
  z-index: 1;
  width: min(42rem, calc(100vw - 1.5rem));
  max-height: calc(100vh - 1.5rem);
  margin: 0.75rem auto;
  overflow: hidden;
  border: 1px solid rgba(124, 58, 237, 0.16);
  border-radius: 1.35rem;
  background:
    radial-gradient(circle at top left, rgba(216, 180, 254, 0.28), transparent 42%),
    linear-gradient(150deg, #fffaf0 0%, #fff7ed 46%, #f8f3ff 100%);
  box-shadow: 0 26px 70px rgba(43, 19, 92, 0.24);
}

.zap-dialog-scroll {
  max-height: calc(100vh - 1.5rem);
  overflow: auto;
}

.zap-dialog-close {
  position: absolute;
  top: 0.7rem;
  right: 0.7rem;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 2.1rem;
  height: 2.1rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.08);
  color: inherit;
  font-size: 1.35rem;
  font-family: inherit;
  line-height: 1;
  cursor: pointer;
}

.zap-dialog-close:hover,
.zap-dialog-close:focus-visible {
  background: rgba(15, 23, 42, 0.16);
}

.zap-dialog-head,
.zap-dialog-grid,
.zap-dialog-actions,
.zap-dialog-status,
.zap-dialog-invoice {
  margin: 0 1.05rem;
}

.zap-dialog-head {
  padding: 1.35rem 2.8rem 0.45rem 0;
}

.zap-dialog-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.36rem;
  margin: 0 0 0.28rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-transform: none;
  color: #6d28d9;
}

.zap-dialog-head h3 {
  margin: 0;
  font-size: clamp(1.2rem, 2vw, 1.7rem);
  line-height: 1.15;
}

.zap-dialog-subtitle {
  margin: 0.48rem 0 0;
  max-width: 34rem;
  color: rgba(17, 24, 39, 0.72);
  line-height: 1.42;
}

.zap-dialog-grid {
  display: grid;
  gap: 0.9rem;
  padding: 0.7rem 0 0;
}

.zap-dialog-field {
  display: grid;
  gap: 0.45rem;
}

.zap-dialog-label-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.45rem 0.8rem;
}

.zap-dialog-label {
  font-weight: 700;
}

.zap-dialog-label small {
  font-weight: 500;
  color: rgba(17, 24, 39, 0.6);
}

.zap-dialog-current-amount {
  font-size: 0.84rem;
  font-weight: 720;
  color: #6d28d9;
}

.zap-usd-note {
  color: rgba(17, 24, 39, 0.62);
  font-weight: 600;
}

.zap-amount-chips {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8.2rem, 1fr));
  gap: 0.58rem;
}

.zap-amount-chip {
  display: grid;
  gap: 0.1rem;
  align-content: center;
  justify-items: start;
  min-height: 4rem;
  padding: 0.62rem 0.72rem;
  border: 1px solid rgba(124, 58, 237, 0.14);
  border-radius: 0.95rem;
  background: rgba(255, 255, 255, 0.78);
  color: rgba(17, 24, 39, 0.88);
  font: inherit;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(43, 19, 92, 0.06);
  transition: border-color 150ms ease, background 150ms ease, box-shadow 150ms ease;
}

.zap-amount-chip:hover,
.zap-amount-chip:focus-visible {
  border-color: rgba(124, 58, 237, 0.34);
  background: #fff;
  box-shadow: 0 12px 26px rgba(43, 19, 92, 0.11);
}

.zap-amount-chip.is-selected {
  border-color: rgba(124, 58, 237, 0.62);
  background: linear-gradient(145deg, rgba(124, 58, 237, 0.14), rgba(217, 70, 239, 0.12));
  box-shadow: 0 14px 30px rgba(124, 58, 237, 0.16);
}

.zap-amount-chip-name {
  font-size: 0.72rem;
  font-weight: 760;
  letter-spacing: 0.01em;
  text-transform: none;
  color: #6d28d9;
}

.zap-amount-chip-sats {
  font-size: 1rem;
  font-weight: 820;
}

.zap-amount-chip-usd {
  font-size: 0.78rem;
  font-weight: 650;
  color: rgba(17, 24, 39, 0.58);
}

.zap-dialog-secondary-grid {
  display: grid;
  grid-template-columns: minmax(9rem, 0.72fr) minmax(14rem, 1.28fr);
  gap: 0.75rem;
}

.zap-dialog-field input,
.zap-dialog-field textarea,
.zap-dialog-invoice-field textarea {
  width: min(100%, 32rem);
  max-width: 100%;
}

.zap-dialog-field input[data-zap-custom-sats] {
  width: 9.5rem;
  min-height: 2.75rem;
  padding: 0.58rem 0.72rem;
  font-size: 1.08rem;
  font-weight: 720;
}

.zap-dialog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  padding: 0.95rem 0 0;
}

.zap-dialog-primary-action {
  min-height: 2.9rem;
  padding-inline: 1.15rem;
}

.zap-dialog-status {
  margin-top: 0.85rem;
  margin-bottom: 0;
  line-height: 1.45;
}

.zap-dialog-status.is-info {
  color: rgba(17, 24, 39, 0.78);
}

.zap-dialog-status.is-ok {
  color: #14532d;
}

.zap-dialog-status.is-error {
  color: #991b1b;
}

.zap-dialog-invoice {
  display: grid;
  gap: 0.8rem;
  padding: 1rem 0 1.1rem;
}

.zap-dialog-qr {
  display: grid;
  place-items: center;
  width: fit-content;
  min-width: 10.5rem;
  min-height: 10.5rem;
  padding: 0.55rem;
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 1rem;
  background: #ffffff;
}

.zap-dialog-invoice-field {
  display: grid;
  gap: 0.45rem;
}

.zap-dialog-invoice-field span {
  font-weight: 700;
}

.zap-dialog-invoice-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

@media (max-width: 720px) {
  .zap-inline-card {
    width: 100%;
  }

  .zap-dialog-panel {
    width: calc(100vw - 1rem);
    margin: 0.5rem auto;
  }

  .zap-dialog-secondary-grid {
    grid-template-columns: 1fr;
  }

  .zap-dialog-field input[data-zap-custom-sats] {
    width: min(11rem, 100%);
    min-height: 3rem;
    font-size: 1.16rem;
  }

  .zap-dialog-head,
  .zap-dialog-grid,
  .zap-dialog-actions,
  .zap-dialog-status,
  .zap-dialog-invoice {
    margin-left: 0.9rem;
    margin-right: 0.9rem;
  }
}

/* Loading State */
button.loading {
  position: relative;
  color: transparent;
}

button.loading::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  top: 50%;
  left: 50%;
  margin-left: -8px;
  margin-top: -8px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: white;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

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

/* Responsive Button Adjustments */
@media (max-width: 600px) {
  button,
  .btn {
    width: 100%;
    padding: 1rem;
  }

  .post-page-menu-trigger {
    width: 2rem;
    min-width: 2rem;
    height: 2rem;
    padding: 0;
  }
  
  .demo-box {
    padding: 1.5rem;
  }
}

/* Accessibility */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0.5rem;
  z-index: 9999;
  background: #111827;
  color: #ffffff;
  padding: 0.6rem 0.9rem;
  border-radius: 8px;
  text-decoration: none;
}

.skip-link:focus {
  left: 1rem;
}

/* Post Context Enhancements */
.post-context-card {
  margin: 0.75rem 0 1.5rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-raised-strong, #fff);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
}

.post-context-detail {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  color: var(--light-text);
  font-size: 0.92rem;
  align-items: center;
}

.post-context-summary {
  margin: 0.75rem 0 0;
  color: var(--text);
}

.post-context-tags {
  margin-top: 0.4rem;
}

.post-end-tags {
  margin-top: 2rem;
  padding-top: 0.85rem;
  border-top: 1px dashed var(--border);
}

.post-end-tags .post-context-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
  justify-content: center;
  margin-top: 0.45rem;
  text-align: center;
}

.post-end-tags .tag {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  margin: 0;
  padding: 0.16rem 0.64rem;
  filter: none !important;
}

.post-end-tags-label {
  margin: 0 0 0.35rem;
  color: var(--light-text);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.post-nav-enhanced {
  margin-top: 2.5rem;
  border-top: 1px solid var(--border);
  padding-top: 1rem;
}

.post-nav-label {
  display: block;
  font-size: 0.8rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--light-text);
  margin-bottom: 0.25rem;
}

.post-nav-empty {
  color: var(--light-text);
  font-size: 0.92rem;
}

/* Archive */
.archive-list {
  margin-top: 1.5rem;
}

.archive-month {
  margin: 0 0 1.75rem;
  padding: 1rem 1rem 0.8rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-raised-strong, #fff);
}

.archive-month h2 {
  margin-top: 0;
  border-bottom: none;
  padding-bottom: 0;
  font-size: 1.3rem;
}

.archive-count {
  color: var(--light-text);
  font-size: 0.9rem;
}

.archive-posts {
  list-style: none;
  margin: 0.8rem 0 0;
  padding: 0;
}

.archive-item {
  display: flex;
  gap: 0.8rem;
  align-items: baseline;
  padding: 0.35rem 0;
}

.archive-item a {
  cursor: pointer;
  text-decoration: none;
}

.archive-item a:hover,
.archive-item a:focus-visible {
  text-decoration: underline;
}

.archive-date {
  min-width: 8.75rem;
  color: var(--light-text);
  font-size: 0.9rem;
}

@media (max-width: 700px) {
  .archive-item {
    flex-direction: column;
    gap: 0.2rem;
  }

  .archive-date {
    min-width: 0;
  }
}

/* Responsive Nav Overrides */
@media (max-width: 900px) {
  .site-nav {
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.6rem 0.8rem;
  }

  .nav-center {
    order: 1;
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
    white-space: nowrap;
    scrollbar-width: none;
  }

  .nav-center::-webkit-scrollbar {
    display: none;
  }

  .nav-right {
    order: 2;
    width: 100%;
    justify-content: space-between;
    gap: 0.5rem;
  }

  .nav-feeds {
    flex: 0 0 auto;
  }

  .nav-search {
    margin: 0;
    flex: 1;
    max-width: none;
  }

  .nav-search input[type="text"] {
    width: 100%;
    min-width: 0;
  }

  .btn-login {
    white-space: nowrap;
  }
}

/* Final nav layout overrides */
nav.site-nav {
  --site-nav-panel-width: min(1120px, calc(100vw - 1.5rem));
  width: min(900px, calc(100vw - 1rem));
  max-width: none;
  margin-left: 50%;
  margin-right: 0;
  transform: translateX(-50%);
  box-sizing: border-box;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.9rem;
  padding: 0.22rem 1rem;
  background: var(--nav-bg, var(--bg));
  border-top: 1px solid var(--nav-border, var(--border));
  border-bottom: 1px solid var(--nav-border, var(--border)) !important;
  box-shadow: none !important;
}

@supports (width: 100dvw) {
  nav.site-nav {
    width: min(900px, calc(100dvw - 1rem));
    max-width: none;
  }
}

.nav-center {
  width: auto;
  min-width: 0;
  justify-content: flex-start;
  flex-wrap: nowrap;
  gap: 0.45rem;
  overflow-x: auto;
  scrollbar-width: none;
}

.nav-center::-webkit-scrollbar {
  display: none;
}

.nav-right {
  width: auto;
  min-width: max-content;
  justify-content: flex-end;
  gap: 0.55rem;
  flex-wrap: nowrap;
}

.nav-search {
  margin: 0;
  flex: 0 1 280px;
  min-width: 0;
  max-width: 280px;
}

.nav-search input[type="text"] {
  width: 100%;
  min-width: 0;
}

.btn-login {
  white-space: nowrap;
}

@media (max-width: 900px) {
  .site-nav {
    grid-template-columns: 1fr;
    gap: 0.55rem;
    padding: 0.3rem 0.7rem;
  }

  .nav-center {
    width: 100%;
    overflow-x: auto;
    white-space: nowrap;
    scrollbar-width: none;
  }

  .nav-center::-webkit-scrollbar {
    display: none;
  }

  .nav-right {
    width: 100%;
    justify-content: flex-start;
  }

  .nav-search {
    flex: 1;
  }
}

@media (max-width: 640px) {
  .nav-right {
    flex-wrap: wrap;
  }

  .nav-search {
    width: 100%;
    flex-basis: 100%;
    order: 3;
    min-width: 0;
  }

  .btn-login {
    margin-left: auto;
  }

  .post-byline-top {
    column-gap: 0.5rem;
  }
}

/* Final mobile nav lock: always one row, no stretched buttons */
@media (max-width: 900px) {
  nav.site-nav {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0.45rem;
    padding: 0.24rem 0.55rem;
    overflow: visible;
  }

  .nav-center {
    flex: 1 1 auto;
    min-width: 0;
    width: auto;
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
  }

  .nav-right {
    flex: 0 0 auto;
    min-width: max-content;
    width: auto;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.45rem;
  }

  .nav-search {
    flex: 0 1 clamp(140px, 22vw, 220px);
    min-width: 130px;
    max-width: 230px;
    margin: 0;
  }

  .nav-search input[type="text"] {
    width: 100%;
    min-width: 0;
  }

  .nav-search button {
    flex: 0 0 44px;
    width: 44px;
    min-width: 44px;
    padding: 0;
  }

  .btn-login,
  .nav-login-split,
  .nav-user-menu,
  .nav-menu-btn,
  .nav-compose,
  .nav-username {
    flex: 0 0 auto;
    white-space: nowrap;
  }
}

@media (max-width: 640px) {
  nav.site-nav {
    gap: 0.35rem;
    padding: 0.2rem 0.45rem;
  }

  .nav-center a {
    padding: 0.3rem 0.62rem;
    font-size: 0.84rem;
  }

  .nav-search {
    flex: 0 1 170px;
    min-width: 118px;
    max-width: 180px;
  }

  .btn-login {
    padding: 0.38rem 0.72rem;
    font-size: 0.84rem;
  }
}

/* Hard mobile fixes: prevent full-width nav buttons and full-width tag pills */
@media (max-width: 600px) {
  nav.site-nav {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    overflow-x: auto;
  }

  nav.site-nav .nav-center {
    flex: 1 1 auto;
    min-width: 0;
    width: auto !important;
    white-space: nowrap;
    overflow-x: auto;
  }

  nav.site-nav .nav-right {
    flex: 0 0 auto;
    width: auto !important;
    min-width: 0;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: flex-end !important;
  }

  nav.site-nav .nav-search {
    flex: 0 1 165px !important;
    min-width: 120px !important;
    max-width: 175px !important;
    width: auto !important;
    margin: 0 !important;
  }

  nav.site-nav .nav-search button,
  nav.site-nav .btn-login,
  nav.site-nav .nav-login-split,
  nav.site-nav .nav-overflow-menu,
  nav.site-nav .nav-user-menu,
  nav.site-nav .nav-menu-btn,
  nav.site-nav .nav-compose,
  nav.site-nav .nav-username,
  .tag-cloud .tag {
    width: auto !important;
    min-width: 0 !important;
    flex: 0 0 auto !important;
  }

  nav.site-nav .nav-search button {
    padding: 0 !important;
    width: 40px !important;
    min-width: 40px !important;
  }

  .tag-cloud {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
  }

  .tag-cloud .tag {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 0.14rem 0.58rem !important;
    white-space: nowrap;
  }

  .nav-username {
    font-size: 0.84rem;
  }

  .nav-username.active {
    padding: 0.3rem 0.62rem;
    line-height: 1.15;
  }
}

.post-comments-shell {
  margin-top: 2rem;
  padding: 0.9rem 0.95rem;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.58);
}

.post-comments-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.post-comments-head h3 {
  margin: 0;
}

.post-comments-count {
  font-weight: 700;
}

#post-comments-refresh {
  border-radius: 999px;
  border: 1px solid var(--color-border);
  padding: 0.32rem 0.78rem;
  background: rgba(255, 255, 255, 0.78);
  cursor: pointer;
}

.post-comments-compose {
  margin-top: 0.55rem;
  display: grid;
  gap: 0.42rem;
}

#post-comment-input {
  width: 100%;
  min-height: 84px;
  border-radius: 8px;
  border: 1px solid var(--color-border);
  padding: 0.5rem 0.58rem;
  resize: vertical;
  font: inherit;
  box-sizing: border-box;
}

#post-comment-submit {
  justify-self: start;
  border-radius: 999px;
  border: 1px solid var(--color-border);
  padding: 0.34rem 0.9rem;
  background: rgba(255, 255, 255, 0.88);
  cursor: pointer;
}

#post-comments-refresh:disabled,
#post-comment-submit:disabled {
  opacity: 0.72;
  cursor: not-allowed;
}

.post-comments-shortcut {
  margin: 0.18rem 0 0.34rem;
  color: var(--light-text);
  font-size: 0.81rem;
}

.post-comments-status {
  margin: 0.45rem 0 0.5rem;
  min-height: 1.05rem;
  font-size: 0.88rem;
}

.post-comments-status.is-ok {
  color: #1f7a4d;
}

.post-comments-status.is-warn {
  color: #9a5f12;
}

.post-comments-status.is-info {
  color: #375a8f;
}

.post-comments-list {
  display: grid;
  gap: 0.6rem;
}

.post-comment {
  border: 1px solid rgba(137, 153, 176, 0.35);
  border-radius: 9px;
  padding: 0.6rem 0.7rem;
  background: rgba(255, 255, 255, 0.74);
}

.post-comment header {
  display: flex;
  gap: 0.5rem;
  align-items: baseline;
  margin-bottom: 0.22rem;
  font-size: 0.85rem;
}

.post-comment-author {
  font-weight: 700;
}

.post-comment-time {
  color: var(--color-subtle, #5a6d85);
}

.post-comment p {
  margin: 0;
  line-height: 1.46;
}

@media (max-width: 640px) {
  .post-head > .zap-inline-host.is-compact {
    right: 2.35rem;
  }

  .post-comments-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.45rem;
  }

  #post-comments-refresh {
    width: 100%;
    min-height: 2.3rem;
  }

  #post-comment-submit {
    width: 100%;
    min-height: 2.3rem;
  }

  .post-comments-shortcut {
    font-size: 0.78rem;
  }
}

/* Default to plain button style in content/admin areas (navbar controls stay Lapis). */
#main-content :where(button, input[type="button"], input[type="submit"], input[type="reset"]):not(.unobtrusive-icon-button):not(.tag):not(.btn-login):not(.btn-login-main):not(.btn-login-caret):not(.list-admin-primary-btn):not(.auth-primary-btn):not(.auth-secondary-btn):not(.list-entry-vote-btn):not(.list-inline-row-menu-trigger):not(.contact-value-link):not([role="menuitem"]) {
  border: 1px solid var(--admin-border, var(--border)) !important;
  background: var(--surface-raised, var(--admin-surface, var(--post-card-bg-single))) !important;
  background-image: none !important;
  color: var(--admin-text, var(--text)) !important;
  -webkit-text-fill-color: var(--admin-text, var(--text)) !important;
  box-shadow: none !important;
  transform: none !important;
}

#main-content :where(button, input[type="button"], input[type="submit"], input[type="reset"]):not(.unobtrusive-icon-button):not(.tag):not(.btn-login):not(.btn-login-main):not(.btn-login-caret):not(.list-admin-primary-btn):not(.auth-primary-btn):not(.auth-secondary-btn):not(.list-entry-vote-btn):not(.list-inline-row-menu-trigger):not(.contact-value-link):not([role="menuitem"]):hover:not(:disabled),
#main-content :where(button, input[type="button"], input[type="submit"], input[type="reset"]):not(.unobtrusive-icon-button):not(.tag):not(.btn-login):not(.btn-login-main):not(.btn-login-caret):not(.list-admin-primary-btn):not(.auth-primary-btn):not(.auth-secondary-btn):not(.list-entry-vote-btn):not(.list-inline-row-menu-trigger):not(.contact-value-link):not([role="menuitem"]):focus-visible:not(:disabled) {
  border-color: color-mix(in srgb, var(--admin-border, var(--border)) 68%, var(--admin-accent, var(--accent)) 32%) !important;
  background: var(--admin-hover, var(--nav-link-hover)) !important;
  background-image: none !important;
  color: var(--admin-text, var(--text)) !important;
  -webkit-text-fill-color: var(--admin-text, var(--text)) !important;
  box-shadow: none !important;
  transform: none !important;
}

#main-content .secure-chat-close-btn {
  display: inline-flex !important;
  width: 2rem !important;
  height: 2rem !important;
  min-width: 0 !important;
  padding: 0 !important;
  border-radius: 999px !important;
  border-color: color-mix(in srgb, var(--admin-border, #c7d2fe) 70%, transparent) !important;
  background: color-mix(in srgb, var(--post-card-bg-single, #fff) 80%, white 20%) !important;
  color: var(--muted, #5d4a2f) !important;
  -webkit-text-fill-color: var(--muted, #5d4a2f) !important;
}

#main-content .secure-chat-close-btn:hover,
#main-content .secure-chat-close-btn:focus-visible {
  border-color: var(--action-soft-hover-border, #b77753) !important;
  background: var(--action-soft-hover-bg, #f0d7c5) !important;
  color: var(--action-soft-hover-text, #5b2f18) !important;
  -webkit-text-fill-color: var(--action-soft-hover-text, #5b2f18) !important;
}

#main-content .secure-chat-emoji-button,
#main-content .secure-chat-voice-btn {
  display: inline-flex !important;
  width: 2.08rem !important;
  height: 2.08rem !important;
  min-width: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  color: var(--admin-text, #0b132b) !important;
  -webkit-text-fill-color: var(--admin-text, #0b132b) !important;
}

#main-content .secure-chat-voice-btn.is-locked {
  color: var(--admin-muted, #5f6f92) !important;
  -webkit-text-fill-color: var(--admin-muted, #5f6f92) !important;
}

#main-content .secure-chat-voice-btn.is-recording {
  background: transparent !important;
  color: var(--danger, #b42318) !important;
  -webkit-text-fill-color: var(--danger, #b42318) !important;
}

#main-content .secure-chat-emoji-button:hover,
#main-content .secure-chat-emoji-button:focus-visible,
#main-content .secure-chat-voice-btn:hover:not(:disabled),
#main-content .secure-chat-voice-btn:focus-visible:not(:disabled) {
  background: color-mix(in srgb, var(--light-bg, #e0e7ff) 72%, white 28%) !important;
  background-image: none !important;
  box-shadow: none !important;
  color: var(--accent, #2f4aa6) !important;
  -webkit-text-fill-color: var(--accent, #2f4aa6) !important;
}

#main-content .list-entry-read-menu .list-inline-row-menu-trigger,
#main-content .list-entry-read-menu .list-inline-row-menu-trigger:not(:disabled) {
  border-color: transparent !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

#main-content .list-entry-read-menu .list-inline-row-menu-trigger:hover:not(:disabled),
#main-content .list-entry-read-menu .list-inline-row-menu-trigger:focus-visible:not(:disabled),
#main-content .list-entry-read-menu .list-inline-row-menu-trigger:active:not(:disabled) {
  background: var(--light-bg, #eef3ff) !important;
  background-image: none !important;
  box-shadow: none !important;
}

#main-content .list-inline-row-menu button[role="menuitem"]:not(.unobtrusive-icon-button):not(.tag):not(.btn-login):not(.btn-login-main):not(.btn-login-caret):not(.list-admin-primary-btn):not(.auth-primary-btn):not(.auth-secondary-btn):not(.list-entry-vote-btn) {
  border-color: transparent !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  transform: none !important;
}

#main-content .list-inline-row-menu button[role="menuitem"]:not(.unobtrusive-icon-button):not(.tag):not(.btn-login):not(.btn-login-main):not(.btn-login-caret):not(.list-admin-primary-btn):not(.auth-primary-btn):not(.auth-secondary-btn):not(.list-entry-vote-btn):hover,
#main-content .list-inline-row-menu button[role="menuitem"]:not(.unobtrusive-icon-button):not(.tag):not(.btn-login):not(.btn-login-main):not(.btn-login-caret):not(.list-admin-primary-btn):not(.auth-primary-btn):not(.auth-secondary-btn):not(.list-entry-vote-btn):focus-visible {
  border-color: transparent !important;
  background: var(--menu-hover-bg, var(--admin-hover, var(--nav-link-hover))) !important;
  background-image: none !important;
  box-shadow: none !important;
  transform: none !important;
}

#main-content .blog-post-item button.tag,
#main-content .blog-post-item button.tag:hover:not(:disabled),
#main-content .blog-post-item button.tag:focus-visible:not(:disabled),
#main-content .blog-post-item button.blog-type-pill,
#main-content .blog-post-item button.blog-type-pill:hover:not(:disabled),
#main-content .blog-post-item button.blog-type-pill:focus-visible:not(:disabled),
#main-content .blog-post-item button.blog-year-pill,
#main-content .blog-post-item button.blog-year-pill:hover:not(:disabled),
#main-content .blog-post-item button.blog-year-pill:focus-visible:not(:disabled) {
  border-color: var(--post-tag-standard-border) !important;
  background: var(--post-tag-standard-bg) !important;
  background-color: var(--post-tag-standard-bg) !important;
  color: var(--post-tag-standard-text) !important;
  -webkit-text-fill-color: var(--post-tag-standard-text) !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  filter: none !important;
  transform: none !important;
  transition: none !important;
  animation: none !important;
}

#main-content .blog-post-item button.blog-type-pill,
#main-content .blog-post-item button.blog-type-pill:hover:not(:disabled),
#main-content .blog-post-item button.blog-type-pill:focus-visible:not(:disabled) {
  -webkit-appearance: none !important;
  appearance: none !important;
  border-color: var(--post-tag-type-border) !important;
  background: #dff4d7 !important;
  background-color: #dff4d7 !important;
  color: var(--post-tag-type-text) !important;
  -webkit-text-fill-color: var(--post-tag-type-text) !important;
}

#main-content .blog-post-item button.blog-year-pill,
#main-content .blog-post-item button.blog-year-pill:hover:not(:disabled),
#main-content .blog-post-item button.blog-year-pill:focus-visible:not(:disabled) {
  -webkit-appearance: none !important;
  appearance: none !important;
  border-color: var(--post-tag-year-border) !important;
  background: #dcecff !important;
  background-color: #dcecff !important;
  color: var(--post-tag-year-text) !important;
  -webkit-text-fill-color: var(--post-tag-year-text) !important;
}

button.blog-type-pill,
button.blog-type-pill:hover:not(:disabled),
button.blog-type-pill:focus-visible:not(:disabled) {
  -webkit-appearance: none !important;
  appearance: none !important;
  border-color: var(--post-tag-type-border) !important;
  background: #dff4d7 !important;
  background-color: #dff4d7 !important;
  color: var(--post-tag-type-text) !important;
  -webkit-text-fill-color: var(--post-tag-type-text) !important;
}

button.blog-year-pill,
button.blog-year-pill:hover:not(:disabled),
button.blog-year-pill:focus-visible:not(:disabled) {
  -webkit-appearance: none !important;
  appearance: none !important;
  border-color: var(--post-tag-year-border) !important;
  background: #dcecff !important;
  background-color: #dcecff !important;
  color: var(--post-tag-year-text) !important;
  -webkit-text-fill-color: var(--post-tag-year-text) !important;
}

#main-content .blog-post-item .post-card-meta-tags > button.tag.is-active,
#main-content .blog-post-item .post-card-meta-tags > button.tag.is-active:hover:not(:disabled),
#main-content .blog-post-item .post-card-meta-tags > button.tag.is-active:focus-visible:not(:disabled) {
  border-color: color-mix(in srgb, var(--accent, #3158a4) 78%, black 8%) !important;
  background: color-mix(in srgb, var(--accent, #3158a4) 20%, var(--post-card-bg-single, white) 80%) !important;
  background-color: color-mix(in srgb, var(--accent, #3158a4) 20%, var(--post-card-bg-single, white) 80%) !important;
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text) !important;
  outline: 2px solid color-mix(in srgb, var(--accent, #3158a4) 50%, transparent) !important;
  outline-offset: 1px;
  font-weight: 700;
}

#main-content .list-entry-vote-btn,
#main-content .list-entry-vote-btn:hover:not(:disabled),
#main-content .list-entry-vote-btn:focus-visible:not(:disabled),
#main-content .list-entry-vote-btn.is-active {
  appearance: none !important;
  -webkit-appearance: none !important;
  border: 0 !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  color: #c9ced8 !important;
  -webkit-text-fill-color: #c9ced8 !important;
  filter: none !important;
  transform: none !important;
  transition: none !important;
  animation: none !important;
}

#main-content .list-entry-vote-btn.is-upvote.is-active,
#main-content .list-entry-vote-btn.is-upvote:hover:not(:disabled),
#main-content .list-entry-vote-btn.is-upvote:focus-visible:not(:disabled) {
  color: #d13939 !important;
  -webkit-text-fill-color: #d13939 !important;
}

#main-content .list-entry-vote-btn.is-upvote.is-stale {
  color: #b77a7a !important;
  -webkit-text-fill-color: #b77a7a !important;
}

#main-content .list-entry-vote-btn.is-downvote.is-active,
#main-content .list-entry-vote-btn.is-downvote:hover:not(:disabled),
#main-content .list-entry-vote-btn.is-downvote:focus-visible:not(:disabled) {
  color: #286dc8 !important;
  -webkit-text-fill-color: #286dc8 !important;
}

#main-content .list-entry-vote-btn.is-downvote.is-stale {
  color: #718bad !important;
  -webkit-text-fill-color: #718bad !important;
}

/* Keep nav/login hovers in primary color space (never tan fallback). */
nav.site-nav .btn-login:hover:not(:disabled),
nav.site-nav .btn-login:focus-visible:not(:disabled) {
  background-image: linear-gradient(135deg, var(--button-primary-hover-start) 0%, var(--button-primary-hover-end) 100%) !important;
  background-color: var(--button-primary-hover-start) !important;
  border-color: var(--button-primary-border) !important;
  color: var(--button-primary-text) !important;
  -webkit-text-fill-color: var(--button-primary-text) !important;
}

/* Keep split-login divider color stable across hover states. */
nav.site-nav .nav-login-split .btn-login,
nav.site-nav .nav-login-split .btn-login:hover:not(:disabled),
nav.site-nav .nav-login-split .btn-login:focus-visible:not(:disabled) {
  border-color: var(--button-primary-end) !important;
}

nav.site-nav .nav-login-split .btn-login-caret,
nav.site-nav .nav-login-split .btn-login-caret:hover:not(:disabled),
nav.site-nav .nav-login-split .btn-login-caret:focus-visible:not(:disabled) {
  border-left-color: var(--button-primary-end) !important;
}

body.nostr-publish-dialog-open {
  overflow: hidden;
}

.nostr-publish-modal[hidden] {
  display: none !important;
}

.nostr-publish-modal {
  position: fixed;
  inset: 0;
  z-index: 1300;
}

.nostr-publish-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.46);
}

.nostr-publish-modal-panel {
  position: relative;
  max-width: min(56rem, calc(100% - 2rem));
  margin: min(6vh, 2.6rem) auto;
  border: 1px solid var(--border);
  border-radius: 0.88rem;
  background: var(--modal-bg, var(--post-card-bg-single));
  box-shadow: var(--modal-shadow, 0 20px 48px rgba(15, 23, 42, 0.26));
  padding: 0.9rem 0.95rem 0.8rem;
}

.nostr-publish-modal-close {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  inline-size: 1.9rem;
  block-size: 1.9rem;
}

.nostr-publish-modal-panel h2 {
  margin: 0 2.2rem 0.2rem 0;
  font-size: 1.15rem;
}

.nostr-publish-modal-subtitle {
  margin: 0 2.2rem 0.55rem 0;
  color: var(--light-text);
  font-size: 0.92rem;
}

.nostr-publish-modal-status,
.nostr-publish-modal-error {
  margin: 0 0 0.55rem;
  padding: 0.34rem 0.52rem;
  border-radius: 0.48rem;
  font-size: 0.84rem;
}

.nostr-publish-modal-status {
  color: var(--light-text);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--post-card-bg-single) 86%, var(--nav-link-hover) 14%);
}

.nostr-publish-modal-error {
  color: #7f1d1d;
  border: 1px solid rgba(185, 28, 28, 0.34);
  background: rgba(185, 28, 28, 0.13);
}

.nostr-publish-meta {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.32rem;
  margin: 0 0 0.56rem;
}

.nostr-publish-meta-item {
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  padding: 0.3rem 0.4rem;
  background: color-mix(in srgb, var(--post-card-bg-single) 88%, var(--nav-link-hover) 12%);
  min-width: 0;
}

.nostr-publish-meta-item strong {
  display: block;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--light-text);
  margin: 0 0 0.1rem;
}

.nostr-publish-meta-item span {
  display: block;
  font-size: 0.8rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nostr-publish-code-inline {
  font-family: "Courier New", Courier, "Liberation Mono", monospace;
}

.nostr-publish-warnings {
  margin: 0 0 0.54rem;
  border: 1px solid rgba(180, 83, 9, 0.35);
  background: rgba(234, 179, 8, 0.14);
  border-radius: 0.5rem;
  padding: 0.34rem 0.5rem;
  font-size: 0.82rem;
}

.nostr-publish-warnings strong {
  display: block;
  margin-bottom: 0.1rem;
}

.nostr-publish-warnings ul {
  margin: 0.15rem 0 0;
  padding-left: 1.1rem;
}

.nostr-publish-json-wrap {
  margin: 0 0 0.68rem;
}

.nostr-publish-json-label {
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--light-text);
  margin-bottom: 0.2rem;
}

.nostr-publish-json {
  margin: 0;
  max-height: min(45vh, 24rem);
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--post-card-bg-single) 78%, #111827 22%);
  color: color-mix(in srgb, var(--text) 92%, #f8fafc 8%);
  padding: 0.56rem 0.62rem;
  line-height: 1.28;
  font-size: 0.79rem;
  font-family: "Courier New", Courier, "Liberation Mono", monospace;
}

.nostr-publish-modal-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.45rem;
}

.nostr-publish-modal-actions button {
  width: auto;
  min-width: 0;
}

@media (max-width: 980px) {
  .nostr-publish-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .nostr-publish-modal-panel {
    max-width: calc(100% - 1rem);
    margin: 0.5rem auto;
    padding: 0.8rem 0.74rem 0.7rem;
  }

  .nostr-publish-meta {
    grid-template-columns: 1fr;
  }
}

/* Final nav panel layout: brand/actions row above page links when space allows. */
@media (max-width: 1400px) {
  nav.site-nav {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) auto !important;
    grid-template-rows: auto auto !important;
    align-items: center !important;
    justify-content: stretch !important;
    gap: 0.46rem 0.7rem;
    overflow: visible !important;
    padding: 0.68rem 1rem 0.76rem;
  }

  nav.site-nav .nav-site-signature {
    grid-column: 1 / 2;
    grid-row: 1;
    display: inline-flex !important;
    flex: 0 0 auto !important;
    min-width: max-content !important;
    margin-left: 0;
    margin-right: 0;
    font-size: 1.04rem;
    white-space: nowrap;
    color: var(--text) !important;
    opacity: 0.92;
  }

  nav.site-nav .nav-center {
    grid-column: 1 / -1;
    grid-row: 2;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    width: 100% !important;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.4rem;
    overflow-x: hidden !important;
    overflow-y: hidden !important;
    white-space: nowrap;
    scrollbar-width: none;
  }

  nav.site-nav .nav-center::-webkit-scrollbar {
    display: none;
  }

  nav.site-nav .nav-center a {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  nav.site-nav .nav-right {
    grid-column: 2 / -1;
    grid-row: 1;
    justify-self: end;
    flex: 0 0 auto !important;
    min-width: 0 !important;
    width: auto !important;
    display: flex;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 0.4rem;
  }

  nav.site-nav .nav-search {
    flex: 0 1 clamp(116px, 20vw, 220px) !important;
    min-width: 96px !important;
    max-width: 220px !important;
    width: auto !important;
    margin: 0 !important;
  }

  nav.site-nav .nav-search input[type="text"] {
    width: 100%;
    min-width: 0;
  }

  nav.site-nav .nav-search button,
  nav.site-nav .btn-login,
  nav.site-nav .nav-login-split,
  nav.site-nav .nav-user-menu,
  nav.site-nav .nav-menu-btn,
  nav.site-nav .nav-compose,
  nav.site-nav .nav-username {
    flex: 0 0 auto !important;
  }
}

@media (max-width: 920px) {
  nav.site-nav {
    --nav-pill-font-size: 0.84rem;
    --nav-pill-pad-y: 0.3rem;
    --nav-pill-pad-x: 0.64rem;
  }

  nav.site-nav .nav-center a {
    padding: var(--nav-pill-pad-y) var(--nav-pill-pad-x);
    font-size: var(--nav-pill-font-size);
  }

  nav.site-nav .nav-search {
    flex: 0 1 170px !important;
    min-width: 120px !important;
    max-width: 170px !important;
  }
}

@media (max-width: 780px) {
  nav.site-nav .nav-search {
    flex: 0 0 auto !important;
    min-width: 0 !important;
    max-width: none !important;
  }

  nav.site-nav .nav-search input[type="text"] {
    display: none !important;
  }

  nav.site-nav .nav-search button {
    width: 40px !important;
    min-width: 40px !important;
    padding: 0 !important;
    border-left: 1px solid var(--nav-border, var(--border));
    border-radius: 20px !important;
  }
}

/* Keep clickable active nav pills in lapis button styling even under late hover rules. */

/* Final mobile nav safety: prevent search/actions from covering center links. */
@media (max-width: 700px) {
  nav.site-nav {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto auto;
    align-items: center;
    gap: 0.34rem;
    padding: 0.22rem 0.42rem;
  }

  nav.site-nav .nav-center {
    grid-row: 1;
    grid-column: 1;
    min-width: 0;
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto !important;
    overflow-y: hidden;
    white-space: nowrap;
  }

  nav.site-nav .nav-right {
    grid-row: 2;
    grid-column: 1;
    min-width: 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.38rem;
    flex-wrap: nowrap;
  }

  nav.site-nav .nav-search {
    flex: 1 1 12rem !important;
    min-width: 0 !important;
    max-width: none !important;
    margin: 0 !important;
  }
}

/* Clickable active home/blog title stays plain-link style. */
nav.site-nav .nav-center a.active.allow-active-click,
nav.site-nav .nav-center a.active.allow-active-click:link,
nav.site-nav .nav-center a.active.allow-active-click:visited,
nav.site-nav .nav-center a.active.allow-active-click:active,
nav.site-nav .nav-center a.active.allow-active-click:hover,
nav.site-nav .nav-center a.active.allow-active-click:focus-visible {
  background: transparent !important;
  background-image: none !important;
  background-color: transparent !important;
  color: var(--text) !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}

nav.site-nav .nav-center a.active.allow-active-click:hover,
nav.site-nav .nav-center a.active.allow-active-click:focus-visible {
  text-decoration: underline !important;
}

/* Absolute final guard: any active nav item must stay in button-blue on hover/focus. */
nav.site-nav .nav-center a.active,
nav.site-nav .nav-center a.active:hover,
nav.site-nav .nav-center a.active:focus-visible {
  background: linear-gradient(128deg, #5b8fe8 0%, var(--lapis, var(--accent, #3b70d0)) 36%, #2f60b7 72%, #244d99 100%) !important;
  background-image: var(--button-primary-overlay), linear-gradient(128deg, #5b8fe8 0%, var(--lapis, var(--accent, #3b70d0)) 36%, #2f60b7 72%, #244d99 100%) !important;
  background-color: var(--lapis, var(--accent, #3b70d0)) !important;
  color: var(--nav-active-text, #fff) !important;
  text-decoration: none !important;
}

/* If active class is ever missing, aria-current still forces lapis active styling. */
nav.site-nav .nav-center a[aria-current="page"],
nav.site-nav .nav-center a[aria-current="page"]:hover,
nav.site-nav .nav-center a[aria-current="page"]:focus-visible {
  background: linear-gradient(128deg, #5b8fe8 0%, var(--lapis, var(--accent, #3b70d0)) 36%, #2f60b7 72%, #244d99 100%) !important;
  background-image: var(--button-primary-overlay), linear-gradient(128deg, #5b8fe8 0%, var(--lapis, var(--accent, #3b70d0)) 36%, #2f60b7 72%, #244d99 100%) !important;
  background-color: var(--lapis, var(--accent, #3b70d0)) !important;
  color: var(--nav-active-text, #fff) !important;
  text-decoration: none !important;
}

/* Final nav overflow lock: keep site title visible and collapse links into overflow one-by-one. */
nav.site-nav {
  display: grid !important;
  grid-template-columns: auto auto auto !important;
  grid-template-rows: auto auto !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.38rem 0.72rem !important;
  overflow: visible !important;
  position: static !important;
  top: auto !important;
  z-index: 1200;
  width: fit-content;
  max-width: calc(100vw - 1.5rem);
  min-height: 4.35rem;
  margin-left: auto;
  margin-right: auto;
  transform: none;
  padding: 0.54rem 1rem 0.62rem;
  border-radius: 0 0 16px 16px;
  border: 1px solid color-mix(in srgb, var(--nav-border, var(--border)) 82%, transparent) !important;
  border-top: 0 !important;
  box-sizing: border-box;
}

nav.site-nav .nav-overflow-menu {
  order: 99;
  flex: 0 0 auto !important;
  margin-left: 0;
  margin-right: 0;
}

nav.site-nav > .nav-site-signature {
  grid-column: 1 / 2;
  grid-row: 1;
  display: inline-flex !important;
  flex: 0 0 auto !important;
  color: color-mix(in srgb, var(--nav-signature-color, var(--text)) 42%, var(--text, #2f2517) 58%) !important;
  font-size: 1.15rem;
  min-width: max-content !important;
  white-space: nowrap !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

nav.site-nav > .nav-center {
  grid-column: 1 / -1;
  grid-row: 2;
  flex: 0 1 auto !important;
  min-width: 0 !important;
  width: fit-content !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.28rem !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  scrollbar-width: none !important;
  box-sizing: border-box;
  justify-self: center;
  max-width: min(100%, 760px, calc(100vw - 3rem));
  margin-inline: auto;
  padding: 0.18rem 0.9rem 0.18rem 0.36rem;
  border-radius: 999px;
}

nav.site-nav > .nav-center::-webkit-scrollbar {
  display: none !important;
}

nav.site-nav > .nav-center a {
  flex: 0 0 auto !important;
  white-space: nowrap !important;
  padding: 0.25rem 0.58rem !important;
  border-radius: 8px !important;
  line-height: 1.1 !important;
}

nav.site-nav > .nav-right {
  grid-column: 2 / -1;
  grid-row: 1;
  justify-self: end;
  flex: 0 0 auto !important;
  min-width: 0 !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 0.4rem !important;
  position: relative;
  z-index: 1;
}

nav.site-nav .nav-overflow-menu,
nav.site-nav > .nav-center .nav-overflow-menu,
nav.site-nav > .nav-right .nav-login-split,
nav.site-nav > .nav-right .nav-user-menu {
  position: relative;
  z-index: 2;
}

nav.site-nav .nav-menu-panel,
nav.site-nav .nav-login-menu {
  z-index: 1300;
}

@keyframes nav-search-input-expand {
  from {
    opacity: 0;
    transform: scaleX(0);
  }
  to {
    opacity: 1;
    transform: scaleX(1);
  }
}

nav.site-nav > .nav-right .nav-search {
  order: 1;
  display: flex !important;
  align-items: center !important;
  flex: 0 0 auto !important;
  width: 40px !important;
  min-width: 40px !important;
  max-width: 40px !important;
  margin: 0 !important;
  overflow: visible;
  position: relative;
  z-index: 4;
  transition: box-shadow 160ms ease;
}

nav.site-nav > .nav-right .nav-search.is-search-expanded,
nav.site-nav > .nav-right .nav-search.has-search-value,
nav.site-nav > .nav-right .nav-search:focus-within {
  flex: 0 0 auto !important;
  width: 40px !important;
  max-width: 40px !important;
}

nav.site-nav > .nav-right .nav-compose-tools,
nav.site-nav > .nav-right .nav-cart-toggle,
nav.site-nav > .nav-right .nav-username,
nav.site-nav > .nav-right .nav-user-menu,
nav.site-nav > .nav-right .nav-login-split {
  order: 2;
}

nav.site-nav > .nav-right .nav-search input[type="text"] {
  position: absolute;
  right: 40px;
  top: 0;
  bottom: 0;
  width: 180px !important;
  min-width: 0 !important;
  max-width: 180px !important;
  box-sizing: border-box;
  padding-left: 0.8rem !important;
  padding-right: 0.8rem !important;
  opacity: 0;
  pointer-events: none;
  transform: scaleX(0);
  transform-origin: right center;
  transition: none;
  will-change: transform, opacity;
}

nav.site-nav > .nav-right .nav-search.is-search-expanded input[type="text"],
nav.site-nav > .nav-right .nav-search.has-search-value input[type="text"],
nav.site-nav > .nav-right .nav-search:focus-within input[type="text"] {
  width: 180px !important;
  max-width: 180px !important;
  padding-left: 0.8rem !important;
  padding-right: 0.8rem !important;
  opacity: 1;
  pointer-events: auto;
  transform: scaleX(1);
  animation: nav-search-input-expand 240ms cubic-bezier(0.2, 0.9, 0.2, 1) both;
}

nav.site-nav > .nav-right .nav-search button,
nav.site-nav > .nav-right .btn-login,
nav.site-nav > .nav-right .nav-login-split,
nav.site-nav > .nav-right .nav-user-menu,
nav.site-nav > .nav-right .nav-menu-btn,
nav.site-nav > .nav-right .nav-compose,
nav.site-nav > .nav-right .nav-username,
nav.site-nav > .nav-right .nav-overflow-menu {
  flex: 0 0 auto !important;
}

nav.site-nav > .nav-right .nav-search button {
  position: relative;
  z-index: 1;
  width: 40px !important;
  min-width: 40px !important;
  padding: 0 !important;
  border-radius: 20px !important;
  transition:
    border-radius 180ms ease,
    border-color 160ms ease,
    background 160ms ease,
    color 160ms ease;
}

nav.site-nav > .nav-right .nav-search.is-search-expanded button,
nav.site-nav > .nav-right .nav-search.has-search-value button,
nav.site-nav > .nav-right .nav-search:focus-within button {
  border-radius: 0 20px 20px 0 !important;
}

@media (max-width: 780px) {
  nav.site-nav > .nav-right .nav-search {
    flex: 0 0 auto !important;
    width: 40px !important;
    min-width: 0 !important;
    max-width: 40px !important;
  }

  nav.site-nav > .nav-right .nav-search.is-search-expanded,
  nav.site-nav > .nav-right .nav-search.has-search-value,
  nav.site-nav > .nav-right .nav-search:focus-within {
    flex: 0 0 auto !important;
    width: 40px !important;
    max-width: 40px !important;
  }

  nav.site-nav > .nav-right .nav-search input[type="text"] {
    display: block !important;
  }

  nav.site-nav > .nav-right .nav-search button {
    width: 40px !important;
    min-width: 40px !important;
    padding: 0 !important;
    border-left: 1px solid var(--nav-border, var(--border));
    border-radius: 20px !important;
  }
}

/* Public surface depth replaces thin framing lines. */
nav.site-nav {
  border-top: 0 !important;
  border-bottom: 0 !important;
  box-shadow:
    0 18px 36px rgba(15, 23, 42, 0.12),
    0 2px 8px rgba(15, 23, 42, 0.07) !important;
}

.post-item,
.list-page-shell {
  border: 0 !important;
  box-shadow:
    0 20px 44px rgba(15, 23, 42, 0.12),
    0 2px 8px rgba(15, 23, 42, 0.06) !important;
}

.post-single-item {
  border: 0 !important;
  box-shadow:
    0 22px 52px rgba(15, 23, 42, 0.13),
    0 3px 10px rgba(15, 23, 42, 0.06) !important;
}

.post-list > .blog-post-item,
.post-list > .blog-post-item:hover,
.post-list > .blog-post-item:focus,
.post-list > .blog-post-item:focus-within {
  transform: none !important;
  filter: none !important;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.07) !important;
  transition: none !important;
}

.nav-search {
  border-radius: 999px;
  box-shadow:
    0 9px 20px rgba(15, 23, 42, 0.12),
    0 1px 3px rgba(15, 23, 42, 0.08);
}

.nav-search input[type="text"],
.nav-search button,
nav.site-nav > .nav-right .nav-search input[type="text"],
nav.site-nav > .nav-right .nav-search button {
  border-color: transparent !important;
}

.nav-search input[type="text"] {
  border-right: 0 !important;
}

.nav-search button,
nav.site-nav > .nav-right .nav-search button {
  border-left: 0 !important;
}

.nav-search:focus-within {
  box-shadow:
    0 12px 24px rgba(15, 23, 42, 0.14),
    0 0 0 3px var(--focus-ring, rgba(91, 126, 216, 0.2));
}

/* Button hover stability: hover/focus may change color, border, or shadow, but not position. */
:where(button, input[type="button"], input[type="submit"], input[type="reset"], [role="button"], .btn, .checkout-link-button, .cart-page-link-button, .nav-cart-link-button, .nip23-product-btn, .zap-action-btn, .zap-amount-chip, .blog-clear-filters, .auth-primary-btn, .auth-secondary-btn, .auth-platform-card, .btn-login):hover:not(:disabled),
:where(button, input[type="button"], input[type="submit"], input[type="reset"], [role="button"], .btn, .checkout-link-button, .cart-page-link-button, .nav-cart-link-button, .nip23-product-btn, .zap-action-btn, .zap-amount-chip, .blog-clear-filters, .auth-primary-btn, .auth-secondary-btn, .auth-platform-card, .btn-login):focus-visible:not(:disabled) {
  transform: none !important;
}

/* Final mobile containment: desktop-width content must never expand the phone viewport. */
@media (max-width: 720px), (pointer: coarse) {
  body.blog-post-resize-enabled {
    max-width: 100%;
  }

  .post-item.blog-post-resizable {
    width: 100%;
  }
}

@media (max-width: 640px) {
  html,
  body {
    max-width: 100%;
    overflow-x: clip;
  }

  body {
    padding: 0 0.62rem 1.25rem;
  }

  main,
  #blog-page-root,
  .post-list,
  .post-item,
  .post-single-item,
  .post-single-item .post-head,
  .post-single-item .post-single-body {
    min-width: 0;
  }

  .post-single-item {
    width: 100%;
    max-width: 100%;
    margin-top: 0.72rem;
    padding: 1rem 0.95rem 0.96rem;
    border-radius: 14px;
  }

  .post-single-item .post-head-main .post-title {
    padding-right: 2.7rem;
  }

  .post-single-item .post-title {
    font-size: clamp(1.82rem, 10.5vw, 2.9rem);
    line-height: 1.06;
    overflow-wrap: anywhere;
    hyphens: auto;
  }

  .post-byline-top {
    grid-template-columns: minmax(0, 1fr) auto;
    column-gap: 0.5rem;
  }

  .post-author,
  .post-meta,
  .post-byline-top .post-date,
  .post-byline-top .post-date-published {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .post-single-item .post-single-body {
    padding: 0.62rem 0 0.52rem;
    font-size: clamp(1rem, 4.8vw, 1.12rem);
    line-height: 1.72;
    text-wrap: auto;
  }

  .post-single-item .post-single-body,
  .post-single-item .post-single-body * {
    max-width: 100%;
  }

  .post-single-item .post-single-body {
    overflow-wrap: break-word;
  }

  .post-single-item .post-single-body a {
    overflow-wrap: anywhere;
  }

  .post-single-item .post-single-body table {
    display: block;
    width: max-content;
    max-width: 100%;
    margin-inline: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-collapse: collapse;
    font-size: 0.9rem;
  }

  .post-single-item .post-single-body th,
  .post-single-item .post-single-body td {
    overflow-wrap: normal;
  }

  .post-single-item .post-single-body pre {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .post-single-item .post-single-body img,
  .post-single-item .post-single-body video,
  .post-single-item .post-single-body iframe {
    max-width: 100%;
    height: auto;
  }
}

@media (max-width: 640px) {
  .auth-modal-panel,
  .auth-info-modal-panel {
    width: min(100%, calc(100dvw - 0.75rem));
    margin: 0.5rem auto 0;
    max-height: calc(100dvh - 1rem);
    padding: 0;
    border-radius: 12px;
  }

  .auth-modal-scroll {
    max-height: calc(100dvh - 1rem);
    padding: 0.82rem 0.72rem 0.9rem;
  }

  .auth-platform-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.46rem;
  }

  .auth-platform-card {
    min-height: 3.15rem;
    padding: 0.48rem 0.5rem;
  }

  .post-page-modal-panel {
    width: min(100%, calc(100dvw - 0.75rem));
    max-height: calc(100dvh - 1rem);
    margin: 0.5rem auto;
    overflow: auto;
    padding: 0.84rem;
  }

  .post-page-modal-actions {
    flex-wrap: wrap;
  }
}

@media (max-width: 720px) {
  .zap-dialog-panel {
    width: min(100%, calc(100dvw - 0.75rem));
    max-height: calc(100dvh - 0.75rem);
    margin: 0.38rem auto;
    border-radius: 1rem;
  }

  .zap-dialog-scroll {
    max-height: calc(100dvh - 0.75rem);
  }

  .zap-amount-chips {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.46rem;
  }

  .zap-amount-chip {
    min-height: 3.4rem;
    padding: 0.5rem 0.56rem;
  }

  .zap-dialog-head,
  .zap-dialog-grid,
  .zap-dialog-actions,
  .zap-dialog-status,
  .zap-dialog-invoice {
    margin-left: 0.78rem;
    margin-right: 0.78rem;
  }

  .zap-dialog-head {
    padding-top: 1rem;
  }
}

@media (max-width: 420px) {
  .zap-amount-chips {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .nostr-publish-modal-panel {
    width: min(100%, calc(100dvw - 0.75rem));
    max-width: min(100%, calc(100dvw - 0.75rem));
    max-height: calc(100dvh - 0.75rem);
    overflow: auto;
  }

  .nostr-publish-json {
    max-height: min(34dvh, 16rem);
  }
}

/* Compact public pages: keep the control-panel nav and list shells usable below tablet width. */
@media (max-width: 920px) {
  body {
    max-width: 100%;
    padding-left: 0.72rem;
    padding-right: 0.72rem;
  }

  nav.site-nav {
    display: grid !important;
    width: min(100%, calc(100vw - 0.72rem)) !important;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) !important;
    grid-template-rows: auto auto !important;
    min-height: 0;
    padding: 0.5rem 0.62rem 0.58rem !important;
    gap: 0.42rem 0.48rem !important;
  }

  nav.site-nav > .nav-site-signature {
    grid-column: 2;
    grid-row: 1;
    justify-self: center !important;
    width: fit-content !important;
    min-width: 0 !important;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  nav.site-nav > .nav-right {
    grid-column: 3;
    grid-row: 1;
    width: auto !important;
    justify-self: end !important;
  }

  nav.site-nav > .nav-center {
    grid-column: 1 / -1;
    grid-row: 2;
    width: 100% !important;
    max-width: 100% !important;
    justify-self: stretch;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding-bottom: 0.06rem;
  }

  #main-content,
  .list-page-shell,
  .list-page-head,
  .list-page-content,
  .list-entries,
  .list-entry-line,
  .list-entry-first-line,
  .list-entry-main-inline {
    min-width: 0;
    max-width: 100%;
  }

  .list-page-shell {
    width: 100%;
    margin-top: 0.82rem;
    padding: 0.88rem 0.78rem 0.86rem;
    border-radius: 12px;
    overflow: visible;
  }
}

@media (max-width: 720px) {
  .list-page-head h1 {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.38rem 0.54rem;
    font-size: clamp(1.85rem, 8.8vw, 2.35rem);
  }

  .list-page-title-actions {
    width: 100%;
    margin: 0;
    padding: 0 0 0.34rem;
    transform: none;
    justify-content: flex-start;
    flex-wrap: wrap;
    row-gap: 0.36rem;
  }

  #blog-page-title {
    flex-wrap: nowrap;
    align-items: baseline;
  }

  #blog-page-title .list-page-title-actions {
    width: auto;
    margin-left: auto;
    padding: 0 0 0.22rem 0.45rem;
    flex-wrap: nowrap;
    justify-content: flex-end;
    row-gap: 0;
  }

  .list-page-admin-bar {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  #blog-page-title .blog-title-action-bar {
    width: auto;
    justify-content: flex-end;
    flex: 0 0 auto;
    flex-wrap: nowrap;
  }
}

#list-page-root .list-page-admin-bar button.list-admin-primary-btn,
#list-page-root .list-page-admin-bar button.list-admin-primary-btn:hover:not(:disabled),
#list-page-root .list-page-admin-bar button.list-admin-primary-btn:focus-visible:not(:disabled),
#list-page-root .list-page-admin-bar button.list-admin-primary-btn:active:not(:disabled),
#blog-page-root .list-page-admin-bar button.list-admin-primary-btn,
#blog-page-root .list-page-admin-bar button.list-admin-primary-btn:hover:not(:disabled),
#blog-page-root .list-page-admin-bar button.list-admin-primary-btn:focus-visible:not(:disabled),
#blog-page-root .list-page-admin-bar button.list-admin-primary-btn:active:not(:disabled),
#contact-page-root .list-page-admin-bar button.list-admin-primary-btn,
#contact-page-root .list-page-admin-bar button.list-admin-primary-btn:hover:not(:disabled),
#contact-page-root .list-page-admin-bar button.list-admin-primary-btn:focus-visible:not(:disabled),
#contact-page-root .list-page-admin-bar button.list-admin-primary-btn:active:not(:disabled),
#nip23-page-root .list-page-admin-bar button.list-admin-primary-btn,
#nip23-page-root .list-page-admin-bar button.list-admin-primary-btn:hover:not(:disabled),
#nip23-page-root .list-page-admin-bar button.list-admin-primary-btn:focus-visible:not(:disabled),
#nip23-page-root .list-page-admin-bar button.list-admin-primary-btn:active:not(:disabled),
#public-ranking-root .list-page-admin-bar button.list-admin-primary-btn,
#public-ranking-root .list-page-admin-bar button.list-admin-primary-btn:hover:not(:disabled),
#public-ranking-root .list-page-admin-bar button.list-admin-primary-btn:focus-visible:not(:disabled),
#public-ranking-root .list-page-admin-bar button.list-admin-primary-btn:active:not(:disabled) {
  border: 0 !important;
  border-top: 0 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  border-left: 0 !important;
  border-inline-start: 0 !important;
  border-inline-end: 0 !important;
  border-block-start: 0 !important;
  border-block-end: 0 !important;
  border-color: transparent !important;
  border-image: none !important;
  outline: 0;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  background: var(--action-soft-bg, #f5e4d7) !important;
  background-color: var(--action-soft-bg, #f5e4d7) !important;
  background-image: none !important;
  background-clip: padding-box !important;
  -webkit-background-clip: padding-box !important;
  background-origin: padding-box !important;
  filter: none !important;
  text-shadow: none !important;
  clip-path: none !important;
  contain: none !important;
  overflow: visible !important;
}

#list-page-title .list-page-title-actions .list-admin-primary-btn,
#list-page-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#list-page-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#list-page-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled),
#blog-page-title .list-page-title-actions .list-admin-primary-btn,
#blog-page-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#blog-page-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#blog-page-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled),
#contact-page-title .list-page-title-actions .list-admin-primary-btn,
#contact-page-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#contact-page-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#contact-page-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled),
#nip23-page-title .list-page-title-actions .list-admin-primary-btn,
#nip23-page-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#nip23-page-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#nip23-page-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled),
#public-ranking-title .list-page-title-actions .list-admin-primary-btn,
#public-ranking-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#public-ranking-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#public-ranking-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled) {
  border: 1px solid var(--action-soft-border, #c58f6f) !important;
  border-image: none !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  background-clip: border-box !important;
  -webkit-background-clip: border-box !important;
  clip-path: none;
  contain: none;
  overflow: visible;
}

/* Final title-action button reset: no border layer around compact admin buttons. */
#list-page-title .list-page-title-actions .list-admin-primary-btn,
#list-page-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#list-page-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#list-page-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled),
#blog-page-title .list-page-title-actions .list-admin-primary-btn,
#blog-page-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#blog-page-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#blog-page-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled),
#blog-page-title .list-page-title-actions .blog-filter-toggle,
#blog-page-title .list-page-title-actions .blog-filter-toggle:hover,
#blog-page-title .list-page-title-actions .blog-filter-toggle:focus-visible,
#blog-page-title .list-page-title-actions .blog-filter-toggle[aria-expanded="true"],
#contact-page-title .list-page-title-actions .list-admin-primary-btn,
#contact-page-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#contact-page-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#contact-page-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled),
#nip23-page-title .list-page-title-actions .list-admin-primary-btn,
#nip23-page-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#nip23-page-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#nip23-page-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled),
#public-ranking-title .list-page-title-actions .list-admin-primary-btn,
#public-ranking-title .list-page-title-actions .list-admin-primary-btn:hover:not(:disabled),
#public-ranking-title .list-page-title-actions .list-admin-primary-btn:focus-visible:not(:disabled),
#public-ranking-title .list-page-title-actions .list-admin-primary-btn:active:not(:disabled) {
  appearance: none !important;
  -webkit-appearance: none !important;
  border: 0 !important;
  border-top: 0 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  border-left: 0 !important;
  border-inline: 0 !important;
  border-block: 0 !important;
  border-image: none !important;
  outline: 0;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  background-clip: padding-box !important;
  -webkit-background-clip: padding-box !important;
  background-origin: padding-box !important;
  clip-path: none !important;
  contain: none !important;
  overflow: visible !important;
}

@media (max-width: 640px) {
  nav.site-nav {
    overflow: visible !important;
  }

  nav.site-nav .nav-login-menu {
    max-width: calc(100vw - 1rem);
  }
}

:where(.nav-menu-panel, .nav-login-menu, .nav-overflow-panel, .post-page-menu-panel, .list-inline-row-menu) :where(a, button, .nav-menu-item, [role="menuitem"]) {
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
}

:where(.nav-menu-panel, .nav-login-menu, .nav-overflow-panel, .post-page-menu-panel, .list-inline-row-menu) :where(a, button, .nav-menu-item, [role="menuitem"]):hover,
:where(.nav-menu-panel, .nav-login-menu, .nav-overflow-panel, .post-page-menu-panel, .list-inline-row-menu) :where(a, button, .nav-menu-item, [role="menuitem"]):focus-visible {
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
}

.nav-menu-panel .nav-menu-item,
.nav-menu-panel button,
.nav-login-menu .nav-menu-item,
.nav-login-menu button,
.nav-overflow-panel .nav-menu-item,
.nav-overflow-panel button,
.post-page-menu-panel button,
.list-inline-row-menu button {
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
}

.nav-menu-panel .nav-menu-item:hover,
.nav-menu-panel .nav-menu-item:focus-visible,
.nav-menu-panel button:hover,
.nav-menu-panel button:focus-visible,
.nav-login-menu .nav-menu-item:hover,
.nav-login-menu .nav-menu-item:focus-visible,
.nav-login-menu button:hover,
.nav-login-menu button:focus-visible,
.nav-overflow-panel .nav-menu-item:hover,
.nav-overflow-panel .nav-menu-item:focus-visible,
.nav-overflow-panel button:hover,
.nav-overflow-panel button:focus-visible,
.post-page-menu-panel button:hover,
.post-page-menu-panel button:focus-visible,
.list-inline-row-menu button:hover,
.list-inline-row-menu button:focus-visible {
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
}

#nav-menu-panel .nav-menu-item,
#nav-menu-panel button,
#nav-login-menu .nav-menu-item,
#nav-login-menu button,
#nav-overflow-panel .nav-menu-item,
#nav-overflow-panel button,
#main-content .post-page-menu-panel button,
#main-content .list-inline-row-menu button,
#main-content .list-inline-row-menu button[role="menuitem"] {
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
  transform: none !important;
}

#nav-menu-panel .nav-menu-item:hover,
#nav-menu-panel .nav-menu-item:focus-visible,
#nav-menu-panel button:hover,
#nav-menu-panel button:focus-visible,
#nav-login-menu .nav-menu-item:hover,
#nav-login-menu .nav-menu-item:focus-visible,
#nav-login-menu button:hover,
#nav-login-menu button:focus-visible,
#nav-overflow-panel .nav-menu-item:hover,
#nav-overflow-panel .nav-menu-item:focus-visible,
#nav-overflow-panel button:hover,
#nav-overflow-panel button:focus-visible,
#main-content .post-page-menu-panel button:hover,
#main-content .post-page-menu-panel button:focus-visible,
#main-content .list-inline-row-menu button:hover,
#main-content .list-inline-row-menu button:focus-visible,
#main-content .list-inline-row-menu button[role="menuitem"]:hover,
#main-content .list-inline-row-menu button[role="menuitem"]:focus-visible {
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: var(--menu-hover-bg, rgba(15, 23, 42, 0.06)) !important;
  background-image: none !important;
  transform: none !important;
}

/* Final menu-item flattening: popup rows are not individual button cards. */
:where(.nav-menu-panel, .nav-login-menu, .nav-overflow-panel, .post-page-menu-panel, .list-inline-row-menu) {
  padding: 0.25rem 0 !important;
}

:where(.nav-menu-panel, .nav-login-menu, .nav-overflow-panel, .post-page-menu-panel, .list-inline-row-menu) :where(a, button, .nav-menu-item, [role="menuitem"]),
#main-content .post-page-menu-panel button,
#main-content .list-inline-row-menu button {
  appearance: none !important;
  -webkit-appearance: none !important;
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  filter: none !important;
  transform: none !important;
  text-align: left !important;
  padding: 0.5rem 0.85rem !important;
}

:where(.nav-menu-panel, .nav-login-menu, .nav-overflow-panel, .post-page-menu-panel, .list-inline-row-menu) :where(a, button, .nav-menu-item, [role="menuitem"]):hover,
:where(.nav-menu-panel, .nav-login-menu, .nav-overflow-panel, .post-page-menu-panel, .list-inline-row-menu) :where(a, button, .nav-menu-item, [role="menuitem"]):focus-visible,
#main-content .post-page-menu-panel button:hover,
#main-content .post-page-menu-panel button:focus-visible,
#main-content .list-inline-row-menu button:hover,
#main-content .list-inline-row-menu button:focus-visible {
  border: 0 !important;
  border-radius: 0 !important;
  background: var(--menu-hover-bg, rgba(15, 23, 42, 0.06)) !important;
  background-color: var(--menu-hover-bg, rgba(15, 23, 42, 0.06)) !important;
  background-image: none !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  filter: none !important;
  transform: none !important;
}

nav.site-nav > .nav-right .nav-search {
  --nav-search-button-size: 26px;
  width: var(--nav-search-button-size) !important;
  min-width: var(--nav-search-button-size) !important;
  max-width: var(--nav-search-button-size) !important;
  height: var(--nav-search-button-size) !important;
  overflow: visible !important;
  box-shadow: none !important;
}

nav.site-nav > .nav-right .nav-search.is-search-expanded,
nav.site-nav > .nav-right .nav-search.has-search-value,
nav.site-nav > .nav-right .nav-search:focus-within {
  width: var(--nav-search-button-size) !important;
  min-width: var(--nav-search-button-size) !important;
  max-width: var(--nav-search-button-size) !important;
}

nav.site-nav > .nav-right .nav-search button {
  width: var(--nav-search-button-size) !important;
  min-width: var(--nav-search-button-size) !important;
  height: var(--nav-search-button-size) !important;
  min-height: var(--nav-search-button-size) !important;
  padding: 0 !important;
  border: 1px solid color-mix(in srgb, var(--amethyst, var(--theme_accent, #6a4fa3)) 42%, transparent) !important;
  border-radius: 999px !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  color: var(--amethyst, var(--theme_accent, #6a4fa3)) !important;
  -webkit-text-fill-color: currentColor !important;
  line-height: 1 !important;
  overflow: visible !important;
  clip-path: none !important;
}

nav.site-nav > .nav-right .nav-search button:hover,
nav.site-nav > .nav-right .nav-search button:focus-visible {
  border-color: color-mix(in srgb, var(--amethyst, var(--theme_accent, #6a4fa3)) 62%, transparent) !important;
  background: color-mix(in srgb, var(--amethyst, var(--theme_accent, #6a4fa3)) 15%, transparent) !important;
  background-image: none !important;
  box-shadow: none !important;
  color: var(--amethyst-dark, var(--amethyst, var(--theme_accent, #6a4fa3))) !important;
  -webkit-text-fill-color: currentColor !important;
}

nav.site-nav > .nav-right .nav-search button svg {
  display: block;
  width: 14px;
  height: 14px;
}

nav.site-nav > .nav-right .nav-search input[type="text"] {
  right: var(--nav-search-button-size) !important;
  top: 0 !important;
  bottom: auto !important;
  height: var(--nav-search-button-size) !important;
  min-height: var(--nav-search-button-size) !important;
  padding-block: 0 !important;
  line-height: 1 !important;
  border-radius: 999px 0 0 999px !important;
}

nav.site-nav > .nav-right .nav-search.is-search-expanded input[type="text"],
nav.site-nav > .nav-right .nav-search.has-search-value input[type="text"],
nav.site-nav > .nav-right .nav-search:focus-within input[type="text"] {
  width: 196px !important;
  max-width: 196px !important;
  opacity: 1 !important;
  transform: scaleX(1) !important;
}

html body nav.site-nav > .nav-right form.nav-search button[type="submit"] {
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  background: transparent !important;
  background-image: none !important;
}

html body nav.site-nav > .nav-right form.nav-search button[type="submit"]:hover,
html body nav.site-nav > .nav-right form.nav-search button[type="submit"]:focus-visible {
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  background: color-mix(in srgb, var(--amethyst, var(--theme_accent, #6a4fa3)) 15%, transparent) !important;
  background-image: none !important;
}

@media (min-width: 480px) {
  nav.site-nav {
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) !important;
  }

  nav.site-nav > .nav-site-signature {
    grid-column: 2;
    justify-self: center !important;
    width: fit-content !important;
    max-width: max-content !important;
    transform: translateY(1px) !important;
    transition: transform 240ms cubic-bezier(0.2, 0.9, 0.2, 1) !important;
  }

  nav.site-nav > .nav-right {
    grid-column: 3;
    justify-self: end !important;
  }

  nav.site-nav:has(> .nav-right .nav-search.is-search-expanded) > .nav-site-signature,
  nav.site-nav:has(> .nav-right .nav-search.has-search-value) > .nav-site-signature,
  nav.site-nav:has(> .nav-right .nav-search:focus-within) > .nav-site-signature {
    transform: translateX(-7rem) translateY(1px) !important;
  }

  nav.site-nav.has-expanded-search > .nav-site-signature {
    transform: translateX(-7rem) translateY(1px) !important;
  }
}

/* Keep the navbar aligned to the same content column as the page below it. */
body:not(.blog-post-resize-enabled):not(.list-page-wide):not(:has(.post-single-item)) #main-content {
  width: min(100%, var(--site-content-width));
  margin-left: auto;
  margin-right: auto;
}

nav.site-nav {
  width: min(100%, var(--site-content-width)) !important;
  max-width: calc(100vw - 1rem) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  justify-self: center !important;
}

body:has(.post-single-item) nav.site-nav {
  width: var(--blog-post-resizable-width, clamp(30rem, 92vw, 60rem)) !important;
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  justify-self: center !important;
}

body:has(.post-single-item.post-single-has-wide-content) nav.site-nav {
  width: var(--blog-post-resizable-width, clamp(26rem, 96vw, 72rem)) !important;
}

nav.site-nav > .nav-right form.nav-search button[type="submit"] {
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
}

nav.site-nav > .nav-right form.nav-search button[type="submit"]:hover,
nav.site-nav > .nav-right form.nav-search button[type="submit"]:focus-visible {
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
}

.blog-draft-notice .blog-draft-notice-close,
.blog-draft-notice .blog-draft-notice-close:hover,
.blog-draft-notice .blog-draft-notice-close:focus-visible,
#main-content .blog-draft-notice .blog-draft-notice-close,
#main-content .blog-draft-notice .blog-draft-notice-close:hover,
#main-content .blog-draft-notice .blog-draft-notice-close:focus-visible {
  border: 0 !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  background-image: none !important;
}

.blog-draft-notice .blog-draft-notice-close,
#main-content .blog-draft-notice .blog-draft-notice-close {
  background: transparent !important;
}

.blog-draft-notice .blog-draft-notice-close:hover,
.blog-draft-notice .blog-draft-notice-close:focus-visible,
#main-content .blog-draft-notice .blog-draft-notice-close:hover,
#main-content .blog-draft-notice .blog-draft-notice-close:focus-visible {
  background: rgba(15, 23, 42, 0.10) !important;
}

nav.site-nav .nav-menu-btn,
nav.site-nav .nav-menu-btn:hover,
nav.site-nav .nav-menu-btn:focus-visible,
nav.site-nav .nav-user-menu .nav-menu-btn,
nav.site-nav .nav-user-menu .nav-menu-btn:hover,
nav.site-nav .nav-user-menu .nav-menu-btn:focus-visible {
  transform: none !important;
  translate: none !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
}

nav.site-nav .nav-menu-btn:hover,
nav.site-nav .nav-menu-btn:focus-visible,
nav.site-nav .nav-user-menu .nav-menu-btn:hover,
nav.site-nav .nav-user-menu .nav-menu-btn:focus-visible {
  border-radius: 7px !important;
  background: rgba(15, 23, 42, 0.10) !important;
  background-image: none !important;
}

.blog-compose-card .compose-post-type-toolbar {
  box-shadow: none !important;
}

.blog-compose-card .compose-post-type-pill {
  border-right: 1px solid color-mix(in srgb, var(--amethyst, var(--theme_accent, #6a4fa3)) 42%, transparent) !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  background-image: none !important;
  filter: none !important;
}

.blog-compose-card .compose-post-type-pill:last-child {
  border-right: 0 !important;
}

.overworld-page-shell {
  max-width: min(1180px, calc(100vw - 32px));
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 18px 0 36px;
}

.overworld-page-head {
  margin-bottom: 12px;
}

.overworld-godot-shell {
  display: grid;
  gap: 10px;
}

.overworld-godot-frame-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: min(64vh, 640px);
  border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
  border-radius: 8px;
  overflow: hidden;
  background: #101310;
  touch-action: none;
}

.overworld-godot-splash {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  color: #f7f1df;
  background: linear-gradient(180deg, #101310, #080a08);
}

.overworld-godot-splash-panel {
  display: grid;
  justify-items: center;
  gap: 12px;
  max-width: 34rem;
  text-align: center;
}

.overworld-godot-kicker {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(247, 241, 223, 0.26);
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 0.78rem;
  line-height: 1.15;
  color: rgba(247, 241, 223, 0.82);
  background: rgba(247, 241, 223, 0.10);
}

.overworld-godot-title {
  margin: 0;
  padding: 0;
  border: 0;
  background: none;
  font-size: clamp(1.35rem, 2vw, 2.2rem);
  line-height: 1.08;
  color: #fff8e8 !important;
  -webkit-text-fill-color: #fff8e8;
  text-decoration: none;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.48);
}

.overworld-godot-copy {
  margin: 0;
  max-width: 28rem;
  color: rgba(247, 241, 223, 0.88);
  -webkit-text-fill-color: rgba(247, 241, 223, 0.88);
  line-height: 1.35;
}

.overworld-godot-download {
  appearance: none;
  width: auto;
  border: 1px solid rgba(255, 250, 231, 0.44);
  border-radius: 7px;
  padding: 9px 13px;
  font: inherit;
  line-height: 1.2;
  font-weight: 700;
  color: #17221b;
  -webkit-text-fill-color: #17221b;
  background: #fff1b8;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.24);
  cursor: pointer;
}

.overworld-godot-download:hover,
.overworld-godot-download:focus-visible {
  background: #fff6d1;
  outline: 2px solid rgba(255, 246, 209, 0.42);
  outline-offset: 3px;
}

.overworld-godot-download[disabled] {
  cursor: default;
  opacity: 0.72;
}

.overworld-godot-frame {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  background: #101310;
  touch-action: none;
}

.overworld-godot-status {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  gap: 8px;
  border: 1px solid color-mix(in srgb, currentColor 14%, transparent);
  border-radius: 7px;
  padding: 6px 9px;
  font-size: 0.86rem;
  color: color-mix(in srgb, currentColor 72%, transparent);
  background: color-mix(in srgb, canvas 91%, #dfe8da 9%);
}

.overworld-godot-status::before {
  content: "";
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 999px;
  background: #b78f31;
  box-shadow: 0 0 0 3px color-mix(in srgb, #b78f31 18%, transparent);
}

.overworld-godot-status.is-ready::before {
  background: #2f7b55;
  box-shadow: 0 0 0 3px color-mix(in srgb, #2f7b55 18%, transparent);
}

.overworld-godot-help {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
  color: color-mix(in srgb, currentColor 76%, transparent);
  font-size: 0.9rem;
  line-height: 1.35;
}

.overworld-godot-keys {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.overworld-godot-key {
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  border: 1px solid color-mix(in srgb, currentColor 20%, transparent);
  border-radius: 6px;
  padding: 2px 8px;
  background: color-mix(in srgb, canvas 88%, currentColor 5%);
  color: color-mix(in srgb, currentColor 84%, transparent);
}

.overworld-godot-login-note {
  max-width: 42rem;
}

@media (max-width: 720px) {
  .overworld-page-shell {
    max-width: 100%;
    padding: 8px 0 24px;
  }

  .overworld-godot-frame-wrap {
    aspect-ratio: auto;
    min-height: 0;
    height: min(78vh, 640px);
    height: min(78svh, 640px);
    max-height: calc(100vh - 96px);
    max-height: calc(100svh - 96px);
    border-radius: 6px;
  }

  .overworld-godot-splash {
    padding: 12px;
  }

  .overworld-godot-splash-panel {
    gap: 8px;
    max-width: min(21rem, 100%);
  }

  .overworld-godot-title {
    font-size: clamp(1.25rem, 7vw, 1.8rem);
  }

  .overworld-godot-copy,
  .overworld-godot-status {
    font-size: 0.9rem;
  }

  .overworld-godot-download {
    min-height: 44px;
    padding: 10px 14px;
    touch-action: manipulation;
  }

  .overworld-godot-status {
    justify-self: center;
    max-width: calc(100vw - 20px);
  }

  .overworld-godot-help {
    justify-content: center;
    padding-inline: 10px;
    text-align: center;
  }

  .overworld-godot-keys {
    justify-content: center;
  }
}

@media (max-width: 480px) {
  .overworld-godot-frame-wrap {
    height: min(76vh, 600px);
    height: min(76svh, 600px);
    max-height: calc(100vh - 88px);
    max-height: calc(100svh - 88px);
  }

  .overworld-godot-copy {
    max-width: 18rem;
  }
}

@media (orientation: landscape) and (max-height: 520px) {
  .overworld-page-shell {
    max-width: 100%;
    padding-block: 6px 12px;
  }

  .overworld-godot-frame-wrap {
    height: calc(100vh - 70px);
    height: calc(100svh - 70px);
    min-height: 280px;
    max-height: none;
  }

  .overworld-godot-splash-panel {
    max-width: min(26rem, calc(100vw - 24px));
  }
}
