:root {
  color-scheme: light dark;

  --radius: 12px;
  --shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
  --btn-radius: 999px;
  --input-radius: 12px;
  --bg-page: #050810;
  --bg-card: #111827;
  --bg-elev: #020617;
  --border: #1f2937;
  --txt: #e5edf9;
  --muted: #9ca3af;
  --brand: #8ab4ff;
  --ok: #22c55e;
  --warn: #fbbf24;
  --err: #ef4444;
  --focus: #8ab4ff;
  --link: var(--brand);
  --input-bg: #0b1220;
  --btn-primary-bg: #6ea4ff;
  --btn-primary-fg: #ffffff;
  --btn-secondary-bg: #111827;
  --btn-secondary-fg: var(--txt);
  --card: var(--bg-card);
  --primary-2: rgba(99, 102, 241, 0.95);
}

:root {
  --emoji-popover-bg: var(--card);
  --emoji-popover-border: var(--border);
}

.emoji-popover {
  background: var(--emoji-popover-bg) !important;
  background-image: none !important;
  opacity: 1 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-color: var(--emoji-popover-border) !important;
}

@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;
  }
}
@media (prefers-color-scheme: light) {
  :root {
    color-scheme: light;
  }
}

@media (prefers-color-scheme: dark) {
  select,
  input,
  textarea {
    color-scheme: dark;
  }

  select option {
    background: #0b1220;
    color: #e5edf9;
  }

  input[type="date"],
  input[type="datetime-local"],
  input[type="month"],
  input[type="time"],
  input[type="week"] {
    color-scheme: dark;
  }
  input[type="date"]::-webkit-calendar-picker-indicator,
  input[type="datetime-local"]::-webkit-calendar-picker-indicator,
  input[type="month"]::-webkit-calendar-picker-indicator,
  input[type="time"]::-webkit-calendar-picker-indicator,
  input[type="week"]::-webkit-calendar-picker-indicator {
    filter: invert(1) brightness(1.15);
    opacity: 0.9;
    cursor: pointer;
  }
}

:root[data-theme="dark"] {
  --bg-page: #050810;
  --bg-card: #111827;
  --bg-elev: #020617;
  --border: #1f2937;
  --txt: #e5edf9;
  --muted: #9ca3af;
  --brand: #8ab4ff;
  --ok: #22c55e;
  --warn: #fbbf24;
  --err: #ef4444;
  --focus: #8ab4ff;

  --link: var(--brand);
  --input-bg: #0b1220;

  --btn-primary-bg: #6ea4ff;
  --btn-primary-fg: #ffffff;
  --btn-secondary-bg: #111827;
  --btn-secondary-fg: var(--txt);
}


:root[data-theme="light"] {
  --bg-page: #f3f4f6;
  --bg-card: #ffffff;
  --bg-elev: #f9fafb;
  --border: #e5e7eb;
  --txt: #020617;
  --muted: #6b7280;
  --brand: #2563eb;
  --ok: #16a34a;
  --warn: #eab308;
  --err: #dc2626;
  --focus: #2563eb;

  --link: var(--brand);
  --input-bg: #ffffff;

  --btn-primary-bg: #2563eb;
  --btn-primary-fg: #ffffff;
  --btn-secondary-bg: #f3f4f6;
  --btn-secondary-fg: var(--txt);
}

@media (prefers-color-scheme: light) {
  :root:not([data-theme]) {
    --bg-page: #f3f4f6;
    --bg-card: #ffffff;
    --bg-elev: #f9fafb;
    --border: #e5e7eb;
    --txt: #020617;
    --muted: #6b7280;
    --brand: #2563eb;
    --focus: #2563eb;

    --btn-primary-bg: #2563eb;
    --btn-primary-fg: #ffffff;
    --btn-secondary-bg: #f3f4f6;
    --btn-secondary-fg: #020617;

    --input-bg: #ffffff;
  }
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

body {
  background: var(--bg-page);
  color: var(--txt);
  font:
    14px/1.6 system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    Arial,
    sans-serif;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

.container {
  max-width: 1100px;
  margin: 24px auto 32px;
  padding: 0 16px;
}

.site-header,
.site-footer {
  background: var(--bg-elev);
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

.site-footer {
  border-top: 1px solid rgba(148, 163, 184, 0.18);
  border-bottom: none;
  margin-top: 28px;
}

.site-header .wrap,
.site-footer .wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 10px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.brand {
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.03em;
  color: var(--txt);
}

.header-actions {
  display: flex;
  gap: 8px;
}

.pageHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 18px 0 12px;
  flex-wrap: wrap;
}
.pageHeader h2 {
  margin: 0;
  font-size: 20px;
}

.muted {
  color: var(--muted);
}

a {
  color: var(--link);
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}
a:visited {
  color: var(--link);
}

::selection {
  background: color-mix(in oklab, var(--focus) 30%, transparent);
}

.cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}

.card {
  background: var(--bg-card);
  border: 1px solid rgba(148, 163, 184, 0.26);
  border-radius: 18px;
  padding: 16px 16px 14px;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.6);
  transition:
    transform 0.12s ease-out,
    box-shadow 0.14s ease-out,
    border-color 0.18s ease-out;
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.8);
  border-color: rgba(148, 163, 184, 0.5);
}

.card .cover {
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.3);
  margin-bottom: 10px;
}

.card h3 {
  margin: 0 0 6px;
  font-size: 16px;
}

.card .meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: 6px;
  font-size: 12px;
  color: var(--muted);
}

.article h1 {
  margin: 10px 0 12px;
  font-size: 22px;
}

.article .cover {
  width: 100%;
  height: auto;
  max-height: 320px;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.35);
  margin: 10px 0 18px;
}

.article .content {
  font-size: 15px;
}
.article .content p {
  margin: 10px 0;
}
.article .content ul,
.article .content ol {
  padding-left: 22px;
}
.article .content pre {
  background: #020617;
  padding: 12px;
  border-radius: 10px;
  overflow: auto;
  border: 1px solid var(--border);
  font-size: 13px;
}
:root[data-theme="light"] .article .content pre {
  background: #0f172a0d;
}

.article .meta-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--muted);
  margin-top: 18px;
  font-size: 12px;
}

.tag {
  color: var(--brand);
  text-decoration: none;
  margin-right: 8px;
  font-size: 12px;
}
.tag:hover {
  text-decoration: underline;
}

.back {
  color: var(--muted);
}

.form {
  display: grid;
  gap: 12px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.field .label {
  color: var(--muted);
  font-size: 12px;
}

.field input,
.field select,
textarea {
  width: 100%;
  background: var(--input-bg);
  border: 1px solid var(--border);
  color: var(--txt);
  border-radius: var(--input-radius);
  padding: 10px 12px;
  font: inherit;
}

.input,
.select,
.textarea {
  width: 100%;
  background: var(--input-bg);
  border: 1px solid var(--border);
  color: var(--txt);
  border-radius: var(--input-radius);
  padding: 10px 12px;
  outline: none;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease,
    background 0.15s ease;
  height: 42px;
}

.textarea {
  height: auto;
  min-height: 140px;
  resize: vertical;
  padding: 12px 12px;
  line-height: 1.45;
}

.input:focus,
.select:focus,
.textarea:focus {
  border-color: var(--primary-2);
  box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.25);
}

.select {
  -webkit-appearance: none;
  appearance: none;
  -moz-appearance: none;
  padding-right: 40px;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) 50%,
    calc(100% - 13px) 50%;
  background-size:
    5px 5px,
    5px 5px;
  background-repeat: no-repeat;
}

.select:hover {
  border-color: color-mix(in srgb, var(--border), var(--txt) 18%);
}

.btn-icon {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.btn-icon .btn-ico {
  font-size: 18px;
  line-height: 1;
}
.btn-icon .btn-text {
  font-weight: 800;
  letter-spacing: 0.2px;
}

.chk {
  -webkit-appearance: none;
  appearance: none;
  width: 24px;
  height: 24px;
  border-radius: 9px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card), #fff 6%);
  display: inline-grid;
  place-content: center;
  cursor: pointer;
  transition:
    transform 0.08s ease,
    border-color 0.15s ease,
    background 0.15s ease,
    box-shadow 0.15s ease;
}
.chk::before {
  content: "";
  width: 11px;
  height: 6px;
  border-left: 2px solid rgba(255, 255, 255, 0.95);
  border-bottom: 2px solid rgba(255, 255, 255, 0.95);
  transform: rotate(-45deg) scale(0.7);
  opacity: 0;
  transition:
    opacity 0.12s ease,
    transform 0.12s ease;
  margin-top: -1px;
}
.chk:checked {
  background: linear-gradient(
    180deg,
    rgba(99, 102, 241, 0.95),
    rgba(79, 70, 229, 0.95)
  );
  border-color: rgba(99, 102, 241, 0.95);
  box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.18);
}
.chk:checked::before {
  opacity: 1;
  transform: rotate(-45deg) scale(1);
}
.chk:active {
  transform: scale(0.96);
}
.chk:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.25);
}

.field input::placeholder,
textarea::placeholder {
  color: color-mix(in oklab, var(--muted) 80%, transparent);
}

.field input:focus,
.field select:focus,
textarea:focus {
  outline: 2px solid color-mix(in oklab, var(--focus) 55%, transparent);
  outline-offset: 1px;
}

.file-input {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
}
.file-meta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.image-preview {
  margin-top: 10px;
  max-width: 280px;
  border-radius: 14px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.emoji-wrap {
  position: relative;
}
.emoji-btn {
  height: 42px;
  padding: 0 14px;
  border-radius: 12px;
  white-space: nowrap;
}
.emoji-popover {
  position: absolute;
  right: 0;
  top: 46px;
  width: min(340px, 92vw);
  background: color-mix(in oklab, var(--card) 92%, #000 8%);
  border: 1px solid color-mix(in oklab, var(--border) 75%, transparent);
  border-radius: 16px;
  padding: 10px;
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(12px);
  z-index: 40;
}

.emoji-popover.open {
  display: block;
}
.emoji-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 6px;
  padding: 4px;
  background: transparent;
}

.emoji-item {
  height: 34px;
  width: 34px;
  display: grid;
  place-items: center;
  border: 1px solid transparent;
  border-radius: 12px;
  background: transparent;
  cursor: pointer;
  user-select: none;
  transition:
    transform 0.08s ease,
    background 0.12s ease,
    border-color 0.12s ease;
}
.emoji-item:hover {
  background: rgba(99, 102, 241, 0.14);
  border-color: rgba(99, 102, 241, 0.18);
  transform: translateY(-1px);
}
.emoji-item:active {
  transform: translateY(0);
}

.emoji-item:hover {
  background: color-mix(in oklab, var(--brand) 18%, transparent);
}

@media (max-width: 520px) {
  .emoji-grid {
    grid-template-columns: repeat(8, 1fr);
  }
}

.editor {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.editor .preview {
  border: 1px dashed var(--border);
  border-radius: 12px;
  padding: 12px;
  min-height: 200px;
  background: color-mix(in oklab, var(--bg-page) 85%, black);
}
:root[data-theme="light"] .editor .preview {
  background: #f8fafc;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: var(--btn-radius);
  text-decoration: none;
  cursor: pointer;
  border: 1px solid rgba(148, 163, 184, 0.5);
  background: var(--btn-secondary-bg);
  color: var(--btn-secondary-fg);
  font-size: 13px;
  font-weight: 500;
  transition:
    transform 0.07s ease-out,
    filter 0.15s ease-out,
    background-color 0.16s ease-out,
    border-color 0.16s ease-out,
    box-shadow 0.16s ease-out;
}
.btn:hover {
  filter: brightness(1.03);
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.45);
}
.btn:active {
  transform: translateY(1px);
  box-shadow: 0 0 0 rgba(0, 0, 0, 0);
}
.btn-sm {
  padding: 6px 10px;
  font-size: 12px;
}
.btn-primary {
  background: var(--btn-primary-bg);
  color: var(--btn-primary-fg) !important;
  border-color: transparent;
}
.btn-secondary {
  background: var(--btn-secondary-bg);
  color: var(--btn-secondary-fg);
}
.no-wrap {
  white-space: nowrap;
}

.docs-table {
  display: block;
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  background: var(--bg-card);
}

.docs-table .thead {
  background: var(--bg-elev);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
  font-size: 12px;
  position: sticky;
  top: 0;
  z-index: 1;
}

.docs-table .tr {
  display: grid;
  grid-template-columns:
    var(--col-name, 1.3fr) var(--col-type, 88px) var(--col-key, 2fr)
    var(--col-act, 190px);
  align-items: center;
}

.docs-table .tbody .tr:nth-child(odd) {
  background: rgba(255, 255, 255, 0.02);
}
:root[data-theme="light"] .docs-table .tbody .tr:nth-child(odd) {
  background: rgba(0, 0, 0, 0.02);
}

.docs-table .tbody .tr:hover {
  background: color-mix(in oklab, var(--bg-card) 90%, var(--brand) 6%);
}

.docs-table .td {
  padding: 10px 12px;
  text-align: left;
}

.mono {
  font-family:
    ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
    "Courier New", monospace;
}

.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
}
.badge.ok {
  background: #0b3321;
  color: #6ee7b7;
}
.badge.warn {
  background: #33250b;
  color: #ffd08a;
}
.badge.pin {
  background: #142a3a;
  color: #89c2ff;
}
:root[data-theme="light"] .badge.ok {
  background: #e6f7ef;
  color: #065f46;
}
:root[data-theme="light"] .badge.warn {
  background: #fff7e6;
  color: #92400e;
}
:root[data-theme="light"] .badge.pin {
  background: #e8f1ff;
  color: #1d4ed8;
}

.alert {
  padding: 10px 12px;
  border: 1px solid var(--warn);
  border-radius: 12px;
  color: #ffd08a;
  background: #2a1e0b;
  font-size: 13px;
}
:root[data-theme="dark"] .alert.ok {
  border-color: rgba(0, 220, 130, 0.35);
  color: #b9ffe2;
  background: rgba(0, 220, 130, 0.08);
}
:root[data-theme="light"] .alert {
  background: #fff7e6;
  color: #92400e;
}
:root[data-theme="light"] .alert.ok {
  background: #ecfdf5;
  color: #065f46;
  border-color: rgba(16, 185, 129, 0.35);
}

.empty {
  padding: 32px;
  text-align: center;
  color: var(--muted);
  border: 1px dashed var(--border);
  border-radius: 12px;
}

:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
  * {
    transition: none !important;
    animation: none !important;
  }
}

.docs-table.cols-5 .tr {
  grid-template-columns:
    var(--col-name, 1.3fr)
    var(--col-status, 140px)
    var(--col-slug, 1.1fr)
    var(--col-tags, 1.1fr)
    var(--col-act, 220px);
}

.kb-admin-list {
  --col-name: 1.3fr;
  --col-status: 140px;
  --col-slug: 1.1fr;
  --col-tags: 1.1fr;
  --col-act: 260px;
}

.kb-admin .btns {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.stack-12 > * + * {
  margin-top: 12px;
}
.stack-16 > * + * {
  margin-top: 16px;
}
.stack-20 > * + * {
  margin-top: 20px;
}

.kb-grid-5 .tr {
  grid-template-columns: 1.3fr 140px 1.2fr 1.2fr 260px;
}

.kb-admin .toolbar {
  display: grid;
  grid-template-columns: 1.2fr 160px 120px 1fr auto;
  gap: 12px;
  align-items: end;
}

.kb-admin .toolbar .field-pin {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
}
.kb-admin .toolbar .field-pin input[type="checkbox"] {
  width: 18px;
  height: 18px;
}
.kb-admin .toolbar .field input,
.kb-admin .toolbar .field select {
  height: 40px;
}
.kb-admin .toolbar .btn-reset {
  height: 40px;
  padding: 0 14px;
  border-radius: 12px;
  align-self: end;
}

.kb-edit .top-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.kb-edit .editor-grid {
  display: grid;
  grid-template-columns: 1.6fr 0.9fr;
  gap: 16px;
  align-items: start;
}

.kb-edit .meta-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 12px;
  position: sticky;
  top: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.kb-edit .meta-card .field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.kb-edit .meta-card .label {
  color: var(--muted);
  font-size: 12px;
}

.kb-edit .meta-card input,
.kb-edit .meta-card select,
.kb-edit .meta-card button {
  min-height: 40px;
  padding: 10px 12px;
  border-radius: 12px;
}

.kb-edit .slug-row {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas:
    "slug btn"
    "preview preview";
  gap: 8px;
  align-items: end;
}
.kb-edit .slug-row .slug-box {
  grid-area: slug;
  min-width: 0;
}
.kb-edit .btn-gen {
  grid-area: btn;
  align-self: end;
  margin-bottom: 2px;
}

.kb-edit .slug-box #slug {
  height: 36px;
  padding: 10px 14px;
  font-size: 15px;
  border-radius: 14px;
  max-width: 520px;
}

.kb-edit .slug-preview {
  grid-area: preview;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  width: 100%;
  line-height: 1.35;
}
.kb-edit .slug-preview .mono {
  min-width: 0;
  flex: 1 1 auto;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.kb-edit .slug-preview .slug-path {
  color: var(--muted);
}
.kb-edit .slug-preview .slug-seg {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  font-weight: 600;
}

.kb-edit .muted-url {
  margin-top: 6px;
  color: var(--muted);
}

.kb-edit .chips-pin-row {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: space-between;
}
.kb-edit .chips {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.kb-edit .chip {
  padding: 2px 8px;
  border-radius: 10px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  font-size: 12px;
}
.kb-edit .pin-inline {
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 8px;
}

.kb-edit .toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 8px 0 6px;
}
.kb-edit .preview {
  min-height: 220px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px;
}
.kb-edit .stats {
  display: flex;
  gap: 12px;
  color: var(--muted);
  font-size: 12px;
}
.kb-edit .help {
  font-size: 12px;
  color: var(--muted);
  margin-top: -4px;
}

.kb-edit .restore-banner {
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 10px 12px;
}
.kb-edit .restore-banner.show {
  display: flex;
}

.kb-edit .cover-preview {
  width: 100%;
  max-height: 220px;
  object-fit: cover;
  border: 1px solid var(--border);
  border-radius: 12px;
  display: none;
}

.kb-edit .dropzone {
  border: 1px dashed var(--border);
  border-radius: 12px;
  background: var(--bg-card);
  padding: 12px 14px;
}
.kb-edit .dz-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.kb-edit .dz-left {
  display: flex;
  align-items: center;
  gap: 10px;
}
.kb-edit .dz-ico {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
}
.kb-edit .dz-title {
  font-weight: 600;
}
.kb-edit .dz-hint {
  color: var(--muted);
  font-size: 12px;
  margin-top: 2px;
}
.kb-edit .dropzone.drag {
  outline: 2px dashed var(--brand);
  outline-offset: 2px;
}
.kb-edit .file-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
  color: var(--muted);
  font-size: 12px;
}

.kb-edit input.danger {
  outline: 2px solid var(--err);
}

.searchbar {
  display: flex;
  align-items: center;
  gap: 8px;
  width: clamp(280px, 36vw, 520px);
}
.searchbar .search-input {
  position: relative;
  flex: 1;
  min-width: 220px;
}
.searchbar .search-input input[type="text"] {
  height: 40px;
  padding: 10px 32px 10px 36px;
  width: 100%;
  border-radius: var(--input-radius);
  background: var(--input-bg);
  border: 1px solid var(--border);
  color: var(--txt);
}
.searchbar .search-input .ico {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.7;
  font-size: 14px;
}
.searchbar .search-input .clear {
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  border-radius: 8px;
  background: transparent;
  border: 0;
  cursor: pointer;
  color: var(--muted);
}
.searchbar .search-input .clear:hover {
  filter: brightness(1.1);
}

.filters-line {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin: 4px 0 14px;
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 12px;
  background: var(--bg-elev);
  color: var(--txt);
  border: 1px solid var(--border);
}
.pill a {
  color: inherit;
  text-decoration: none;
}
.link-reset {
  color: var(--muted);
  text-decoration: none;
}
.link-reset:hover {
  text-decoration: underline;
}

@media (max-width: 900px) {
  .editor {
    grid-template-columns: 1fr;
  }
  .kb-edit .editor-grid {
    grid-template-columns: 1fr;
  }
  .kb-edit .meta-card {
    position: static;
  }
}

@media (max-width: 720px) {
  .site-header .wrap {
    flex-wrap: wrap;
    gap: 6px;
  }
  .brand {
    font-size: clamp(16px, 4vw, 18px);
  }
  .header-actions {
    width: 100%;
    order: 3;
    gap: 6px;
  }
  .header-actions .btn {
    flex: 1 1 auto;
    justify-content: center;
  }
  main.container {
    padding: 0 12px;
  }
  .pageHeader h2 {
    flex: 1 1 100%;
  }
  .searchbar {
    width: 100%;
    max-width: 100%;
  }
}

.page-wrap {
  max-width: 980px;
  margin: 32px auto 40px;
  padding: 0 16px 40px;
}

.page-hero {
  margin-bottom: 18px;
}

.page-hero h1 {
  margin: 0 0 6px;
}

.page-meta {
  font-size: 13px;
  color: var(--muted);
}

.page-card {
  background: var(--bg-card);
  border-radius: 24px;
  padding: 28px 28px 32px;
  border: 1px solid var(--border);
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.18);
}

.legal-html {
  font-size: 15px;
  line-height: 1.7;
  color: var(--txt);
}

.legal-html * {
  color: inherit !important;
}

.legal-html h1,
.legal-html h2,
.legal-html h3 {
  margin-top: 20px;
  margin-bottom: 10px;
}

.legal-html p {
  margin: 10px 0;
}

.legal-html ol,
.legal-html ul {
  padding-left: 1.4em;
  margin: 8px 0 12px;
}

:root[data-theme="light"] .page-card.legal-html,
:root[data-theme="light"] .page-card .legal-html {
  color: #111827;
}

:root[data-theme="light"] .page-card.legal-html *,
:root[data-theme="light"] .page-card .legal-html * {
  color: inherit !important;
}

:root[data-theme="light"] .legal-html h1,
:root[data-theme="light"] .legal-html h2,
:root[data-theme="light"] .legal-html h3 {
  color: #020617;
  font-weight: 700;
}

:root[data-theme="light"] .page-card {
  background: #ffffff;
  border-color: #dde3ee;
}

.file-input {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
}
.file-meta {
  font-size: 12px;
  color: var(--muted);
}
.image-preview {
  margin-top: 10px;
  max-width: 360px;
  width: 100%;
  border-radius: 14px;
  border: 1px solid var(--border);
}
.emoji-wrap {
  position: relative;
}
.emoji-btn {
  height: 42px;
  padding: 0 14px;
  border-radius: 12px;
  white-space: nowrap;
}
.emoji-popover {
  position: absolute;
  left: 0;
  top: 48px;
  z-index: 30;
  width: min(360px, 92vw);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card), #000 12%);
  border-radius: 14px;
  box-shadow: 0 16px 42px rgba(0, 0, 0, 0.45);
  overflow: visible;
  padding: 12px;
}
.emoji-popover.open {
  display: block;
}
.emoji-grid {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 8px;
}
.emoji-item {
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 6px 0;
  border-radius: 10px;
  transition:
    background 0.12s ease,
    transform 0.12s ease;
  font-family:
    "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji",
    "Twemoji Mozilla", sans-serif;
}
.emoji-item:hover {
  background: color-mix(in oklab, var(--brand) 18%, transparent);
}
@media (max-width: 520px) {
  .emoji-grid {
    grid-template-columns: repeat(8, 1fr);
  }
  .image-preview {
    max-width: 100%;
  }
}

.toggle-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 0;
}

.toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.toggle input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-ui {
  position: relative;
  width: 46px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--border) 80%, transparent);
  background: color-mix(in oklab, var(--bg-card) 68%, black);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.02),
    var(--shadow);
  transition: 180ms ease;
}

.toggle-ui::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: color-mix(in oklab, var(--txt) 8%, var(--bg-page));
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.35);
  transition: 180ms ease;
}

.toggle input:checked + .toggle-ui {
  border-color: color-mix(in oklab, var(--brand) 40%, transparent);
  background: linear-gradient(
    135deg,
    color-mix(in oklab, var(--brand) 80%, #000) 0%,
    color-mix(in oklab, var(--brand) 55%, #000) 100%
  );
}

.toggle input:checked + .toggle-ui::after {
  transform: translateX(20px);
  background: #fff;
}

.toggle input:focus-visible + .toggle-ui {
  outline: 2px solid color-mix(in oklab, var(--focus) 65%, transparent);
  outline-offset: 2px;
}

.toggle-label {
  font-weight: 600;
  color: var(--txt);
}

:root[data-theme="dark"] {
  color-scheme: dark;
}
:root[data-theme="light"] {
  color-scheme: light;
}

@media (prefers-color-scheme: dark) {
  select {
    color-scheme: dark;
  }
}
:root[data-theme="dark"] select {
  color-scheme: dark;
}
:root[data-theme="dark"] select option {
  background: #0b1220;
  color: #e5edf9;
}

@media (prefers-color-scheme: dark) {
  input[type="datetime-local"]::-webkit-calendar-picker-indicator {
    filter: invert(1) brightness(1.15);
    opacity: 0.9;
  }
}
:root[data-theme="dark"]
  input[type="datetime-local"]::-webkit-calendar-picker-indicator {
  filter: invert(1) brightness(1.15);
  opacity: 0.9;
}
:root[data-theme="light"]
  input[type="datetime-local"]::-webkit-calendar-picker-indicator {
  filter: none;
  opacity: 0.75;
}

.bulkbar {
  margin: 10px 0 12px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: color-mix(in oklab, var(--card) 92%, transparent);
}

.bulk-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: nowrap;
}

.bulk-left {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.bulk-right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: nowrap;
  flex: 0 0 auto;
}

.bulk-action-select {
  width: 100%;
  min-width: 0;
  max-width: none;
}

.bulk-apply {
  white-space: nowrap;
}

@media (max-width: 560px) {
  .bulk-actions {
    flex-wrap: wrap;
  }
  .bulk-right {
    width: 100%;
    justify-content: start;
  }
  .bulk-action-select {
    flex: 1 1 280px;
    max-width: none;
  }
}

.bulk-count {
  color: var(--muted);
  font-size: 13px;
}

.th-check,
.td-check {
  width: 44px;
  text-align: center;
}

.bulk-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
}
.bulk-check .chk {
  width: 24px;
  height: 24px;
}

.attach-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 6px;
}

.btn-attach {
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
}

.file-name {
  color: var(--muted);
  font-size: 13px;
}

.emoji-wrap {
  position: relative;
}

.emoji-btn {
  height: 42px;
  padding: 0 14px;
  border-radius: 12px;
  white-space: nowrap;
}

.emoji-popover {
  position: absolute;
  left: 0;
  top: 48px;
  z-index: 30;
  width: min(360px, 92vw);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card), #000 12%);
  border-radius: 14px;
  box-shadow: 0 16px 42px rgba(0, 0, 0, 0.45);
  padding: 12px;
  box-sizing: border-box;
  overflow: visible;
}

.emoji-grid {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 8px;
}

.emoji-item {
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 6px 0;
  border-radius: 10px;
  transition:
    background 0.12s ease,
    transform 0.12s ease;
  font-family:
    "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji",
    "Twemoji Mozilla", sans-serif;
}

.emoji-item:hover {
  background: color-mix(in oklab, var(--brand) 18%, transparent);
}

@media (max-width: 520px) {
  .emoji-grid {
    grid-template-columns: repeat(8, 1fr);
  }
  .emoji-popover {
    position: absolute;
    left: 0;
    top: 48px;
    z-index: 30;
    width: min(360px, 92vw);
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--card), #000 12%);
    border-radius: 14px;
    box-shadow: 0 16px 42px rgba(0, 0, 0, 0.45);
    overflow: visible;
    padding: 12px;
  }
}

:root {
  --emoji-popover-bg: var(--card);
  --emoji-popover-border: var(--border);
}

.emoji-popover {
  background: var(--emoji-popover-bg) !important;
  background-image: none !important;
  opacity: 1 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-color: var(--emoji-popover-border) !important;
}

.emoji-popover {
  background: none !important;
  background-color: var(--bg-card) !important;
  background-image: none !important;
  opacity: 1 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  mix-blend-mode: normal !important;
  isolation: isolate;
}

.emoji-popover {
  width: min(360px, calc(100vw - 24px)) !important;
  overflow: hidden !important;
}

.emoji-grid {
  padding: 16px !important;
  gap: 8px !important;
  grid-template-columns: repeat(8, minmax(0, 1fr)) !important;
}

.emoji-item {
  width: 100% !important;
  aspect-ratio: 1 / 1;
  padding: 0 !important;
  line-height: 1 !important;
  font-size: 20px !important;
  border-radius: 10px !important;
}

:root[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator,
:root[data-theme="dark"]
  input[type="datetime-local"]::-webkit-calendar-picker-indicator,
:root[data-theme="dark"] input[type="month"]::-webkit-calendar-picker-indicator,
:root[data-theme="dark"] input[type="time"]::-webkit-calendar-picker-indicator,
:root[data-theme="dark"] input[type="week"]::-webkit-calendar-picker-indicator {
  filter: invert(1) brightness(1.15);
  opacity: 0.9;
}

.attach-row {
  flex-wrap: nowrap;
}
@media (max-width: 520px) {
  .attach-row {
    flex-wrap: wrap;
  }
}

.file-name {
  flex: 1 1 auto;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mono-ellipsis {
  display: block;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.toggle-label {
  line-height: 1.1;
}

.toggle-ui {
  background: color-mix(in oklab, var(--border) 25%, var(--bg-card));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.toggle-ui::after {
  background: #fff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

:root[data-theme="dark"] .toggle-ui {
  background: #0b1220;
  border-color: #334155;
}

:root[data-theme="dark"] .toggle input:not(:checked) + .toggle-ui {
  background: #0b1220;
}

.attach-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.attach-row .file-name {
  flex: 1 1 auto;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (prefers-color-scheme: dark) {
  input[type="date"],
  input[type="datetime-local"],
  input[type="time"] {
    color-scheme: dark;
  }
  input[type="date"]::-webkit-calendar-picker-indicator,
  input[type="datetime-local"]::-webkit-calendar-picker-indicator,
  input[type="time"]::-webkit-calendar-picker-indicator {
    filter: invert(1) brightness(1.25) !important;
    opacity: 0.9;
  }
}
@media (prefers-color-scheme: light) {
  input[type="date"],
  input[type="datetime-local"],
  input[type="time"] {
    color-scheme: light;
  }
}

.toggle-ui::after {
  width: 24px;
  height: 24px;
  top: 50%;
  left: 2px;
  transform: translateY(-50%);
}
.toggle input:checked + .toggle-ui::after {
  transform: translate(22px, -50%);
}

.toggle {
  align-items: center;
}
.toggle-ui {
  width: 46px;
  height: 26px;
  border-radius: 999px;
  position: relative;
  flex: 0 0 auto;
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  transition:
    background 0.18s ease,
    border-color 0.18s ease;
}
.toggle-ui::after {
  width: 22px;
  height: 22px;
  left: 2px;
  top: 50%;
  transform: translateY(-50%);
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
  transition: transform 0.18s ease;
}
.toggle input:checked + .toggle-ui {
  background: var(--accent);
  border-color: color-mix(in oklab, var(--accent), #000 28%);
}
.toggle input:checked + .toggle-ui::after {
  transform: translate(20px, -50%);
}
.toggle input:focus-visible + .toggle-ui {
  outline: 2px solid color-mix(in oklab, var(--accent), #fff 35%);
  outline-offset: 2px;
}

@media (prefers-color-scheme: dark) {
  input[type="date"]::-webkit-calendar-picker-indicator,
  input[type="datetime-local"]::-webkit-calendar-picker-indicator,
  input[type="time"]::-webkit-calendar-picker-indicator {
    filter: invert(1) brightness(1.35) !important;
    opacity: 1 !important;
  }
  input[type="date"],
  input[type="datetime-local"],
  input[type="time"] {
    color-scheme: dark;
  }
}

:root[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator,
:root[data-theme="dark"]
  input[type="datetime-local"]::-webkit-calendar-picker-indicator,
:root[data-theme="dark"] input[type="time"]::-webkit-calendar-picker-indicator {
  filter: invert(1) brightness(1.35) !important;
  opacity: 1 !important;
}

.sidebar, .sidebar *,
.nav, .nav *,
.brand, .brand *,
.section, .section *,
.btn, .btn *,
.actions, .actions *,
.topbar, .topbar *,
.tabs, .tabs *,
.pager, .pager *,
.muted {
  -webkit-user-select: none;
  user-select: none;
}

input, textarea, select,
.input, .textarea, .select {
  -webkit-user-select: text;
  user-select: text;
}

a.btn:visited {
  color: var(--btn-secondary-fg);
}
a.btn.btn-primary:visited {
  color: var(--btn-primary-fg) !important;
}
a.btn.btn-secondary:visited {
  color: var(--btn-secondary-fg);
}

:root {
  --date-icon: url("data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%2024%2024%22%20fill=%22none%22%20stroke=%22%23E5EDF9%22%20stroke-width=%221.8%22%20stroke-linecap=%22round%22%20stroke-linejoin=%22round%22%3E%3Crect%20x=%223%22%20y=%224%22%20width=%2218%22%20height=%2218%22%20rx=%224%22/%3E%3Cpath%20d=%22M16%202v4M8%202v4M3%2010h18%22/%3E%3Cpath%20d=%22M8%2014h.01M12%2014h.01M16%2014h.01M8%2018h.01M12%2018h.01%22/%3E%3C/svg%3E");
  --time-icon: url("data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%2024%2024%22%20fill=%22none%22%20stroke=%22%23E5EDF9%22%20stroke-width=%221.8%22%20stroke-linecap=%22round%22%20stroke-linejoin=%22round%22%3E%3Ccircle%20cx=%2212%22%20cy=%2212%22%20r=%229%22/%3E%3Cpath%20d=%22M12%207v6l3%202%22/%3E%3C/svg%3E");
}
:root[data-theme="light"] {
  --date-icon: url("data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%2024%2024%22%20fill=%22none%22%20stroke=%22%230F172A%22%20stroke-width=%221.8%22%20stroke-linecap=%22round%22%20stroke-linejoin=%22round%22%3E%3Crect%20x=%223%22%20y=%224%22%20width=%2218%22%20height=%2218%22%20rx=%224%22/%3E%3Cpath%20d=%22M16%202v4M8%202v4M3%2010h18%22/%3E%3Cpath%20d=%22M8%2014h.01M12%2014h.01M16%2014h.01M8%2018h.01M12%2018h.01%22/%3E%3C/svg%3E");
  --time-icon: url("data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%2024%2024%22%20fill=%22none%22%20stroke=%22%230F172A%22%20stroke-width=%221.8%22%20stroke-linecap=%22round%22%20stroke-linejoin=%22round%22%3E%3Ccircle%20cx=%2212%22%20cy=%2212%22%20r=%229%22/%3E%3Cpath%20d=%22M12%207v6l3%202%22/%3E%3C/svg%3E");
}
@media (prefers-color-scheme: light) {
  :root:not([data-theme]) {
    --date-icon: url("data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%2024%2024%22%20fill=%22none%22%20stroke=%22%230F172A%22%20stroke-width=%221.8%22%20stroke-linecap=%22round%22%20stroke-linejoin=%22round%22%3E%3Crect%20x=%223%22%20y=%224%22%20width=%2218%22%20height=%2218%22%20rx=%224%22/%3E%3Cpath%20d=%22M16%202v4M8%202v4M3%2010h18%22/%3E%3Cpath%20d=%22M8%2014h.01M12%2014h.01M16%2014h.01M8%2018h.01M12%2018h.01%22/%3E%3C/svg%3E");
    --time-icon: url("data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%2024%2024%22%20fill=%22none%22%20stroke=%22%230F172A%22%20stroke-width=%221.8%22%20stroke-linecap=%22round%22%20stroke-linejoin=%22round%22%3E%3Ccircle%20cx=%2212%22%20cy=%2212%22%20r=%229%22/%3E%3Cpath%20d=%22M12%207v6l3%202%22/%3E%3C/svg%3E");
  }
}

input[type="date"],
input[type="datetime-local"],
input[type="month"],
input[type="week"],
input[type="time"] {
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 18px 18px;
  padding-right: 44px; 
}

input[type="date"],
input[type="datetime-local"],
input[type="month"],
input[type="week"] {
  background-image: var(--date-icon);
}

input[type="time"] {
  background-image: var(--time-icon);
}

input[type="date"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator,
input[type="month"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="week"]::-webkit-calendar-picker-indicator{
  display: none !important;
  -webkit-appearance: none !important;
}

input[type="date"]::-webkit-inner-spin-button,
input[type="datetime-local"]::-webkit-inner-spin-button,
input[type="month"]::-webkit-inner-spin-button,
input[type="time"]::-webkit-inner-spin-button,
input[type="week"]::-webkit-inner-spin-button{
  display: none;
}

input[type="date"]::-moz-calendar-picker-indicator,
input[type="datetime-local"]::-moz-calendar-picker-indicator,
input[type="month"]::-moz-calendar-picker-indicator,
input[type="time"]::-moz-calendar-picker-indicator,
input[type="week"]::-moz-calendar-picker-indicator{
  opacity: 0 !important;
}