@font-face {
  font-family: "Google Sans";
  src: url("/static/fonts/google-sans/GoogleSans-VariableFont_GRAD,opsz,wght.ttf") format("truetype");
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
}

@font-face {
  font-family: "Google Sans";
  src: url("/static/fonts/google-sans/GoogleSans-Italic-VariableFont_GRAD,opsz,wght.ttf") format("truetype");
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
}

:root {
  --red: #c1272d;
  --ink: #171717;
  --muted: #6b7280;
  --line: #e5e7eb;
  --admin-bg: #f4f6f8;
  --admin-surface: #ffffff;
  --admin-sidebar: #10131a;
  --admin-sidebar-soft: #181d27;
  --admin-text: #161a22;
  --admin-muted: #677084;
  --admin-line: #e2e7ef;
  --admin-shadow: 0 20px 60px rgba(16, 19, 26, .08);
  --font-admin: "Google Sans", Arial, sans-serif;
  font-family: "Open Sans", Arial, sans-serif;
}

* { box-sizing: border-box; }
body { margin: 0; color: var(--ink); background: #fff; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.site-header {
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 32px;
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,.9);
  position: sticky;
  top: 0;
  z-index: 20;
  backdrop-filter: blur(12px);
}
.brand { font-weight: 800; color: var(--red); }
nav { display: flex; gap: 20px; color: #374151; }

.hero {
  min-height: calc(100vh - 72px);
  display: grid;
  align-items: center;
  padding: 48px 8vw;
  background: linear-gradient(135deg, #fff 0%, #fff5f5 55%, #f3f4f6 100%);
}
.hero-copy { max-width: 760px; }
.eyebrow { color: var(--red); text-transform: uppercase; font-size: 12px; letter-spacing: .08em; font-weight: 800; }
h1 { font-size: clamp(40px, 6vw, 88px); line-height: 1; margin: 12px 0 18px; }
h2 { font-size: 22px; line-height: 1.2; }
p { line-height: 1.7; color: #4b5563; }
.actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 8px;
  border: 1px solid var(--red);
  background: var(--red);
  color: white;
  font-weight: 700;
  cursor: pointer;
}
.button.secondary { background: white; color: var(--red); }
.page, .article { max-width: 1120px; margin: 0 auto; padding: 56px 24px; }
.grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; }
.card { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; padding: 18px; background: white; }
.card img { margin: -18px -18px 16px; width: calc(100% + 36px); aspect-ratio: 16/9; object-fit: cover; }
.cover { width: 100%; aspect-ratio: 16/9; object-fit: cover; border-radius: 8px; margin: 24px 0; }
.summary { font-size: 18px; }
.content { white-space: pre-wrap; line-height: 1.8; }
.rich-content {
  white-space: normal;
  color: #263142;
  font-size: 16px;
  line-height: 1.78;
}

.rich-content > *:first-child { margin-top: 0; }
.rich-content > *:last-child { margin-bottom: 0; }
.rich-content p {
  margin: 0 0 18px;
  color: inherit;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.78;
}
.rich-content p + p { margin-top: 4px; }
.rich-content p + :where(ul, ol, blockquote, .tableWrapper, figure, img),
.rich-content :where(ul, ol, blockquote, .tableWrapper, figure, img) + p {
  margin-top: 18px;
}
.rich-content h2,
.rich-content h3,
.rich-content h4,
.rich-content h5,
.rich-content h6 {
  margin: 36px 0 12px;
  padding-bottom: 6px;
  color: #111827;
  line-height: 1.22;
  font-weight: 700;
}
.rich-content :where(h2, h3, h4, h5, h6) + :where(p, ul, ol, blockquote, .tableWrapper, figure, img) {
  margin-top: 0;
  padding-top: 10px;
}
.rich-content :where(h2, h3) + :where(p, ul, ol, blockquote, .tableWrapper, figure, img) {
  padding-top: 14px;
}
.rich-content :where(h2, h3, h4, h5, h6) + :where(h2, h3, h4, h5, h6) {
  margin-top: 22px;
}
.rich-content p + h2,
.rich-content ul + h2,
.rich-content ol + h2,
.rich-content blockquote + h2,
.rich-content .tableWrapper + h2,
.rich-content figure + h2,
.rich-content img + h2 {
  margin-top: 42px;
}
.rich-content p + h3,
.rich-content ul + h3,
.rich-content ol + h3,
.rich-content blockquote + h3,
.rich-content .tableWrapper + h3,
.rich-content figure + h3,
.rich-content img + h3,
.rich-content p + h4,
.rich-content ul + h4,
.rich-content ol + h4,
.rich-content blockquote + h4,
.rich-content .tableWrapper + h4,
.rich-content figure + h4,
.rich-content img + h4 {
  margin-top: 36px;
}
.rich-content p + h5,
.rich-content ul + h5,
.rich-content ol + h5,
.rich-content blockquote + h5,
.rich-content .tableWrapper + h5,
.rich-content figure + h5,
.rich-content img + h5,
.rich-content p + h6,
.rich-content ul + h6,
.rich-content ol + h6,
.rich-content blockquote + h6,
.rich-content .tableWrapper + h6,
.rich-content figure + h6,
.rich-content img + h6 {
  margin-top: 36px;
}
.rich-content h2 { font-size: 30px; }
.rich-content h3 { font-size: 25px; }
.rich-content h4 { font-size: 21px; }
.rich-content h5 { font-size: 18px; }
.rich-content h6 {
  color: #4b5563;
  font-size: 15px;
  font-weight: 700;
  text-transform: uppercase;
}
.rich-content strong { font-weight: 700; color: #111827; }
.rich-content a { color: var(--red); text-decoration: underline; text-underline-offset: 3px; }
.rich-content ul,
.rich-content ol { margin: 0 0 18px; padding-left: 26px; }
.rich-content li { margin: 7px 0; }
.rich-content blockquote {
  margin: 24px 0;
  padding: 14px 18px;
  border-left: 4px solid var(--red);
  border-radius: 0 8px 8px 0;
  background: #fff7f7;
  color: #374151;
}
.rich-content blockquote p { margin: 0; }
.rich-content figure { margin: 28px 0; }
.rich-content img {
  width: auto;
  max-width: min(100%, 800px);
  height: auto;
  margin: 28px auto;
  border-radius: 8px;
}
.rich-content p + img,
.rich-content img + p,
.rich-content p + figure,
.rich-content figure + p {
  margin-top: 28px;
}
.rich-content td img,
.rich-content th img {
  max-width: 100%;
  margin: 8px auto;
}
.rich-content figcaption {
  margin-top: -12px;
  color: var(--muted);
  font-size: 13px;
  text-align: center;
}
.rich-content .tableWrapper {
  width: 100%;
  margin: 22px 0;
  overflow-x: auto;
}
.rich-content table {
  width: 100%;
  min-width: 640px;
  border-collapse: collapse;
  border: 1px solid var(--line);
  background: #fff;
}
.rich-content th,
.rich-content td {
  padding: 11px 12px;
  border: 1px solid var(--line);
  vertical-align: top;
}
.rich-content th {
  background: #f7f8fb;
  color: #111827;
  font-weight: 700;
}

.admin-shell { min-height: 100vh; display: grid; grid-template-columns: 260px 1fr; background: #f8fafc; }
.login-shell { display: flex; align-items: center; justify-content: center; padding: 24px; }
.login-card { width: 100%; max-width: 420px; padding: 28px; background: white; border: 1px solid var(--line); border-radius: 8px; }
label { display: grid; gap: 8px; margin: 16px 0; font-weight: 700; }
input { width: 100%; height: 44px; padding: 0 12px; border: 1px solid var(--line); border-radius: 8px; font: inherit; }
.alert { border: 1px solid #fecaca; background: #fff1f2; color: #b91c1c; padding: 10px 12px; border-radius: 8px; }
.alert.success { border-color: #bbf7d0; background: #f0fdf4; color: #166534; }
.cms-toast-region {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 10000;
  display: grid;
  gap: 10px;
  width: min(360px, calc(100vw - 32px));
  pointer-events: none;
}
.cms-toast {
  padding: 12px 14px;
  border: 1px solid #bbf7d0;
  border-radius: 8px;
  background: #f0fdf4;
  color: #166534;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .16);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
  animation: cmsToastIn .18s ease-out;
}
.cms-toast.is-error {
  border-color: #fecaca;
  background: #fff1f2;
  color: #b91c1c;
}
.cms-toast.is-leaving {
  animation: cmsToastOut .18s ease-in forwards;
}
@keyframes cmsToastIn {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes cmsToastOut {
  to { opacity: 0; transform: translateY(-8px); }
}
.admin-nav { background: #111827; color: white; padding: 24px; display: flex; flex-direction: column; gap: 14px; }
.admin-nav a, .admin-nav button { color: white; background: transparent; border: 0; text-align: left; font: inherit; cursor: pointer; }
.admin-nav a.is-active { color: #bfdbfe; font-weight: 700; }
.admin-main { padding: 32px; }
.session-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  padding: 12px 14px;
  border: 1px solid #fde68a;
  border-radius: 8px;
  background: #fffbeb;
  color: #92400e;
}
.session-banner[hidden] { display: none; }
.session-banner strong,
.session-banner span { color: inherit; }
.session-banner.is-expired {
  border-color: #fecaca;
  background: #fff1f2;
  color: #b91c1c;
}
.session-dialog p {
  color: #374151;
}
.metrics { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.metrics div { background: white; border: 1px solid var(--line); border-radius: 8px; padding: 20px; }
.metrics strong { display: block; font-size: 36px; color: var(--red); }
.metrics span { color: var(--muted); }
.admin-form {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
  background: white;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  margin: 18px 0;
}
.inline-check { display: flex; align-items: center; gap: 8px; }
.inline-check input { width: auto; height: auto; }
.table-wrap { overflow-x: auto; background: white; border: 1px solid var(--line); border-radius: 8px; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 920px; }
.admin-table th, .admin-table td { padding: 10px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.admin-table th { font-size: 12px; text-transform: uppercase; color: var(--muted); background: #f9fafb; }
.row-form { display: grid; gap: 8px; grid-template-columns: repeat(2, minmax(140px, 1fr)); }
.row-actions { display: flex; gap: 8px; align-items: flex-start; }
.inline-form { display: inline; }
.button.small { min-height: 36px; padding: 0 12px; font-size: 13px; }
.button.icon-only {
  width: 40px;
  padding: 0;
  justify-content: center;
}
.button.icon-only svg { width: 16px; height: 16px; }
.button.danger { border-color: #dc2626; background: #dc2626; }
.button.secondary { background: white; color: var(--red); }
.button:disabled { opacity: .55; cursor: not-allowed; }
.page-title-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.category-workspace {
  display: grid;
  gap: 16px;
}
.category-tree-preview {
  background: white;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 18px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .04);
}
.category-preview-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}
.category-preview-head h2 {
  margin: 2px 0 0;
  font-size: 22px;
}
.category-preview-count {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: #fff1f2;
  color: var(--red);
  font-weight: 800;
  white-space: nowrap;
}
.category-tree-map {
  display: grid;
  gap: 10px;
  position: relative;
}
.category-tree-node {
  --level: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  width: min(760px, calc(100% - (var(--level) * 34px)));
  margin-left: calc(var(--level) * 34px);
  padding: 12px 14px;
  border: 1px solid #e5e7eb;
  border-radius: 9px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(15, 23, 42, .04);
}
.category-tree-node[data-level="0"] {
  border-color: rgba(200, 0, 0, .22);
  background: linear-gradient(180deg, #fffafa, #fff);
}
.category-node-depth {
  display: inline-grid;
  place-items: center;
  flex: 0 0 30px;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #f3f4f6;
  color: #6b7280;
  font-size: 12px;
  font-weight: 800;
}
.category-node-depth svg {
  width: 16px;
  height: 16px;
}
.category-tree-node[data-level="0"] .category-node-depth {
  background: var(--red);
  color: white;
}
.category-node-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.category-node-copy strong {
  color: #111827;
  font-size: 15px;
}
.category-node-copy span {
  color: var(--muted);
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.menu-manager {
  display: grid;
  gap: 18px;
  min-width: 0;
}
.menu-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.menu-preview-card {
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: white;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .04);
}
.menu-preview-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}
.menu-preview-head h2 {
  margin: 2px 0 0;
  font-size: 22px;
}
.menu-preview-head span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 11px;
  border-radius: 999px;
  background: #fff1f2;
  color: var(--red);
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
}
.menu-preview-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.menu-preview-links a {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 12px;
  border: 1px solid #fee2e2;
  border-radius: 999px;
  background: #fffafa;
  color: var(--red);
  font-weight: 800;
  text-decoration: none;
}
.menu-location-section {
  display: grid;
  gap: 14px;
  min-width: 0;
}
.menu-location-section .table-wrap {
  min-width: 0;
}
.settings-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.settings-section-head h2 {
  margin: 2px 0 0;
  font-size: 22px;
}
.menu-create-form {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 0;
}
.menu-row-form {
  grid-template-columns: repeat(2, minmax(140px, 1fr));
}
.menu-table {
  min-width: 980px;
  table-layout: fixed;
}
.menu-table input,
.menu-table select {
  min-width: 0;
}
.menu-table .row-actions {
  width: 90px;
}
.tree-workspace,
.folder-tree-panel {
  min-width: 0;
}
.folder-tree-panel {
  display: grid;
  gap: 16px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .04);
}
.tree-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.tree-panel-head h2 {
  margin: 2px 0 0;
  font-size: 22px;
}
.tree-head-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}
.tree-count {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: #fff1f2;
  color: var(--red);
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
}
.folder-tree {
  position: relative;
  display: grid;
  gap: 30px;
  min-width: 0;
  padding: 16px 0 8px;
  overflow-x: auto;
  overflow-y: visible;
  scrollbar-gutter: stable;
}
.folder-tree::before {
  display: none;
}
.folder-tree-level {
  --level: 0;
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  gap: 14px;
  align-items: start;
  min-width: 0;
  width: max-content;
  min-width: 100%;
  overflow: visible;
  padding-bottom: 4px;
}
.folder-tree-level:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -16px;
  left: 12%;
  right: 12%;
  height: 1px;
  background: rgba(199, 0, 0, .22);
}
.folder-tree-level:not(:first-child)::after {
  content: "";
  position: absolute;
  top: -30px;
  left: 50%;
  width: 1px;
  height: 14px;
  background: rgba(199, 0, 0, .24);
}
.folder-tree-node {
  --level: 0;
  position: relative;
  flex: 0 0 220px;
  width: auto;
  min-width: 0;
  margin-left: 0;
  padding-left: 0;
}
.folder-tree-level:has(.folder-tree-node:nth-child(5)) .folder-tree-node {
  flex-basis: 196px;
}
.folder-tree-level:has(.folder-tree-node:nth-child(7)) .folder-tree-node {
  flex-basis: 150px;
}
.folder-tree-level:has(.folder-tree-node:nth-child(9)) .folder-tree-node {
  flex-basis: 128px;
}
.folder-tree-level:has(.folder-tree-node:nth-child(13)) .folder-tree-node {
  flex-basis: 108px;
}
.folder-tree-node::before {
  content: "";
  position: absolute;
  top: -16px;
  left: 50%;
  width: 1px;
  height: 16px;
  background: rgba(199, 0, 0, .24);
}
.folder-tree-level[data-level="0"] .folder-tree-node::before {
  display: none;
}
.folder-node-card {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 52px;
  padding: 9px 10px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(15, 23, 42, .04);
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
}
.folder-node-card:hover,
.folder-node-card:focus {
  border-color: rgba(199, 0, 0, .32);
  box-shadow: 0 14px 34px rgba(199, 0, 0, .10);
  outline: none;
}
.folder-tree-node[data-level="0"] > .folder-node-card {
  border-color: rgba(199, 0, 0, .20);
  background: linear-gradient(180deg, #fffafa, #fff);
}
.folder-node-icon {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 10px;
  background: #fff1f2;
  color: var(--red);
}
.folder-node-icon svg {
  width: 16px;
  height: 16px;
}
.folder-node-copy {
  display: grid;
  gap: 3px;
  min-width: 0;
}
.folder-node-copy strong {
  overflow: hidden;
  color: #111827;
  font-size: 14px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.folder-node-copy small {
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.folder-node-status {
  display: inline-flex;
  align-items: center;
  grid-column: 2;
  justify-self: start;
  min-height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  background: #f3f4f6;
  color: #6b7280;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}
.folder-node-status.is-on {
  background: #ecfdf5;
  color: #047857;
}
.folder-node-status.is-off {
  background: #fff7ed;
  color: #c2410c;
}
.folder-node-edit {
  position: absolute;
  right: 8px;
  top: 8px;
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid rgba(199, 0, 0, .16);
  border-radius: 8px;
  background: #fff;
  color: var(--red);
  opacity: 0;
  transform: translateY(-2px);
  transition: opacity .16s ease, transform .16s ease;
}
.folder-node-edit svg {
  width: 15px;
  height: 15px;
}
.folder-tree-node:hover .folder-node-edit,
.folder-tree-node:focus-within .folder-node-edit,
.folder-node-card:hover .folder-node-edit,
.folder-node-card:focus .folder-node-edit {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
.tree-edit-popover {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 30;
  display: none;
  width: min(360px, calc(100vw - 40px));
  padding: 14px;
  border: 1px solid rgba(199, 0, 0, .18);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 24px 70px rgba(15, 23, 42, .18);
}
.folder-tree-node.is-editing {
  z-index: 25;
}
.folder-tree-node.is-editing > .tree-edit-popover {
  display: block;
}
.tree-edit-popover::before {
  content: "";
  position: absolute;
  top: -8px;
  right: 26px;
  width: 14px;
  height: 14px;
  border-left: 1px solid rgba(199, 0, 0, .18);
  border-top: 1px solid rgba(199, 0, 0, .18);
  background: #fff;
  transform: rotate(45deg);
}
.tree-edit-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.tree-edit-form label {
  display: grid;
  gap: 6px;
  min-width: 0;
  color: #111827;
  font-size: 12px;
  font-weight: 800;
}
.tree-edit-form label:nth-child(3),
.tree-edit-form label:nth-child(4),
.tree-edit-form label:nth-child(5),
.tree-edit-form label:nth-child(6) {
  grid-column: 1 / -1;
}
.tree-edit-form .inline-check {
  display: flex;
  align-items: center;
  gap: 8px;
}
.tree-popover-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
}
.tree-popover-actions form {
  margin: 0;
}
.filter-form, .batch-bar {
  display: flex;
  align-items: end;
  gap: 12px;
  flex-wrap: wrap;
  background: white;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  margin: 16px 0;
}
select, textarea {
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font: inherit;
  background: white;
}
textarea { min-height: 96px; resize: vertical; }
.large-text { min-height: 280px; font-family: ui-monospace, SFMono-Regular, Consolas, monospace; }
.muted { color: var(--muted); font-size: 13px; margin-top: 4px; }
.status-pill { display: inline-flex; border-radius: 999px; background: #f3f4f6; padding: 4px 8px; font-size: 12px; font-weight: 700; }
.table-foot { padding: 0 14px 14px; }
.post-form { display: grid; gap: 18px; }
.post-editor {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 18px;
  align-items: start;
  padding-bottom: 24px;
}
.editor-main,
.editor-side {
  display: grid;
  gap: 18px;
}
.editor-side {
  position: sticky;
  top: 18px;
}
.compact-panel {
  grid-template-columns: 1fr;
}
.compact-panel label,
.compact-panel .sticky-actions,
.compact-panel .author-auto-card,
.compact-panel .author-override-panel {
  grid-column: 1 / -1;
}
.editor-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 8px;
}
.editor-toolbar button {
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f9fafb;
  cursor: pointer;
  font-weight: 700;
}
.rich-textarea {
  min-height: 420px;
}

.richtext-box {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
}

.rich-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px;
  border-bottom: 1px solid var(--admin-line);
  background: #f7f8fb;
}

.rich-button {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid #d8dee8;
  border-radius: 8px;
  background: #fff;
  color: var(--admin-text);
  cursor: pointer;
}

.rich-button:hover,
.rich-button:focus {
  border-color: #c8d0dc;
  background: #eef2f7;
  outline: 0;
}

.rich-button.is-active,
.rich-button[aria-pressed="true"] {
  border-color: rgba(193, 39, 45, .46);
  background: #fff1f2;
  color: var(--red);
}

.rich-button svg {
  width: 17px;
  height: 17px;
}

.rich-toolbar-divider {
  width: 1px;
  min-height: 34px;
  margin: 0 2px;
  background: #e2e7ef;
}

.rich-editor-frame {
  min-width: 0;
  max-width: 100%;
  overflow: auto;
  background: #fff;
}

.rich-editor-content {
  min-height: 520px;
  max-height: 70vh;
  padding: 22px;
  outline: 0;
}

.rich-editor-content .is-empty::before {
  content: attr(data-placeholder);
  float: left;
  height: 0;
  color: #a5adba;
  pointer-events: none;
}

.rich-editor-content img.ProseMirror-selectednode {
  outline: 2px solid rgba(100, 116, 139, .34);
}

.rich-editor-content .selectedCell::after {
  background: rgba(100, 116, 139, .14);
}

.rich-editor-content .column-resize-handle {
  position: absolute;
  right: -2px;
  top: 0;
  bottom: -2px;
  width: 4px;
  background: rgba(100, 116, 139, .38);
  pointer-events: none;
}

.rich-footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 12px;
  border-top: 1px solid var(--admin-line);
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 600;
}

.rich-source-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  min-height: 0;
  padding: 0;
  border: 0;
  opacity: 0;
  pointer-events: none;
}

.rich-image-dialog {
  width: min(640px, calc(100vw - 28px));
}

.rich-image-form {
  display: grid;
  gap: 12px;
}

.rich-image-form label {
  display: grid;
  gap: 6px;
}

.rich-image-size-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.media-picker-dialog {
  width: min(1320px, calc(100vw - 24px));
  max-height: min(900px, calc(100vh - 24px));
}

.media-picker-panel {
  display: grid;
  gap: 16px;
}

.media-picker-tools {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.media-picker-form,
.media-picker-folder-create,
.media-picker-filter,
.media-picker-card-actions {
  display: grid;
  gap: 8px;
}

.media-picker-form {
  grid-template-columns: minmax(0, 1fr) minmax(160px, 210px) auto;
  align-items: end;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
}

.media-picker-form label,
.media-content .admin-form.compact label {
  min-width: 0;
}

.media-picker-form .button,
.media-content .admin-form.compact .button {
  align-self: end;
  min-height: 44px;
  white-space: nowrap;
}

.media-file-field {
  display: grid;
  gap: 7px;
}

.media-file-control {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  min-height: 44px;
  padding: 5px;
  overflow: hidden;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #f8fafc;
}

.media-file-input {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

.media-file-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 7px;
  background: var(--red);
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.media-file-button svg {
  width: 15px;
  height: 15px;
}

.media-file-name {
  min-width: 0;
  overflow: hidden;
  color: var(--admin-muted);
  font-size: 13px;
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.media-file-control:focus-within {
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(199, 0, 0, .10);
}

.media-upload-progress {
  grid-column: 1 / -1;
  display: grid;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid rgba(199, 0, 0, .16);
  border-radius: 8px;
  background: #fff7f7;
}

.media-upload-progress[hidden] {
  display: none;
}

.media-upload-progress-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--admin-text);
  font-size: 13px;
}

.media-upload-progress-row span {
  color: var(--red);
  font-weight: 900;
}

.media-upload-progress progress {
  width: 100%;
  height: 9px;
  overflow: hidden;
  border: 0;
  border-radius: 999px;
  background: #ffe4e6;
}

.media-upload-progress progress::-webkit-progress-bar {
  background: #ffe4e6;
}

.media-upload-progress progress::-webkit-progress-value {
  background: linear-gradient(90deg, var(--red), #ef4444);
}

.media-upload-progress progress::-moz-progress-bar {
  background: linear-gradient(90deg, var(--red), #ef4444);
}

.media-upload-progress.is-error {
  border-color: rgba(185, 28, 28, .28);
  background: #fff1f2;
}

.media-upload-progress.is-error .media-upload-progress-row strong {
  color: #b91c1c;
}

.media-upload-complete {
  margin: 0 0 12px;
  padding: 11px 14px;
  border: 1px solid rgba(16, 185, 129, .22);
  border-radius: 8px;
  color: #047857;
  background: #ecfdf5;
  font-size: 13px;
  font-weight: 800;
}

.media-secondary-tool,
.media-picker-import,
.media-folder-create-shell {
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
}

.media-secondary-tool > summary,
.media-picker-import > summary,
.media-folder-create-shell > summary {
  min-height: 42px;
  padding: 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  color: var(--admin-text);
  font-size: 13px;
  font-weight: 800;
}

.media-secondary-tool > summary svg,
.media-picker-import > summary svg,
.media-folder-create-shell > summary svg {
  width: 16px;
  height: 16px;
  color: var(--red);
}

.media-secondary-tool .admin-form.compact,
.media-picker-import .media-picker-form {
  margin: 0;
  border: 0;
  border-top: 1px solid var(--admin-line);
  border-radius: 0 0 8px 8px;
}

.media-folder-create-shell {
  margin-top: 12px;
}

.media-folder-create-shell .media-folder-create {
  margin: 0;
  border: 0;
  border-top: 1px solid var(--admin-line);
  border-radius: 0 0 8px 8px;
}

.media-picker-manage {
  display: grid;
  grid-template-columns: minmax(190px, 240px) minmax(0, 1fr);
  gap: 16px;
  min-height: 0;
}

.media-picker-folders,
.media-picker-library {
  min-width: 0;
}

.media-picker-folder-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  max-height: 520px;
  overflow: auto;
}

.media-picker-folder-filter,
.media-picker-folder-node {
  width: 100%;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
}

.media-picker-folder-filter {
  padding: 9px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  text-align: left;
  font-weight: 700;
  color: var(--admin-text);
  cursor: pointer;
}

.media-picker-folder-filter small {
  color: var(--admin-muted);
  font-weight: 800;
}

.media-picker-folder-filter.is-active {
  border-color: rgba(193, 39, 45, .38);
  color: var(--red);
  background: #fff1f2;
}

.media-picker-folder-node summary {
  cursor: pointer;
  padding: 9px 10px;
  font-weight: 700;
}

.media-picker-folder-node small {
  color: var(--admin-muted);
  font-weight: 600;
}

.media-picker-folder-actions {
  display: grid;
  gap: 8px;
  padding: 0 10px 10px;
}

.media-picker-filter {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  margin-bottom: 12px;
}

.media-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 12px;
  max-height: 560px;
  overflow: auto;
}

.media-picker-card {
  min-width: 0;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}

.media-picker-thumb {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  padding: 0;
  border: 0;
  background: #f1f5f9;
  cursor: pointer;
}

.media-picker-thumb:hover,
.media-picker-thumb:focus-visible {
  outline: 3px solid rgba(199, 0, 0, .16);
  outline-offset: -3px;
}

.media-picker-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-picker-card-body {
  display: grid;
  gap: 5px;
  padding: 9px 10px 10px;
}

.media-picker-card-body strong {
  overflow-wrap: anywhere;
  font-size: 13px;
}

.media-picker-card-body small {
  color: var(--admin-muted);
  font-weight: 600;
}

@media (min-width: 1180px) and (orientation: landscape) {
  .media-picker-tools {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 989px), (orientation: portrait) {
  .menu-preview-grid,
  .menu-create-form,
  .media-picker-tools,
  .media-picker-form,
  .media-content .admin-form.compact,
  .media-picker-manage,
  .media-picker-filter,
  .rich-image-size-row {
    grid-template-columns: 1fr;
  }

  .media-picker-form .button,
  .media-content .admin-form.compact .button {
    width: 100%;
  }

  .media-file-control {
    grid-template-columns: 1fr;
  }

  .media-file-button {
    width: 100%;
  }

  .menu-preview-head,
  .settings-section-head,
  .tree-panel-head,
  .tree-head-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .folder-tree {
    gap: 24px;
    padding-left: 0;
  }

  .folder-tree-level {
    gap: 10px;
  }

  .folder-tree-level:not(:first-child)::before {
    left: 18%;
    right: 18%;
  }

  .folder-node-card {
    grid-template-columns: 34px minmax(0, 1fr);
  }

  .folder-node-status {
    grid-column: 2;
    justify-self: start;
  }

  .tree-edit-popover {
    position: static;
    width: auto;
    margin-top: 8px;
  }

  .tree-edit-popover::before {
    display: none;
  }

  .tree-edit-form {
    grid-template-columns: 1fr;
  }

  .tree-popover-actions {
    justify-content: stretch;
  }

  .tree-popover-actions .button,
  .tree-popover-actions form {
    width: 100%;
  }

  .tree-popover-actions .button {
    justify-content: center;
  }

  .media-picker-dialog,
  .rich-image-dialog {
    width: calc(100vw - 20px);
  }
}
.editor-actions {
  grid-column: 1 / -1;
  display: flex;
  gap: 10px;
  align-items: center;
}

.post-editor > .editor-actions {
  position: static;
  padding: 14px 0 0;
  background: transparent;
}
.seo-card-preview {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #f9fafb;
}
.seo-card-preview strong {
  color: #1d4ed8;
  overflow-wrap: anywhere;
}
.seo-card-preview span {
  color: #047857;
  font-size: 13px;
  overflow-wrap: anywhere;
}
.seo-card-preview p {
  margin: 0;
  color: #374151;
  font-size: 13px;
}

[x-cloak] {
  display: none !important;
}

.section-head {
  grid-column: 1 / -1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.section-head h2 {
  margin-bottom: 4px;
}

.section-head p {
  margin: 0;
}

.tab-strip {
  display: inline-flex;
  flex: 0 0 auto;
  gap: 6px;
  padding: 5px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #f7f8fb;
}

.tab-button {
  min-height: 34px;
  padding: 0 12px;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: var(--admin-muted);
  font: 600 13px/1 var(--font-admin);
  cursor: pointer;
  white-space: nowrap;
}

.tab-button:hover,
.tab-button.is-active {
  background: #fff;
  color: var(--admin-text);
  box-shadow: 0 6px 16px rgba(16, 19, 26, .08);
}

.post-edit-tabs .tab-panel {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.post-edit-tabs label:has(textarea),
.post-edit-tabs label:has(.image-url-field),
.post-edit-tabs .seo-card-preview {
  grid-column: 1 / -1;
}

.image-url-field {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.image-url-preview {
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 150px;
  overflow: hidden;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #f7f8fb;
  color: var(--admin-muted);
  font-size: 13px;
  font-weight: 600;
}

.image-url-preview img {
  width: 100%;
  height: 100%;
  max-height: 220px;
  object-fit: contain;
  background: #fff;
}

.image-url-preview.is-empty {
  border-style: dashed;
}

.image-url-field.is-avatar .image-url-preview,
.image-url-field.is-icon .image-url-preview {
  width: 112px;
  min-height: 112px;
}

.image-url-field.is-avatar .image-url-preview img,
.image-url-field.is-icon .image-url-preview img {
  object-fit: contain;
}

.author-auto-card {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #f9fafb;
}

.author-avatar-preview {
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  overflow: hidden;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
  color: var(--red);
  font-size: 12px;
  font-weight: 700;
  text-align: center;
}

.author-avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.author-auto-card h3 {
  margin: 0 0 3px;
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.author-auto-card strong {
  display: block;
  overflow: hidden;
  color: var(--admin-text);
  font-size: 15px;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.author-auto-card p {
  margin: 4px 0 0;
  line-height: 1.45;
}

.author-override-panel {
  display: grid;
  gap: 12px;
  min-width: 0;
  border: 1px dashed var(--admin-line);
  border-radius: 8px;
  padding: 10px 12px;
  background: #fff;
}

.author-override-panel summary {
  cursor: pointer;
  color: var(--admin-muted);
  font-size: 13px;
  font-weight: 600;
}

.author-override-panel[open] summary {
  margin-bottom: 10px;
  color: var(--admin-text);
}
.form-section {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  background: white;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
}
.form-section h2 { grid-column: 1 / -1; margin: 0; }
.form-section label:has(.large-text), .form-section label:has(textarea) { grid-column: 1 / -1; }
.sticky-actions {
  position: sticky;
  bottom: 0;
  padding: 14px 0;
  background: linear-gradient(180deg, rgba(248,250,252,0), #f8fafc 35%);
}
.media-tools {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin: 18px 0;
}
.admin-form.compact {
  grid-template-columns: minmax(0, 1fr) minmax(160px, 220px) auto;
  margin: 0;
}

.media-content .admin-form.compact {
  align-items: end;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
}
.folder-panel {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 16px;
  align-items: start;
  margin: 16px 0;
}
.folder-create,
.folder-row {
  display: flex;
  gap: 8px;
  align-items: center;
  background: white;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
}
.folder-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.media-grid-wrap {
  background: white;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
}
.media-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.media-picker-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.media-picker-item {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: white;
  padding: 10px;
  cursor: pointer;
  text-align: left;
  font: inherit;
}
.media-picker-item img,
.media-picker-item .file-tile {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 6px;
}
.media-picker-item strong {
  font-size: 12px;
  overflow-wrap: anywhere;
}
.media-card {
  position: relative;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}

.media-card .media-select {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 2;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(15, 23, 42, .12);
  border-radius: 8px;
  background: rgba(255, 255, 255, .92);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .12);
}

.media-card .media-select input {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--red);
}
.media-card img,
.file-tile {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  background: #f3f4f6;
}
.file-tile {
  display: grid;
  place-items: center;
  padding: 12px;
  color: var(--muted);
  font-size: 12px;
  text-align: center;
}
.media-meta {
  display: grid;
  gap: 4px;
  padding: 10px;
  font-size: 12px;
}
.media-meta strong {
  overflow-wrap: anywhere;
}
.media-meta span {
  color: var(--muted);
}
.media-actions {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  padding: 0 10px 10px;
}
.empty-state {
  grid-column: 1 / -1;
  margin: 0;
  padding: 24px;
  text-align: center;
}
.metric-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: white;
  padding: 10px 14px;
}
.metric-chip strong { color: var(--red); font-size: 24px; }
.metric-chip span { color: var(--muted); font-size: 13px; font-weight: 700; }
.submissions-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
.submissions-table-wrap .admin-table { min-width: 980px; }
.type-pill {
  display: inline-flex;
  border-radius: 8px;
  background: #eef2ff;
  color: #3730a3;
  padding: 4px 8px;
  font-size: 12px;
  font-weight: 700;
}
.status-pill.status-new { background: #fff7ed; color: #c2410c; }
.status-pill.status-read { background: #eef2ff; color: #3730a3; }
.status-pill.status-replied { background: #ecfdf5; color: #047857; }
.status-pill.status-neutral { background: #f3f4f6; color: #374151; }
.pagination-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  color: var(--muted);
  font-size: 13px;
}
.submission-detail-panel {
  background: white;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
}
.submission-detail-panel.empty-state,
.submission-detail-panel.is-placeholder {
  display: none;
}
.detail-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  border-bottom: 1px solid var(--line);
  padding-bottom: 12px;
}
.detail-head h2 {
  margin: 4px 0;
  overflow-wrap: anywhere;
}
.detail-list {
  display: grid;
  gap: 10px;
  margin: 14px 0;
}
.detail-list div {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 10px;
}
.detail-list dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}
.detail-list dd {
  margin: 0;
  overflow-wrap: anywhere;
}
.detail-file-link { width: 100%; margin: 4px 0 14px; }
.payload-panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f9fafb;
  padding: 12px;
}
.payload-panel h3 {
  margin: 0 0 8px;
  font-size: 14px;
}
.payload-panel pre {
  margin: 0;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  font: 13px/1.6 ui-monospace, SFMono-Regular, Consolas, monospace;
  color: #374151;
}
.status-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.settings-section {
  margin-top: 18px;
}
.settings-section h2 {
  margin-bottom: 8px;
}
.settings-status {
  margin-top: 14px;
}
.feature-lock-banner {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 18px 20px;
  margin: 18px 0;
  border: 1px solid #f4c7c7;
  border-radius: 14px;
  background: linear-gradient(135deg, #fff7f7, #ffffff);
  box-shadow: 0 16px 40px rgba(200, 0, 0, 0.08);
}
.feature-lock-banner h2 {
  margin: 0 0 6px;
  font-size: 18px;
}
.feature-lock-banner p {
  margin: 0;
  color: #5f6b7a;
  line-height: 1.6;
}
.feature-locked-fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
}
.feature-locked-fieldset:disabled {
  opacity: 0.72;
}
.settings-scripts {
  display: grid;
  gap: 14px;
}
.settings-scripts-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.settings-scripts-toolbar h3 {
  margin: 0 0 4px;
  color: var(--text);
  font-size: 17px;
  font-weight: 700;
}
.settings-scripts-toolbar p {
  margin: 0;
}
.script-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.script-list-compact {
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}
.script-summary-card {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.script-summary-main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.script-summary-main h4 {
  margin: 0 0 4px;
  color: var(--text);
  font-size: 15px;
  font-weight: 700;
}
.script-summary-main p {
  margin: 0;
  overflow-wrap: anywhere;
}
.script-slots {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.script-slot {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 9px;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  color: #6b7280;
  background: #f9fafb;
  font-size: 12px;
  font-weight: 600;
}
.script-slot.has-code {
  border-color: rgba(4, 120, 87, .22);
  color: #047857;
  background: #ecfdf5;
}
.script-preview {
  display: -webkit-box;
  min-height: 58px;
  max-height: 86px;
  margin: 0;
  padding: 10px;
  overflow: hidden;
  border: 1px solid #eef0f4;
  border-radius: 8px;
  background: #f7f8fb;
  color: #4b5563;
  font: 12px/1.55 ui-monospace, SFMono-Regular, Consolas, monospace;
  overflow-wrap: anywhere;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}
.script-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.script-card {
  display: grid;
  gap: 12px;
  background: white;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
}
.script-card label {
  margin: 0;
}
.script-card .code-box {
  min-height: 120px;
  font: 13px/1.5 ui-monospace, SFMono-Regular, Consolas, monospace;
}
.script-dialog-form {
  border: 0;
  padding: 0;
  box-shadow: none;
}
.script-code-dialog {
  width: min(1160px, calc(100vw - 48px));
}
.dialog-head {
  margin-bottom: 14px;
}
.dialog-head h2 {
  margin: 0;
}
.script-code-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.script-code-grid .code-box {
  min-height: 260px;
  resize: vertical;
}
.script-new {
  border-style: dashed;
}
.form-grid.two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.partner-cell {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}
.partner-cell img {
  width: 72px;
  aspect-ratio: 4 / 3;
  object-fit: contain;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f9fafb;
  padding: 8px;
}
.partner-cell a,
.partner-cell span {
  display: block;
  overflow-wrap: anywhere;
}
.seo-layout {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  margin-top: 18px;
}
.seo-route-list {
  display: grid;
  gap: 8px;
}
.seo-route {
  display: grid;
  gap: 4px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: white;
  padding: 12px;
  text-align: left;
  cursor: pointer;
  font: inherit;
}
.seo-route span {
  color: var(--muted);
  font-size: 12px;
}
.seo-route-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
}
.seo-route-top strong {
  overflow: hidden;
  color: inherit;
  font-size: 14px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.seo-route-status {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}
.seo-route-status.is-missing {
  background: #fff3e8;
  color: #c2410c;
}
.seo-route-status.is-ok {
  background: #ecfdf3;
  color: #047857;
}
.seo-route.is-active {
  border-color: var(--red);
  color: var(--red);
}
.seo-route.is-dirty {
  border-style: dashed;
}
.seo-route-path {
  overflow-wrap: anywhere;
}
.seo-editor {
  display: grid;
  gap: 14px;
}
.seo-save-status {
  min-height: 0;
}
.seo-save-status.is-visible {
  border: 1px solid #dbe7ff;
  border-radius: 8px;
  background: #f4f8ff;
  padding: 10px 12px;
  color: #1d4ed8;
  font-weight: 700;
}
.seo-save-status.is-error {
  border-color: #fecdd3;
  background: #fff1f2;
  color: #be123c;
}
.seo-issues ul {
  margin: 8px 0 0;
  padding-left: 18px;
}
.seo-tab-strip {
  width: fit-content;
  max-width: 100%;
  overflow-x: auto;
}
.seo-tab-panel {
  display: none;
}
.seo-tab-panel.is-active {
  display: grid;
}
.field-label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  min-width: 0;
}
.char-counter {
  flex: 0 0 auto;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.char-counter.is-over {
  color: var(--red);
}
.seo-editor .seo-card-preview {
  grid-column: 1 / -1;
  min-height: 98px;
}
.ai-cms {
  display: grid;
  gap: 16px;
}
.ai-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}
.ai-tabs-shell,
.ai-tab-panel {
  display: grid;
  gap: 16px;
}
.ai-tab-strip {
  width: fit-content;
  max-width: 100%;
  overflow-x: auto;
}
.ai-config-grid {
  grid-template-columns: repeat(2, minmax(260px, 1fr));
}
.ai-work-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
}
.ai-panel {
  background: white;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  min-width: 0;
}
.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
}
.panel-head > div {
  min-width: 0;
}
.ai-page-actions,
.ai-job-create-form,
.ai-row-actions,
.ai-review-button-row {
  flex-wrap: nowrap;
  align-items: center;
  white-space: nowrap;
}
.ai-job-create-form select {
  width: 170px;
  min-width: 170px;
}
.ai-plan-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}
.ai-info-box {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #f7f8fb;
}
.ai-info-box span {
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 600;
}
.ai-info-box strong {
  min-width: 0;
  overflow: hidden;
  color: var(--admin-text);
  font-size: 15px;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ai-plan-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.panel-head h2,
.provider-summary h3,
.review-item h3 {
  margin: 0;
}
.provider-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 1fr));
  gap: 12px;
}
.provider-summary {
  display: grid;
  gap: 8px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
}
.provider-summary-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}
.provider-summary .ai-row-actions {
  width: auto;
  min-width: 0;
  flex-wrap: wrap;
  justify-content: flex-end;
  white-space: normal;
}
.provider-summary .ai-row-actions form,
.provider-summary .ai-row-actions .button {
  flex: 0 0 auto;
}
.status-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
}
.provider-summary h3 {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.provider-meter,
.quick-facts {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 13px;
}
.provider-meter strong,
.quick-facts strong {
  color: var(--ink);
}
.settings-compact-list {
  display: grid;
  gap: 12px;
  min-width: 0;
}
.settings-integration-list {
  margin-top: 16px;
}
.settings-compact-row {
  display: grid;
  grid-template-columns: minmax(260px, 1.15fr) minmax(360px, 1fr) auto;
  align-items: center;
  gap: 16px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  padding: 14px;
}
.settings-compact-main {
  display: grid;
  gap: 6px;
  min-width: 0;
}
.settings-compact-main h3 {
  margin: 0;
  overflow: hidden;
  color: var(--text);
  font-size: 16px;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.settings-compact-main p {
  margin: 0;
  overflow-wrap: anywhere;
}
.settings-compact-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
  margin: 0;
}
.settings-compact-meta div {
  min-width: 0;
  border: 1px solid #eef0f4;
  border-radius: 8px;
  background: #f9fafb;
  padding: 8px 10px;
}
.settings-compact-meta dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
}
.settings-compact-meta dd {
  margin: 2px 0 0;
  overflow: hidden;
  color: var(--ink);
  font-size: 13px;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.settings-compact-actions {
  justify-content: flex-end;
  min-width: 0;
  white-space: nowrap;
}
.settings-compact-actions form {
  margin: 0;
}
.settings-compact-actions .button {
  flex: 0 0 auto;
}
.cms-dialog {
  width: min(920px, calc(100vw - 32px));
  max-height: min(86vh, 920px);
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 22px;
  box-shadow: 0 24px 80px rgba(15, 23, 42, .22);
}
.cms-dialog::backdrop {
  background: rgba(15, 23, 42, .42);
}
.dialog-close-form {
  float: right;
  margin-left: 12px;
}
.provider-form,
.schedule-form {
  display: grid;
  gap: 14px;
}
.provider-costs,
.toggle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.ai-topic-group-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  padding: 0;
  overflow: hidden;
}
.ai-topic-group-card + .ai-topic-group-card {
  margin-top: 12px;
}
.ai-topic-group-card summary {
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 16px;
  background: #f8fafc;
  border-bottom: 1px solid var(--line);
}
.ai-topic-group-card .provider-costs {
  padding: 16px;
}
.ai-topic-group-card textarea.code-box,
.schedule-form textarea.code-box {
  min-height: 110px;
}
.inline-tool-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}
.inline-tool-form .button {
  min-height: 44px;
  white-space: nowrap;
}
.compact-filter {
  margin: 0 0 12px;
  padding: 0;
  border: 0;
}
.compact-filter label {
  width: min(240px, 100%);
}
.ai-table {
  min-width: 980px;
}
.ai-panel .table-wrap {
  overflow-y: visible;
}
.ai-table td {
  vertical-align: top;
}
.ai-job-progress {
  max-width: 320px;
}
.ai-progress-bar {
  height: 8px;
  width: 100%;
  overflow: hidden;
  border-radius: 999px;
  background: #eef2f7;
  border: 1px solid #e2e8f0;
  margin-bottom: 8px;
}
.ai-progress-bar span {
  display: block;
  height: 100%;
  width: var(--progress, 0%);
  max-width: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #dc2626, #f97316);
  transition: width 180ms ease;
}
.ai-progress-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  font-size: 13px;
  line-height: 1.45;
}
.ai-details {
  margin-top: 8px;
}
.ai-details summary {
  width: fit-content;
  cursor: pointer;
  color: var(--red);
  font-weight: 600;
}
.json-block {
  margin: 8px 0 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f9fafb;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  max-height: 260px;
  overflow: auto;
  font: 13px/1.6 ui-monospace, SFMono-Regular, Consolas, monospace;
}
.review-list {
  display: grid;
  gap: 12px;
  max-height: 740px;
  overflow: auto;
  padding-right: 4px;
}
.review-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 250px;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  min-width: 0;
}
.review-main {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.review-main h3,
.review-main p,
.review-main .muted {
  overflow-wrap: anywhere;
}
.review-actions {
  display: grid;
  gap: 10px;
  align-content: start;
}
.review-status-form {
  display: grid;
  gap: 10px;
}
.ai-unsplash-form {
  grid-template-columns: minmax(260px, 520px) auto;
  justify-content: start;
}
.reason-list {
  margin: 0;
  padding-left: 20px;
  color: var(--muted);
}
.ai-log-panel {
  margin-top: 12px;
  max-height: 280px;
  overflow: auto;
}
.log-row {
  display: grid;
  grid-template-columns: auto minmax(80px, 160px) auto;
  gap: 8px;
  align-items: start;
  border-top: 1px solid var(--line);
  padding: 10px 0;
}
.log-row p {
  grid-column: 1 / -1;
  margin: 0;
}
.status-pill.status-queued,
.status-pill.status-pending { background: #fff7ed; color: #c2410c; }
.status-pill.status-running { background: #eef2ff; color: #3730a3; }
.status-pill.status-succeeded,
.status-pill.status-approved,
.status-pill.status-applied,
.status-pill.status-success { background: #ecfdf5; color: #047857; }
.status-pill.status-failed,
.status-pill.status-rejected,
.status-pill.status-error { background: #fff1f2; color: #b91c1c; }
.status-pill.status-cancelled,
.status-pill.status-blocked,
.status-pill.status-warning { background: #fefce8; color: #a16207; }

@media (max-width: 989px), (min-height: 100vw) {
  .site-header { padding: 0 18px; }
  nav { gap: 12px; font-size: 14px; }
  .hero { min-height: auto; padding: 56px 24px; }
  .grid, .metrics, .admin-shell, .admin-form, .form-section, .post-editor, .media-tools, .folder-panel, .folder-list, .media-grid, .media-picker-grid, .media-actions, .submissions-layout, .script-list, .seo-layout, .ai-grid, .provider-summary-grid, .provider-costs, .toggle-grid, .inline-tool-form, .review-item, .ai-plan-summary, .partner-cell { grid-template-columns: 1fr; }
  .settings-compact-row, .settings-compact-meta { grid-template-columns: 1fr; }
  .settings-compact-actions { justify-content: flex-start; white-space: normal; }
  .admin-nav, .editor-side { position: static; }
  .page-title-row, .pagination-row, .session-banner { align-items: flex-start; flex-direction: column; }
  .cms-dialog { width: calc(100vw - 18px); padding: 16px; }
}

@media (max-width: 1279px) and (orientation: landscape) {
  .settings-compact-row {
    grid-template-columns: minmax(220px, .9fr) minmax(280px, 1fr);
  }
  .settings-compact-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}

/* CMS redesign */
.admin-shell,
.cms-login-shell,
.cms-dialog,
.admin-shell input,
.admin-shell select,
.admin-shell textarea,
.admin-shell button {
  font-family: var(--font-admin);
  letter-spacing: 0;
}

.admin-shell {
  grid-template-columns: 288px minmax(0, 1fr);
  background: var(--admin-bg);
  color: var(--admin-text);
}

.admin-main {
  min-width: 0;
  padding: 28px 32px 40px;
}

.admin-nav {
  position: sticky;
  top: 0;
  height: 100vh;
  gap: 22px;
  padding: 22px 18px;
  background:
    linear-gradient(180deg, rgba(193, 39, 45, .16), rgba(193, 39, 45, 0) 30%),
    var(--admin-sidebar);
  border-right: 1px solid rgba(255, 255, 255, .08);
  color: #f7f8fb;
  overflow-y: auto;
}

.admin-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 8px 18px;
  color: #fff;
}

.admin-brand-mark {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  border-radius: 8px;
  background: var(--red);
  color: #fff;
  font-weight: 800;
  box-shadow: 0 12px 30px rgba(193, 39, 45, .32);
}

.admin-brand strong {
  display: block;
  font-size: 16px;
  line-height: 1.1;
  color: #fff;
}

.admin-brand small {
  display: block;
  margin-top: 3px;
  color: rgba(255, 255, 255, .62);
  font-size: 12px;
  font-weight: 400;
}

.admin-nav-list {
  display: grid;
  gap: 8px;
}

.admin-nav-list a {
  display: grid;
  gap: 3px;
  padding: 12px 13px;
  border: 1px solid transparent;
  border-radius: 8px;
  color: rgba(255, 255, 255, .76);
}

.admin-nav-list a span {
  font-size: 14px;
  font-weight: 600;
  color: inherit;
}

.admin-nav-list a small {
  font-size: 12px;
  font-weight: 400;
  color: rgba(255, 255, 255, .48);
}

.admin-nav-list a:hover,
.admin-nav-list a.is-active {
  background: var(--admin-sidebar-soft);
  border-color: rgba(255, 255, 255, .08);
  color: #fff;
}

.admin-nav-list a.is-active {
  box-shadow: inset 3px 0 0 var(--red);
}

.admin-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 16px;
}

.admin-topbar h1 {
  margin: 2px 0 0;
  font-size: 28px;
  line-height: 1.15;
  font-weight: 700;
  color: var(--admin-text);
}

.admin-kicker,
.eyebrow {
  margin: 0;
  color: var(--red);
  text-transform: uppercase;
  font-size: 12px;
  letter-spacing: 0;
  font-weight: 700;
}

.admin-topbar-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.user-chip {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 12px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
  color: var(--admin-muted);
  font-size: 13px;
  font-weight: 600;
}

.admin-subnav {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  padding: 8px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: rgba(255, 255, 255, .78);
  box-shadow: 0 8px 24px rgba(16, 19, 26, .04);
  overflow-x: auto;
}

.admin-subnav a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 13px;
  border-radius: 8px;
  color: var(--admin-muted);
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
}

.admin-subnav a:hover,
.admin-subnav a.is-active {
  background: var(--admin-sidebar);
  color: #fff;
}

.page-title-row,
.dashboard-hero,
.filter-form,
.batch-bar,
.admin-form,
.form-section,
.table-wrap,
.media-grid-wrap,
.submission-detail-panel,
.settings-section,
.script-card,
.seo-route,
.ai-panel,
.provider-summary,
.review-item,
.metric-chip,
.dashboard-panel {
  border-color: var(--admin-line);
  background: var(--admin-surface);
  box-shadow: 0 10px 30px rgba(16, 19, 26, .04);
}

.page-title-row {
  padding: 18px;
  margin-bottom: 16px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: var(--admin-surface);
}

.page-title-row h1,
.page-title-row h2,
.form-section h2,
.settings-section h2,
.panel-head h2,
.cms-dialog h2 {
  margin-top: 0;
  color: var(--admin-text);
  font-weight: 700;
  letter-spacing: 0;
}

.page-title-row h1 {
  margin-bottom: 4px;
  font-size: 26px;
  line-height: 1.18;
}

.page-title-row .muted,
.dashboard-hero p,
.panel-head .muted {
  max-width: 720px;
}

.button {
  gap: 8px;
  min-height: 42px;
  border-radius: 8px;
  font-family: var(--font-admin);
  font-weight: 600;
  letter-spacing: 0;
  box-shadow: 0 8px 18px rgba(193, 39, 45, .14);
}

.button.secondary {
  border-color: var(--admin-line);
  background: #fff;
  color: var(--admin-text);
  box-shadow: none;
}

.button.secondary:hover {
  border-color: #c8d0dc;
  background: #f7f8fb;
}

.button.danger {
  border-color: #dc2626;
  background: #dc2626;
  color: #fff;
}

.button.small {
  min-height: 34px;
  padding: 0 12px;
  font-size: 13px;
}

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

.button .button-icon,
.icon-button .button-icon {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
  stroke-width: 2;
}

.icon-button {
  width: 34px;
  min-width: 34px;
  height: 34px;
  min-height: 34px;
  padding: 0;
  gap: 0;
  border-radius: 8px;
}

.icon-button .button-icon {
  width: 17px;
  height: 17px;
}

.icon-button.button.small {
  padding: 0;
}

label {
  margin: 0;
  color: var(--admin-text);
  font-weight: 600;
  font-size: 13px;
}

input,
select,
textarea {
  border-color: #d8dee8;
  background: #fff;
  color: var(--admin-text);
  font-weight: 400;
}

input:focus,
select:focus,
textarea:focus {
  outline: 3px solid rgba(193, 39, 45, .14);
  border-color: rgba(193, 39, 45, .58);
}

.muted {
  color: var(--admin-muted);
  font-weight: 400;
}

.admin-form,
.form-section {
  gap: 16px;
  padding: 18px;
}

.filter-form,
.batch-bar {
  margin: 16px 0;
  padding: 14px;
}

.table-wrap,
.table-scroll {
  width: 100%;
  max-width: 100%;
  max-height: min(72vh, 760px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.table-wrap.settings-section,
.table-scroll.settings-section {
  padding: 0;
}

.admin-table {
  width: 100%;
  min-width: 980px;
  font-size: 14px;
}

.admin-table th,
.admin-table td {
  padding: 13px 14px;
}

.admin-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  color: var(--admin-muted);
  background: #f7f8fb;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
  white-space: nowrap;
}

.admin-table td {
  color: var(--admin-text);
}

.nowrap {
  white-space: nowrap;
}

.admin-table tbody tr:hover {
  background: #fafbfc;
}

.post-title-cell {
  max-width: clamp(420px, 50vw, 780px);
}

.post-title-cell strong,
.post-title-cell .muted {
  display: block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.post-table-thumb {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  overflow: hidden;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #f2f5f8;
}

.post-table-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.post-table-thumb.is-empty::before {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 5px;
  border: 1px solid #cbd5e1;
  background: linear-gradient(135deg, #fff 0 50%, #e5eaf1 50% 100%);
}

.row-actions {
  flex-wrap: wrap;
  align-items: center;
}

.post-row-actions {
  width: 1%;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.post-row-actions .button {
  flex: 0 0 auto;
}

.row-actions.ai-page-actions,
.row-actions.ai-job-create-form,
.row-actions.ai-row-actions,
.row-actions.ai-review-button-row {
  flex-wrap: nowrap;
  align-items: center;
  white-space: nowrap;
}

.row-actions.ai-row-actions {
  width: 1%;
}

.row-actions.ai-row-actions .button,
.row-actions.ai-review-button-row .button {
  flex: 0 0 auto;
}

.row-form {
  grid-template-columns: repeat(2, minmax(160px, 1fr));
  gap: 10px;
}

.status-pill,
.type-pill {
  border-radius: 999px;
  font-weight: 600;
}

.dashboard-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 16px;
  padding: 22px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
}

.dashboard-hero h2 {
  margin: 2px 0 6px;
  font-size: 28px;
  line-height: 1.15;
}

.dashboard-hero p {
  margin: 0;
}

.metrics {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}

.metric-card,
.metrics div {
  display: grid;
  gap: 8px;
  min-height: 142px;
  padding: 18px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 30px rgba(16, 19, 26, .04);
}

.metric-card span,
.metrics span {
  color: var(--admin-muted);
  font-size: 13px;
  font-weight: 600;
}

.metric-card strong,
.metrics strong {
  color: var(--admin-text);
  font-size: 40px;
  line-height: 1;
  font-weight: 700;
}

.metric-card small {
  color: var(--admin-muted);
  font-size: 13px;
  line-height: 1.4;
}

.metric-card.attention strong {
  color: var(--red);
}

.dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, .85fr);
  gap: 16px;
}

.dashboard-panel {
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  padding: 18px;
}

.chart-list {
  display: grid;
  gap: 14px;
}

.chart-row {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr) 56px;
  gap: 12px;
  align-items: center;
}

.chart-row span,
.chart-row strong {
  font-size: 13px;
  font-weight: 600;
}

.chart-row strong {
  text-align: right;
}

.chart-track {
  height: 12px;
  border-radius: 999px;
  background: #edf1f6;
  overflow: hidden;
}

.chart-track i {
  display: block;
  min-width: 0;
  max-width: 100%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--red), #ef6b55);
}

.quick-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.quick-grid a {
  display: grid;
  gap: 6px;
  min-height: 92px;
  padding: 14px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #f9fafb;
}

.quick-grid strong {
  color: var(--red);
  font-size: 24px;
  font-weight: 700;
}

.quick-grid span {
  color: var(--admin-muted);
  font-size: 13px;
  font-weight: 600;
}

.ops-hero,
.compact-hero {
  align-items: flex-start;
}

.period-tabs {
  display: inline-flex;
  flex: 0 0 auto;
  gap: 6px;
  padding: 5px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #f7f8fb;
}

.period-tabs a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 7px;
  color: var(--admin-muted);
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
}

.period-tabs a:hover,
.period-tabs a.is-active {
  background: #fff;
  color: var(--admin-text);
  box-shadow: 0 6px 16px rgba(16, 19, 26, .08);
}

.ops-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.analytics-grid {
  align-items: start;
}

.wide-panel {
  grid-column: 1 / -1;
}

.quick-grid.compact a {
  min-height: 74px;
}

.chart-track.warning i {
  background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

.chart-track.danger i {
  background: linear-gradient(90deg, #dc2626, #ef4444);
}

.top-list,
.breakdown-list,
.activity-list {
  display: grid;
  gap: 10px;
  width: 100%;
  min-width: 0;
  max-height: min(44vh, 420px);
  overflow-y: auto;
  padding-right: 4px;
}

.top-row,
.activity-list a {
  display: grid;
  gap: 7px;
  min-width: 0;
  padding: 10px 0;
  border-bottom: 1px solid #edf0f4;
}

.top-row {
  grid-template-columns: minmax(0, 1fr) minmax(120px, 200px) 64px;
  align-items: center;
}

.top-row span,
.activity-list strong {
  overflow: hidden;
  color: var(--admin-text);
  font-size: 13px;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.top-row strong {
  text-align: right;
  color: var(--admin-text);
}

.activity-list small {
  color: var(--admin-muted);
  font-size: 12px;
}

.system-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.system-kpis span {
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #f9fafb;
}

.system-kpis strong {
  overflow: hidden;
  color: var(--admin-text);
  font-size: 18px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.system-kpis small {
  color: var(--admin-muted);
  font-size: 12px;
}

.trend-bars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(28px, 1fr));
  gap: 8px;
  align-items: end;
  min-height: 220px;
  padding-top: 10px;
}

.trend-bars span {
  display: grid;
  grid-template-rows: 180px auto;
  gap: 8px;
  min-width: 0;
}

.trend-bars i {
  align-self: end;
  display: block;
  min-height: 4px;
  border-radius: 6px 6px 0 0;
  background: linear-gradient(180deg, var(--red), #ef6b55);
}

.trend-bars small {
  overflow: hidden;
  color: var(--admin-muted);
  font-size: 10px;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.notification-slot {
  position: relative;
  min-height: 36px;
}

.notification-bell {
  position: relative;
}

.notification-bell summary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 0 12px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
  color: var(--admin-text);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  list-style: none;
}

.notification-bell summary::-webkit-details-marker {
  display: none;
}

.notification-bell summary strong {
  display: inline-grid;
  place-items: center;
  min-width: 20px;
  height: 20px;
  border-radius: 999px;
  background: var(--red);
  color: #fff;
  font-size: 11px;
}

.notification-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 30;
  display: grid;
  gap: 8px;
  width: min(360px, calc(100vw - 32px));
  max-height: 420px;
  overflow: auto;
  padding: 10px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--admin-shadow);
}

.notification-item {
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 10px;
  border: 1px solid #edf0f4;
  border-radius: 8px;
  background: #fbfcfe;
}

.notification-item.is-read {
  opacity: 0.76;
}

.notification-read-all {
  display: flex;
  justify-content: flex-end;
}

.notification-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.notification-actions form {
  margin: 0;
}

.notification-item.danger {
  border-color: #fecaca;
  background: #fff1f2;
}

.notification-item.warning {
  border-color: #fde68a;
  background: #fffbeb;
}

.notification-item strong {
  color: var(--admin-text);
  font-size: 13px;
}

.notification-item span,
.notification-item small {
  color: var(--admin-muted);
  font-size: 12px;
  line-height: 1.45;
}

.span-all {
  grid-column: 1 / -1;
}

.ops-check-form {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.maintenance-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: -4px 0 18px;
}

.media-tools,
.folder-panel,
.seo-layout,
.ai-grid,
.provider-summary-grid,
.script-list {
  gap: 16px;
}

.media-card,
.media-picker-item,
.partner-cell img {
  border-color: var(--admin-line);
  background: #fff;
}

.media-card img,
.media-picker-item img,
.media-picker-item .file-tile,
.file-tile {
  background: #f2f5f8;
}

.media-meta {
  min-height: 98px;
}

.media-meta strong,
.partner-cell a,
.partner-cell span,
.admin-table strong {
  overflow-wrap: anywhere;
}

.media-workspace {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.media-sidebar,
.media-content {
  min-width: 0;
}

.media-sidebar {
  position: sticky;
  top: 20px;
  display: grid;
  gap: 14px;
  max-height: calc(100vh - 116px);
  overflow: auto;
  padding: 16px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 30px rgba(16, 19, 26, .04);
}

.media-sidebar-head h2,
.media-content-head h2 {
  margin: 0 0 4px;
  color: var(--admin-text);
  font-size: 18px;
  font-weight: 700;
}

.media-sidebar-head p,
.media-content-head p {
  margin: 0;
}

.media-folder-tree {
  display: grid;
  gap: 6px;
}

.media-folder-node {
  position: relative;
  display: grid;
  gap: 5px;
}

.media-folder-node::before {
  content: "";
  position: absolute;
  left: 10px;
  top: -6px;
  bottom: 20px;
  width: 1px;
  background: #dde4ee;
}

.media-folder-node::after {
  content: "";
  position: absolute;
  left: 10px;
  top: 20px;
  width: 14px;
  height: 1px;
  background: #dde4ee;
}

.media-folder-node.depth-0::before,
.media-folder-node.depth-0::after {
  display: none;
}

.media-folder-node.depth-1 { padding-left: 22px; }
.media-folder-node.depth-2 { padding-left: 44px; }
.media-folder-node.depth-3,
.media-folder-node.depth-4,
.media-folder-node.depth-5 { padding-left: 66px; }

.media-folder-link {
  position: relative;
  display: block;
  width: 100%;
  min-height: 44px;
  padding: 10px 11px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: var(--admin-text);
  cursor: pointer;
  text-align: left;
}

.media-folder-link:hover,
.media-folder-link.is-active {
  border-color: rgba(193, 39, 45, .28);
  background: #fff7f7;
}

.media-folder-line {
  display: grid;
  gap: 3px;
}

.media-folder-line b {
  font-size: 13px;
  font-weight: 700;
}

.media-folder-line small {
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 400;
}

.media-folder-edit {
  padding-left: 11px;
}

.media-folder-edit summary {
  color: var(--admin-muted);
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
}

.media-folder-edit form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  margin-top: 8px;
}

.media-folder-create {
  display: grid;
  gap: 10px;
  padding-top: 14px;
  border-top: 1px solid var(--admin-line);
}

.media-content {
  display: grid;
  gap: 16px;
}

.media-content-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-end;
  padding: 16px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 30px rgba(16, 19, 26, .04);
}

.media-content-head .filter-form {
  margin: 0;
  min-width: min(100%, 360px);
}

.submissions-layout {
  grid-template-columns: minmax(0, 1fr);
}

.submissions-layout:has(.submission-detail-panel:not(.empty-state):not(.is-placeholder)) {
  grid-template-columns: minmax(0, 1fr) minmax(340px, 420px);
}

.submission-detail-panel {
  position: sticky;
  top: 20px;
}

.detail-head h2 {
  font-size: 20px;
  font-weight: 700;
}

.payload-panel {
  background: #f7f8fb;
}

.settings-section {
  padding: 18px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
}

.settings-section > h2 {
  margin-bottom: 12px;
}

.seo-route.is-active {
  border-color: rgba(193, 39, 45, .45);
  background: #fff7f7;
  color: var(--red);
}

.cms-dialog {
  width: min(1040px, calc(100vw - 48px));
  max-height: calc(100vh - 48px);
  padding: 24px;
  border-color: var(--admin-line);
  border-radius: 8px;
  color: var(--admin-text);
  background: #fff;
  box-shadow: 0 24px 90px rgba(16, 19, 26, .28);
}

.cms-dialog.media-picker-dialog {
  width: min(1320px, calc(100vw - 24px));
  max-width: none;
  max-height: min(900px, calc(100vh - 24px));
}

.ai-schedule-dialog {
  width: min(1480px, calc(100vw - 48px));
}

.ai-schedule-dialog .provider-costs {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ai-schedule-dialog .form-section > .provider-costs label:has(textarea),
.ai-schedule-dialog > form > label {
  grid-column: auto;
}

.ai-schedule-dialog .ai-topic-group-card .provider-costs {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ai-schedule-dialog textarea.code-box {
  min-height: 128px;
}

.ai-schedule-dialog .ai-topic-group-card summary {
  position: sticky;
  top: 40px;
  z-index: 1;
}

.ai-config-dialog {
  width: min(1480px, calc(100vw - 48px));
  padding: 0;
  overflow: hidden;
  background: #f6f7f9;
}

.ai-config-dialog-head {
  position: sticky;
  top: 0;
  z-index: 3;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: start;
  padding: 22px 24px 18px;
  border-bottom: 1px solid var(--admin-line);
  background: rgba(255, 255, 255, .96);
  backdrop-filter: blur(10px);
}

.ai-config-dialog-head h2 {
  margin: 2px 0 6px;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0;
}

.ai-config-dialog-head p {
  max-width: 860px;
  margin: 0;
}

.ai-config-dialog-head .dialog-close-form {
  position: static;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
}

.ai-config-form {
  max-height: calc(100vh - 164px);
  padding: 18px 24px 0;
  overflow: auto;
  gap: 16px;
}

.ai-config-switchbar {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.ai-switch-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-height: 72px;
  margin: 0;
  padding: 14px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
}

.ai-switch-card input {
  width: 18px;
  height: 18px;
  accent-color: var(--red);
}

.ai-switch-card strong,
.ai-switch-card small {
  display: block;
}

.ai-switch-card strong {
  margin-bottom: 3px;
  color: var(--admin-text);
  font-size: 14px;
  font-weight: 700;
}

.ai-switch-card small {
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 400;
  line-height: 1.45;
}

.ai-config-section {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
}

.ai-config-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid #edf0f4;
}

.ai-config-section-head h3 {
  margin: 0 0 4px;
  color: var(--admin-text);
  font-size: 17px;
  font-weight: 700;
}

.ai-config-section-head p {
  margin: 0;
}

.ai-config-days {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.ai-config-days label {
  position: relative;
  min-height: 40px;
  margin: 0;
}

.ai-config-days input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.ai-config-days span {
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  color: #596274;
  background: #fafbfc;
  font-size: 13px;
  font-weight: 600;
}

.ai-config-days input:checked + span {
  border-color: rgba(193, 39, 45, .4);
  color: var(--red);
  background: #fff4f4;
}

.ai-config-grid,
.ai-topic-meta-grid,
.ai-topic-text-grid {
  display: grid;
  gap: 12px;
  min-width: 0;
}

.ai-config-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ai-config-grid-schedule {
  grid-template-columns: minmax(280px, 1.25fr) repeat(2, minmax(180px, 1fr));
  align-items: start;
}

.ai-config-grid-text {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ai-field {
  display: grid;
  gap: 6px;
  min-width: 0;
  margin: 0;
  color: var(--admin-text);
  font-size: 13px;
  font-weight: 600;
}

.ai-field small {
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 400;
  line-height: 1.35;
}

.ai-field input,
.ai-field select,
.ai-field textarea {
  width: 100%;
}

.ai-field select {
  min-height: 42px;
  padding: 0 12px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  color: var(--admin-text);
  background: #fff;
  font: inherit;
  font-weight: 400;
}

.ai-field-wide {
  grid-row: span 2;
}

.ai-field-full {
  grid-column: 1 / -1;
}

.ai-config-dialog textarea.code-box {
  min-height: 84px;
  max-height: 132px;
  overflow-y: auto;
  resize: vertical;
  line-height: 1.55;
}

.ai-config-grid-schedule textarea.code-box {
  min-height: 116px;
  max-height: 160px;
}

.ai-token-field {
  grid-row: auto;
}

.token-input {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 5px 8px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fff;
}

.token-input:focus-within {
  border-color: rgba(193, 39, 45, .45);
  box-shadow: 0 0 0 3px rgba(193, 39, 45, .08);
}

.token-input.is-invalid {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, .12);
}

.token-list {
  display: contents;
}

.token-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 0 8px 0 10px;
  border: 1px solid rgba(193, 39, 45, .22);
  border-radius: 999px;
  color: var(--red);
  background: #fff4f4;
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
}

.token-chip button {
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border: 0;
  border-radius: 999px;
  color: inherit;
  background: transparent;
  cursor: pointer;
  font: inherit;
  line-height: 1;
}

.token-chip button:hover,
.token-chip button:focus-visible {
  background: rgba(193, 39, 45, .12);
  outline: 0;
}

.token-input input[data-token-entry] {
  flex: 1 1 120px;
  min-width: 96px;
  height: 30px;
  min-height: 30px;
  padding: 0 4px;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  font-weight: 400;
}

.token-input input[data-token-entry]:focus {
  outline: 0;
  box-shadow: none;
}

.ai-config-check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.ai-config-check-grid label {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 38px;
  margin: 0;
  padding: 8px 10px;
  border: 1px solid var(--admin-line);
  border-radius: 8px;
  background: #fafbfc;
  color: #596274;
  font-size: 13px;
  font-weight: 600;
}

.ai-config-check-grid input {
  width: 16px;
  height: 16px;
  accent-color: var(--red);
}

.ai-config-check-grid span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ai-topic-group-card {
  border-color: #dfe4ec;
  background: #fff;
}

.ai-topic-group-card summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  background: linear-gradient(180deg, #fbfcfe 0%, #f4f6f9 100%);
}

.ai-topic-summary-main {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.ai-topic-summary-main strong {
  overflow: hidden;
  color: var(--admin-text);
  font-size: 15px;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ai-topic-summary-main small {
  overflow: hidden;
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 400;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ai-topic-summary-meta {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  color: var(--red);
  background: #fff4f4;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.ai-topic-group-body {
  display: grid;
  gap: 14px;
  padding: 16px;
}

.ai-topic-meta-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding-bottom: 14px;
  border-bottom: 1px solid #edf0f4;
}

.ai-topic-text-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ai-topic-text-grid textarea.code-box {
  min-height: 88px;
  max-height: 142px;
}

.ai-topic-text-grid .ai-field-full textarea.code-box {
  min-height: 98px;
  max-height: 164px;
}

.ai-topic-groups-section,
.ai-fallback-section {
  background: #fbfcfe;
}

.ai-fallback-section .ai-config-grid-text {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ai-config-footer {
  position: sticky;
  bottom: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 0 -24px;
  padding: 14px 24px;
  border-top: 1px solid var(--admin-line);
  background: rgba(255, 255, 255, .97);
  backdrop-filter: blur(10px);
}

.cms-dialog::backdrop {
  background: rgba(10, 12, 18, .58);
  backdrop-filter: blur(3px);
}

.dialog-close-form {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  justify-content: flex-end;
  float: none;
  margin: -8px 0 10px;
  padding-bottom: 8px;
  background: linear-gradient(180deg, #fff 70%, rgba(255,255,255,0));
}

.provider-form,
.schedule-form {
  gap: 16px;
}

.session-banner {
  margin: 0 0 16px;
  font-family: var(--font-admin);
  font-weight: 400;
}

.cms-login-shell {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 560px) minmax(360px, 460px);
  align-items: center;
  justify-content: center;
  gap: 56px;
  min-height: 100vh;
  padding: 48px;
  color: #fff;
  background:
    linear-gradient(115deg, rgba(8, 10, 15, .78), rgba(8, 10, 15, .62) 44%, rgba(8, 10, 15, .84)),
    url("/static/img/cms-login-bg.webp") center / cover no-repeat;
}

.cms-login-shell::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 24% 22%, rgba(193, 39, 45, .24), transparent 34%);
}

.cms-login-copy,
.login-card {
  position: relative;
  z-index: 1;
}

.cms-login-copy span {
  display: inline-flex;
  margin-bottom: 16px;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
}

.cms-login-copy h1 {
  max-width: 560px;
  margin: 0 0 18px;
  color: #fff;
  font-size: clamp(42px, 5vw, 72px);
  line-height: .98;
  font-weight: 700;
}

.cms-login-copy p {
  max-width: 520px;
  margin: 0;
  color: rgba(255,255,255,.74);
  font-size: 17px;
  line-height: 1.7;
}

.login-card {
  width: 100%;
  max-width: 460px;
  padding: 26px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  background: rgba(14, 17, 24, .82);
  box-shadow: 0 24px 80px rgba(0,0,0,.34);
  backdrop-filter: blur(16px);
}

.login-card-head {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 18px;
}

.login-card h2 {
  margin: 0 0 4px;
  color: #fff;
  font-size: 24px;
  font-weight: 700;
}

.login-card p {
  margin: 0;
  color: rgba(255,255,255,.66);
  line-height: 1.5;
}

.login-card label {
  margin: 14px 0;
  color: rgba(255,255,255,.88);
}

.login-card input {
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: #fff;
}

.login-card input:focus {
  border-color: rgba(255,255,255,.48);
  outline-color: rgba(193, 39, 45, .38);
}

.login-submit {
  width: 100%;
  margin-top: 4px;
}

.login-card .alert {
  margin: 0 0 14px;
}

.admin-shell input[type="file"] {
  height: auto;
  min-height: 44px;
  padding: 6px;
  line-height: 1.4;
  cursor: pointer;
}

.admin-shell input[type="file"]::file-selector-button {
  min-height: 32px;
  margin: 0 10px 0 0;
  padding: 0 12px;
  border: 1px solid var(--admin-line);
  border-radius: 7px;
  background: #f7f8fb;
  color: var(--admin-text);
  font: 600 13px/1 var(--font-admin);
  cursor: pointer;
}

.admin-shell input[type="file"]::file-selector-button:hover {
  border-color: #c8d0dc;
  background: #eef2f7;
}

.admin-shell input[type="checkbox"],
.admin-shell input[type="radio"] {
  width: 16px;
  height: 16px;
  min-height: 0;
  margin: 0;
  padding: 0;
  border-radius: 4px;
  accent-color: var(--red);
  flex: 0 0 auto;
}

.admin-shell input[type="radio"] {
  border-radius: 999px;
}

.admin-shell label.inline-check {
  display: inline-flex;
  min-height: 44px;
  align-items: center;
  gap: 10px;
}

.script-code-dialog .script-dialog-form {
  border: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

@media (max-width: 989px), (height >= width) {
  .settings-scripts-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .settings-scripts-toolbar .button {
    width: 100%;
  }

  .script-list-compact,
  .script-code-grid,
  .ops-check-form,
  .form-grid.two,
  .post-edit-tabs .tab-panel {
    grid-template-columns: 1fr;
  }

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

  .tab-strip {
    width: 100%;
    overflow-x: auto;
  }

  .script-code-grid .code-box {
    min-height: 180px;
  }

  .script-code-dialog {
    width: calc(100vw - 18px);
  }
}

.admin-table input[type="checkbox"],
.batch-bar input[type="checkbox"] {
  vertical-align: middle;
}

@media (max-width: 989px), (min-height: 100vw) {
  .admin-shell {
    display: block;
  }

  .admin-nav {
    position: static;
    height: auto;
    padding: 16px;
  }

  .admin-nav-list {
    display: flex;
    gap: 8px;
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    padding-bottom: 2px;
  }

  .admin-nav-list a {
    min-width: 178px;
  }

  .admin-main {
    padding: 18px;
    max-width: 100vw;
    overflow-x: hidden;
  }

  .table-wrap {
    contain: layout paint inline-size;
    width: 100%;
    max-width: 100%;
    max-height: min(70vh, 760px);
    min-width: 0;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .table-wrap > form {
    width: 100%;
    min-width: 0;
  }

  .table-wrap .admin-table {
    display: block;
    width: 100%;
    min-width: 0;
    table-layout: auto;
  }

  .admin-table thead {
    display: none;
  }

  .admin-table tbody {
    display: grid;
    gap: 10px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 10px;
  }

  .admin-table tr {
    display: grid;
    gap: 8px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--admin-line);
    border-radius: 8px;
    background: #fff;
  }

  .admin-table tr:has(td[colspan]) {
    display: block;
  }

  .admin-table th,
  .admin-table td {
    display: block;
    padding: 0;
    border: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .admin-table td:empty {
    display: none;
  }

  .row-actions,
  .post-row-actions {
    flex-wrap: wrap;
  }

  .admin-topbar,
  .dashboard-hero,
  .page-title-row,
  .panel-head,
  .admin-topbar-actions {
    align-items: flex-start;
    flex-direction: column;
  }

  .admin-topbar h1 {
    font-size: 24px;
  }

  .admin-subnav {
    margin-bottom: 16px;
  }

  .metrics,
  .dashboard-grid,
  .ops-grid,
  .quick-grid,
  .chart-row,
  .top-row,
  .system-kpis,
  .media-workspace,
  .submissions-layout {
    grid-template-columns: 1fr;
  }

  .period-tabs {
    width: 100%;
    overflow-x: auto;
  }

  .notification-menu {
    left: 0;
    right: auto;
  }

  .trend-bars {
    grid-template-columns: repeat(7, minmax(24px, 1fr));
    overflow-x: auto;
  }

  .media-sidebar,
  .submission-detail-panel {
    position: static;
    max-height: none;
  }

  .media-content-head,
  .media-folder-edit form {
    align-items: stretch;
    flex-direction: column;
    grid-template-columns: 1fr;
  }

  .cms-dialog {
    width: calc(100vw - 18px);
    max-height: calc(100vh - 18px);
    padding: 16px;
  }

  .ai-config-dialog {
    width: calc(100vw - 18px);
    padding: 0;
  }

  .ai-config-dialog-head {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 18px;
  }

  .ai-config-form {
    max-height: calc(100vh - 156px);
    padding: 14px 14px 0;
  }

  .ai-config-switchbar,
  .ai-config-grid,
  .ai-config-grid-schedule,
  .ai-config-grid-text,
  .ai-config-days,
  .ai-config-check-grid,
  .ai-topic-meta-grid,
  .ai-topic-text-grid,
  .ai-fallback-section .ai-config-grid-text {
    grid-template-columns: 1fr;
  }

  .ai-field-wide {
    grid-row: auto;
  }

  .ai-topic-group-card summary {
    grid-template-columns: 1fr;
  }

  .ai-config-footer {
    align-items: stretch;
    flex-direction: column;
    margin: 0 -14px;
    padding: 12px 14px;
  }

  .cms-login-shell {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 28px 18px;
  }

  .cms-login-copy h1 {
    font-size: 38px;
  }
}

@media (max-width: 1280px) and (orientation: landscape) {
  .admin-shell {
    grid-template-columns: 248px minmax(0, 1fr);
  }

  .admin-main {
    padding: 24px;
  }

  .metrics,
  .provider-summary-grid,
  .media-grid,
  .media-picker-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.public-header {
  align-items: center;
  background: rgba(5, 8, 14, 0.84);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  display: grid;
  gap: 18px;
  grid-template-columns: auto minmax(0, 1fr) auto;
  left: 0;
  padding: 14px clamp(18px, 4vw, 64px);
  position: fixed;
  right: 0;
  top: 0;
  z-index: 50;
}

.public-brand,
.public-footer-brand {
  align-items: center;
  color: #fff;
  display: inline-flex;
  font-size: 22px;
  font-weight: 800;
  min-height: 40px;
  text-decoration: none;
}

.public-brand img {
  display: block;
  height: 36px;
  object-fit: contain;
  width: auto;
}

.public-nav {
  align-items: center;
  display: flex;
  gap: 18px;
  justify-content: center;
  min-width: 0;
}

.public-nav a,
.public-footer a,
.lang-link {
  color: rgba(255, 255, 255, 0.78);
  font-size: 14px;
  font-weight: 650;
  text-decoration: none;
}

.public-nav a:hover,
.public-nav a.is-active,
.public-footer a:hover,
.lang-link:hover {
  color: #fff;
}

.public-header-actions {
  align-items: center;
  display: flex;
  gap: 12px;
}

.public-cta {
  background: #e11d48;
  border-radius: 6px;
  color: #fff;
  font-size: 14px;
  font-weight: 750;
  padding: 10px 14px;
  text-decoration: none;
}

.public-nav-toggle,
.public-nav-button {
  display: none;
}

.public-main {
  background: #05070c;
  color: #fff;
  min-height: 100vh;
}

.public-hero {
  display: grid;
  min-height: min(820px, 92vh);
  overflow: hidden;
  padding: 126px clamp(18px, 5vw, 84px) 38px;
  position: relative;
}

.public-hero::after {
  background: linear-gradient(90deg, rgba(5, 7, 12, 0.94), rgba(5, 7, 12, 0.68) 48%, rgba(5, 7, 12, 0.24));
  content: "";
  inset: 0;
  position: absolute;
}

.public-hero-media {
  inset: 0;
  position: absolute;
}

.public-hero-media img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.public-hero-copy {
  align-self: center;
  max-width: 760px;
  position: relative;
  z-index: 1;
}

.public-hero-copy h1,
.post-hero h1 {
  font-size: 56px;
  letter-spacing: 0;
  line-height: 1.04;
  margin: 12px 0 20px;
}

.public-hero-copy p,
.post-hero p,
.section-copy p,
.public-card p,
.public-footer p,
.faq-item p {
  color: rgba(255, 255, 255, 0.74);
  line-height: 1.75;
}

.public-hero-copy > p {
  font-size: 18px;
  max-width: 680px;
}

.public-highlights {
  align-self: end;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 920px;
  position: relative;
  z-index: 1;
}

.public-highlights div {
  border-left: 1px solid rgba(255, 255, 255, 0.2);
  padding: 12px 18px;
}

.public-highlights span {
  color: rgba(255, 255, 255, 0.58);
  display: block;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 6px;
  text-transform: uppercase;
}

.public-highlights strong {
  color: #fff;
  display: block;
  font-size: 16px;
}

.public-section {
  padding: 82px clamp(18px, 5vw, 84px);
}

.public-section:nth-child(even) {
  background: #0b1018;
}

.section-copy {
  max-width: 800px;
}

.section-copy h2 {
  font-size: 34px;
  letter-spacing: 0;
  line-height: 1.15;
  margin: 10px 0 14px;
}

.public-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 28px;
}

.public-card {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  min-width: 0;
  padding: 22px;
}

.public-card h3 {
  font-size: 20px;
  letter-spacing: 0;
  line-height: 1.3;
  margin: 0 0 10px;
}

.public-card a {
  color: #fda4af;
  font-weight: 700;
  text-decoration: none;
}

.public-contact {
  background: #f8fafc;
  color: #111827;
}

.public-contact-grid {
  display: grid;
  gap: 34px;
  grid-template-columns: minmax(0, 0.82fr) minmax(320px, 1.18fr);
}

.public-contact h2,
.public-contact p {
  color: #111827;
}

.public-contact .section-eyebrow {
  color: #be123c;
}

.public-contact-form {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.public-contact-form label {
  display: grid;
  gap: 7px;
}

.public-contact-form span {
  color: #334155;
  font-size: 13px;
  font-weight: 700;
}

.public-contact-form input,
.public-contact-form select,
.public-contact-form textarea {
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  color: #0f172a;
  font: inherit;
  min-width: 0;
  padding: 12px 13px;
  width: 100%;
}

.public-contact-form textarea {
  resize: vertical;
}

.public-contact-form input[type="file"] {
  min-height: 48px;
  padding: 9px 13px;
}

.public-contact-form .span-2 {
  grid-column: 1 / -1;
}

.public-form-actions {
  align-items: center;
  display: flex;
  gap: 14px;
  min-height: 46px;
}

.public-form-status {
  color: #475569;
  font-size: 14px;
  margin: 0;
}

.post-card img {
  aspect-ratio: 16 / 9;
  border-radius: 6px;
  display: block;
  margin: 0 0 16px;
  object-fit: cover;
  width: 100%;
}

.public-footer {
  background: #05070c;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: grid;
  gap: 28px;
  grid-template-columns: minmax(0, 1.2fr) minmax(150px, auto) minmax(170px, auto) minmax(240px, 0.8fr);
  padding: 44px clamp(18px, 5vw, 84px);
}

.public-footer nav,
.public-footer address {
  display: grid;
  gap: 10px;
}

.public-footer address {
  font-style: normal;
}

.public-newsletter-form {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.public-newsletter-form label {
  display: grid;
  gap: 8px;
  margin: 0;
}

.public-newsletter-form span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 13px;
  font-weight: 700;
}

.public-newsletter-form input {
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.public-newsletter-form input::placeholder {
  color: rgba(255, 255, 255, 0.42);
}

.public-newsletter-form .public-form-status {
  color: rgba(255, 255, 255, 0.68);
  font-size: 13px;
}

.quota-strip {
  align-items: center;
  background: rgba(15, 23, 42, 0.06);
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  padding: 12px 14px;
}

.quota-strip span {
  color: var(--muted, #64748b);
  font-size: 13px;
}

.quota-strip strong {
  color: var(--text, #0f172a);
}

.post-main {
  padding-top: 92px;
}

.post-detail {
  margin: 0 auto;
  max-width: 1040px;
  padding: 54px clamp(18px, 5vw, 64px);
}

.post-hero {
  margin-bottom: 34px;
}

.post-hero .cover {
  aspect-ratio: 16 / 9;
  border-radius: 8px;
  display: block;
  margin-top: 28px;
  object-fit: cover;
  width: 100%;
}

.faq-list {
  display: grid;
  gap: 14px;
  max-width: 920px;
}

.faq-item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  padding: 20px 0;
}

.faq-item h2 {
  font-size: 22px;
  letter-spacing: 0;
  line-height: 1.35;
  margin: 0 0 8px;
}

@media (max-width: 989px), (height >= width) {
  .public-header {
    grid-template-columns: auto auto;
    padding: 12px 18px;
  }

  .public-nav-button {
    display: inline-grid;
    gap: 5px;
    justify-self: end;
    padding: 10px;
  }

  .public-nav-button span {
    background: #fff;
    border-radius: 999px;
    display: block;
    height: 2px;
    width: 24px;
  }

  .public-nav,
  .public-header-actions {
    background: rgba(5, 8, 14, 0.96);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    display: none;
    grid-column: 1 / -1;
    justify-content: stretch;
    padding: 12px 0;
  }

  .public-nav {
    flex-direction: column;
    align-items: stretch;
  }

  .public-nav a,
  .public-header-actions a {
    padding: 10px 0;
  }

  .public-nav-toggle:checked ~ .public-nav,
  .public-nav-toggle:checked ~ .public-header-actions {
    display: flex;
  }

  .public-hero {
    min-height: auto;
    padding: 104px 18px 28px;
  }

  .public-hero::after {
    background: linear-gradient(180deg, rgba(5, 7, 12, 0.9), rgba(5, 7, 12, 0.7));
  }

  .public-hero-copy h1,
  .post-hero h1 {
    font-size: 40px;
  }

  .public-highlights,
  .public-grid,
  .public-contact-grid,
  .public-footer {
    grid-template-columns: 1fr;
  }

  .public-contact-form {
    grid-template-columns: 1fr;
  }

  .public-section {
    padding: 54px 18px;
  }

  .section-copy h2 {
    font-size: 28px;
  }

  .post-main {
    padding-top: 74px;
  }
}

@media (max-width: 1280px) and (orientation: landscape) {
  .public-nav {
    gap: 12px;
  }

  .public-hero-copy h1,
  .post-hero h1 {
    font-size: 48px;
  }
}
