:root {
  --bg: #f5f7fb;
  --bg-deep: #0f172a;
  --panel: #ffffff;
  --panel-soft: #f8fafc;
  --text: #0f172a;
  --muted: #64748b;
  --line: #e2e8f0;
  --blue: #2563eb;
  --blue-soft: #dbeafe;
  --green: #16a34a;
  --green-soft: #dcfce7;
  --amber: #f59e0b;
  --amber-soft: #fef3c7;
  --red: #dc2626;
  --red-soft: #fee2e2;
  --purple: #7c3aed;
  --shadow: 0 22px 60px rgba(15, 23, 42, 0.12);
  --radius: 24px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(37, 99, 235, 0.16), transparent 32%),
    radial-gradient(circle at bottom right, rgba(124, 58, 237, 0.12), transparent 30%),
    var(--bg);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

button,
textarea,
input,
select { font: inherit; }

button { cursor: pointer; }

.hidden,
.is-hidden { display: none !important; }

.login-screen {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 100vh;
  padding: 24px;
  overflow: hidden;
}

.orb {
  position: absolute;
  width: 440px;
  height: 440px;
  border-radius: 50%;
  filter: blur(14px);
  opacity: 0.32;
}

.orb-one {
  top: -130px;
  left: -120px;
  background: radial-gradient(circle, rgba(37, 99, 235, 0.7), transparent 68%);
}

.orb-two {
  right: -140px;
  bottom: -140px;
  background: radial-gradient(circle, rgba(124, 58, 237, 0.55), transparent 68%);
}

.login-card {
  position: relative;
  z-index: 1;
  width: min(560px, 100%);
  padding: 44px;
  border: 1px solid rgba(226, 232, 240, 0.82);
  border-radius: 34px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 62px;
  height: 62px;
  color: white;
  font-weight: 950;
  border-radius: 22px;
  background: linear-gradient(135deg, var(--blue), var(--purple));
  box-shadow: 0 18px 36px rgba(37, 99, 235, 0.24);
}

.brand-mark.small {
  width: 44px;
  height: 44px;
  border-radius: 16px;
  font-size: 13px;
}

.eyebrow {
  margin: 20px 0 8px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

h1, h2, h3, p { margin-top: 0; }

h1 {
  margin-bottom: 10px;
  font-size: clamp(30px, 4vw, 50px);
  letter-spacing: -0.045em;
  line-height: 1.02;
}

h3 {
  margin-bottom: 16px;
  font-size: 18px;
}

.muted,
.hint,
.muted-small {
  color: var(--muted);
  line-height: 1.55;
}

.muted-small { font-size: 13px; }

.login-row {
  display: flex;
  gap: 12px;
  margin-top: 26px;
}

input,
textarea,
select {
  width: 100%;
  min-width: 0;
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 14px;
  background: white;
  outline: none;
}

input,
select { padding: 13px 14px; }
textarea { padding: 13px 14px; resize: vertical; }

input:focus,
textarea:focus,
select:focus {
  border-color: rgba(37, 99, 235, 0.7);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

.login-row button,
.primary-btn,
.composer button {
  border: 0;
  color: white;
  font-weight: 800;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--blue), var(--purple));
  box-shadow: 0 14px 28px rgba(37, 99, 235, 0.18);
}

.login-row button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 24px;
  white-space: nowrap;
}


.login-welcome-agent {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 24px;
  padding: 14px;
  border: 1px solid rgba(219, 228, 240, 0.95);
  border-radius: 22px;
  background:
    radial-gradient(circle at 96% 18%, rgba(124, 58, 237, 0.12), transparent 34%),
    rgba(248, 251, 255, 0.92);
}

.login-welcome-agent img {
  flex: 0 0 auto;
  width: 64px;
  height: 64px;
  border-radius: 22px;
  object-fit: cover;
  object-position: center;
  border: 1px solid rgba(37, 99, 235, 0.18);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
}

.login-welcome-agent strong {
  display: block;
  margin-bottom: 4px;
  font-size: 17px;
}

.login-welcome-agent span {
  display: block;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.app {
  display: grid;
  grid-template-columns: 292px 1fr;
  min-height: 100vh;
}

.sidebar {
  position: sticky;
  top: 0;
  display: flex;
  flex-direction: column;
  gap: 22px;
  height: 100vh;
  padding: 22px;
  color: white;
  overflow-y: auto;
  overscroll-behavior: contain;
  background:
    linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(30, 41, 59, 0.98)),
    var(--bg-deep);
}

.sidebar::-webkit-scrollbar { width: 8px; }
.sidebar::-webkit-scrollbar-track { background: rgba(255,255,255,0.04); }
.sidebar::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.38);
}

.logo-row {
  display: flex;
  align-items: center;
  gap: 13px;
}

.logo-row strong { display: block; font-size: 17px; }
.logo-row span, .system-card span { display: block; color: #94a3b8; font-size: 13px; }

.nav { display: grid; gap: 8px; }

.nav-item {
  width: 100%;
  padding: 13px 14px;
  color: #cbd5e1;
  text-align: left;
  border: 1px solid transparent;
  border-radius: 15px;
  background: transparent;
}

.nav-item:hover,
.nav-item.active {
  color: white;
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.085);
}

.system-card {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: auto;
  padding: 15px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.07);
}

.status-dot {
  flex: 0 0 auto;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: var(--green);
  box-shadow: 0 0 0 8px rgba(22, 163, 74, 0.14);
}

.status-dot.warning {
  background: var(--amber);
  box-shadow: 0 0 0 8px rgba(245, 158, 11, 0.16);
}

.status-dot.danger {
  background: var(--red);
  box-shadow: 0 0 0 8px rgba(220, 38, 38, 0.15);
}

.sidebar-link {
  color: #cbd5e1;
  text-align: left;
  border: 0;
  background: transparent;
}

.workspace {
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  gap: 18px;
  min-width: 0;
  padding: 28px;
}

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

.topbar .eyebrow { margin-top: 0; }

.top-actions {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.top-menu-wrap {
  position: relative;
  z-index: 40;
}

.top-menu-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-weight: 900;
}

.top-menu-btn[aria-expanded="true"] {
  color: white;
  border-color: transparent;
  background: linear-gradient(135deg, var(--blue), var(--purple));
  box-shadow: 0 14px 26px rgba(37, 99, 235, 0.16);
}

.top-menu-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  display: grid;
  grid-template-columns: repeat(7, minmax(98px, 1fr));
  gap: 8px;
  width: min(920px, calc(100vw - 72px));
  padding: 12px;
  border: 1px solid rgba(219, 228, 240, 0.95);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.17);
  backdrop-filter: blur(16px);
}

.top-nav-item {
  min-height: 48px;
  padding: 10px 11px;
  color: #334155;
  text-align: left;
  font-size: 13px;
  font-weight: 850;
  border: 1px solid #dbe4f0;
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  cursor: pointer;
}

.top-nav-item:hover,
.top-nav-item.active {
  color: #1d4ed8;
  border-color: rgba(37, 99, 235, 0.28);
  background: #eff6ff;
  box-shadow: 0 10px 22px rgba(37, 99, 235, 0.10);
}

.ghost-btn,
.primary-btn,
.tiny-btn {
  padding: 11px 14px;
  border-radius: 13px;
}

.ghost-btn {
  color: var(--text);
  border: 1px solid var(--line);
  background: white;
}

.ghost-btn.wide { width: 100%; margin-top: 8px; }

.tiny-btn {
  padding: 8px 10px;
  color: var(--text);
  font-size: 13px;
  font-weight: 750;
  border: 1px solid var(--line);
  background: white;
}

.tiny-btn.primary {
  color: white;
  border-color: transparent;
  background: var(--blue);
}

button:disabled { opacity: 0.62; cursor: wait; }

.page-comment-card,
.card,
.loading-card,
.notice,
.empty-state {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 16px 44px rgba(15, 23, 42, 0.06);
}

.page-comment-card { padding: 16px; }

.comment-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.page-comment-card textarea {
  min-height: 70px;
  background: var(--panel-soft);
}

.notice-area:empty { display: none; }

.notice {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 16px;
}

.notice.warning { border-color: #fde68a; background: var(--amber-soft); }
.notice.success { border-color: #bbf7d0; background: var(--green-soft); }
.notice.danger,
.notice.error { border-color: #fecaca; background: var(--red-soft); }

.page-content { display: grid; gap: 18px; }

.loading-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 22px;
  color: var(--muted);
}

.loader {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 3px solid var(--line);
  border-top-color: var(--blue);
  animation: spin 0.9s linear infinite;
}

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

.summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.dashboard-stats-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  margin-bottom: 18px;
}

.dashboard-stats-grid .card {
  padding: 18px;
}

.two-column {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.55fr);
  gap: 18px;
}

.two-column.wide-left { grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.55fr); }

.card { padding: 20px; min-width: 0; }

.metric {
  display: block;
  font-size: 42px;
  line-height: 1;
  letter-spacing: -0.04em;
}

.card > span,
.metric + span { color: var(--muted); }

.site-list,
.compact-list,
.task-list,
.workflow-grid,
.mini-tasks {
  display: grid;
  gap: 10px;
}

.site-card,
.compact-row,
.task-row,
.workflow-site {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--panel-soft);
}

.site-card,
.workflow-site { padding: 14px; }

.site-head,
.compact-row,
.task-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.site-head span,
.compact-row span,
.row-meta {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}

.site-tags { display: flex; flex-wrap: wrap; gap: 6px; justify-content: flex-end; }

.pill {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 4px 9px;
  color: #334155;
  font-size: 12px;
  font-weight: 800;
  border-radius: 999px;
  background: #e2e8f0;
}

.pill.hot { color: #9a3412; background: #fed7aa; }

.compact-row,
.task-row { padding: 13px; }

.task-row.done .row-title { text-decoration: line-through; color: var(--muted); }

.task-row p,
.delivery-row p {
  margin: 8px 0 0;
  color: #475569;
  font-size: 14px;
  line-height: 1.45;
}

.row-title { font-weight: 800; }
.row-actions { flex: 0 0 auto; }

.stack-form { display: grid; gap: 12px; }
.stack-form label { display: grid; gap: 7px; color: var(--muted); font-size: 13px; font-weight: 750; }

.empty-state {
  display: grid;
  gap: 6px;
  padding: 18px;
  color: var(--muted);
  background: var(--panel-soft);
}

.empty-state strong { color: var(--text); }

.agent-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 18px;
  min-height: 580px;
}

.chat-panel {
  display: grid;
  grid-template-rows: 1fr auto;
  min-height: 580px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: white;
  box-shadow: var(--shadow);
}

.chat-log {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
  padding: 20px;
  overflow: auto;
}

.message {
  display: flex;
  gap: 10px;
  max-width: 920px;
}

.message.user {
  align-self: flex-end;
  flex-direction: row-reverse;
}

.avatar {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  color: white;
  font-size: 12px;
  font-weight: 900;
  border-radius: 14px;
  background: var(--blue);
}

.message.user .avatar,
.user-avatar { background: var(--amber); }

.agent-avatar,
.agent-profile-avatar {
  overflow: hidden;
  background: linear-gradient(135deg, #e0ecff, #f4f0ff);
  border: 1px solid rgba(37, 99, 235, 0.18);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.10);
}

.agent-avatar img,
.agent-profile-avatar img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.agent-avatar-helper img { object-position: center 24%; }
.agent-avatar-workflow img { object-position: center 22%; }
.agent-avatar-spravka img { object-position: center 20%; }

.agent-profile {
  display: flex;
  align-items: center;
  gap: 13px;
  padding: 13px;
  border: 1px solid rgba(219, 228, 240, 0.95);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(239, 246, 255, 0.92), rgba(245, 243, 255, 0.92));
}

.agent-profile-avatar {
  flex: 0 0 auto;
  width: 72px;
  height: 72px;
  border-radius: 24px;
}

.agent-profile strong {
  display: block;
  color: var(--text);
  font-size: 15px;
  line-height: 1.2;
}

.agent-profile span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
  line-height: 1.35;
}

.agent-profile-helper .agent-profile-avatar img { object-position: center 24%; }
.agent-profile-workflow .agent-profile-avatar img { object-position: center 21%; }
.agent-profile-spravka .agent-profile-avatar img { object-position: center 19%; }

.bubble {
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--panel-soft);
  line-height: 1.58;
}

.message.user .bubble { background: var(--blue-soft); }
.bubble p { margin: 0; }

.composer {
  display: flex;
  gap: 12px;
  padding: 16px;
  border-top: 1px solid var(--line);
  background: var(--panel-soft);
}

.composer textarea { min-height: 54px; max-height: 180px; resize: vertical; }
.composer button { min-width: 126px; }

.agent-help {
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: white;
}

.agent-help button {
  padding: 12px;
  text-align: left;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel-soft);
}

.agent-help p {
  margin-top: 10px;
  color: var(--muted);
  line-height: 1.5;
}

@media (max-width: 1120px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { position: static; height: auto; }
  .nav { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .top-menu-dropdown { grid-template-columns: repeat(3, minmax(0, 1fr)); width: min(640px, calc(100vw - 36px)); }
  .summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .two-column,
  .two-column.wide-left,
  .agent-layout { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  .workspace { padding: 18px; }
  .nav { grid-template-columns: 1fr; }
  .summary-grid { grid-template-columns: 1fr; }
  .topbar,
  .login-row,
  .composer { flex-direction: column; align-items: stretch; }
  .top-actions { width: 100%; }
  .top-actions > button,
  .top-menu-wrap,
  .top-menu-btn { width: 100%; }
  .top-menu-dropdown { right: auto; left: 0; grid-template-columns: repeat(2, minmax(0, 1fr)); width: 100%; }
}

/* Stage J: site links, SeRanking line and collapsible tasks */
.site-main-info {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.site-title-link {
  color: var(--text);
  text-decoration: none;
  font-weight: 900;
}

.site-title-link:hover {
  color: var(--blue);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.site-link-row {
  display: inline-flex;
  width: fit-content;
  color: var(--blue);
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
}

.site-link-row:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.site-link-row.muted-small {
  color: var(--muted);
  font-weight: 700;
}

.site-tasks-details {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.site-tasks-details summary {
  width: fit-content;
  color: var(--blue);
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
  list-style: none;
}

.site-tasks-details summary::-webkit-details-marker {
  display: none;
}

.site-tasks-details summary::after {
  content: ' ↓';
}

.site-tasks-details[open] summary::after {
  content: ' ↑';
}

.site-tasks-details .mini-tasks {
  margin-top: 10px;
}

textarea[data-autogrow] {
  min-height: 86px;
  overflow: hidden;
  resize: none;
}

.wide-input {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--text);
  outline: none;
}

.wide-input:focus {
  border-color: rgba(37, 99, 235, 0.5);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

.mini-chat-log {
  min-height: 120px;
  max-height: 260px;
  padding: 14px 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.task-work-control {
  display: grid;
  gap: 7px;
  justify-items: end;
  min-width: 160px;
}

.work-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  color: #9a4b00;
  font-size: 12px;
  font-weight: 900;
  background: #ffe1b5;
}

.tiny-btn.work {
  color: #9a4b00;
  background: #ffb454;
}

.tiny-btn.work:hover {
  filter: brightness(0.98);
}

.assignee-select {
  width: 190px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--text);
  background: var(--panel-soft);
  outline: none;
}

.assignee-select.is-hidden {
  display: none;
}

.redirect-acceptor-label {
  display: grid;
  gap: 5px;
  min-width: 240px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-align: left;
}

.redirect-acceptor-input {
  width: 100%;
  padding: 9px 11px;
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--text);
  background: var(--panel-soft);
  outline: none;
}

.redirect-acceptor-input:focus {
  border-color: rgba(37, 99, 235, 0.5);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

.site-geo-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
  color: #334155;
  font-size: 13px;
  font-weight: 750;
}

.site-geo-row span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 9px;
  border-radius: 999px;
  background: #eef6ff;
  border: 1px solid #dbeafe;
}

.site-geo-row.is-unknown span {
  color: #64748b;
  background: #f1f5f9;
  border-color: #e2e8f0;
}

.site-inline-action {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-top: 8px;
  padding: 6px 10px;
  border: 1px solid #dbeafe;
  border-radius: 999px;
  background: #ffffff;
  color: #2563eb;
  cursor: pointer;
  font-size: 13px;
  font-weight: 850;
}

.site-inline-action:hover {
  background: #eff6ff;
}

.site-inline-action:disabled {
  cursor: wait;
  opacity: 0.65;
}

.site-geo-line {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.inline-action {
  border: 0;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 800;
  color: #2563eb;
  background: rgba(37, 99, 235, 0.1);
  cursor: pointer;
}

.inline-action:hover {
  background: rgba(37, 99, 235, 0.16);
}

.inline-action:disabled {
  opacity: 0.65;
  cursor: wait;
}


.geo-group-list {
  display: grid;
  gap: 18px;
}

.geo-group {
  display: grid;
  gap: 12px;
}

.geo-group-title {
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  color: var(--text);
  letter-spacing: -0.02em;
}

.language-group {
  display: grid;
  gap: 10px;
  padding-left: 10px;
  border-left: 3px solid rgba(37, 99, 235, 0.16);
}

.language-group-title {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.site-list.grouped {
  gap: 10px;
}

.grouped-workflows .geo-group-list,
.grouped-workflows .geo-group,
.grouped-workflows .language-group {
  gap: 10px;
}

.site-geo-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.compact-select {
  max-width: 220px;
  padding: 8px 10px;
  color: var(--text);
  font-weight: 800;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
  outline: none;
}

.compact-select:focus {
  border-color: rgba(37, 99, 235, 0.7);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

.work-status.assigned {
  color: #166534;
  background: #bbf7d0;
  border: 1px solid #86efac;
}

.gwt-task-info,
.gwt-followup {
  display: grid;
  gap: 8px;
  width: fit-content;
  margin-top: 10px;
  padding: 10px 12px;
  border: 1px solid #bbf7d0;
  border-radius: 14px;
  color: #166534;
  background: #f0fdf4;
  font-size: 13px;
  font-weight: 800;
}

.gwt-followup span,
.gwt-task-info span {
  color: #166534;
}

.gwt-followup-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.gwt-owner-select {
  background: #ffffff;
}

.site-services-panel {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  padding: 12px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 16px;
  background: rgba(248, 250, 252, 0.72);
}

.site-service-row {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.site-service-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.site-service-summary strong {
  color: var(--text);
}

.site-service-controls {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.service-provider-select,
.service-employee-select {
  min-width: 180px;
}

@media (max-width: 900px) {
  .site-service-row {
    grid-template-columns: 1fr;
  }

  .site-service-controls {
    justify-content: flex-start;
  }
}

.workflow-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 24px;
  align-items: start;
}

.workflow-main {
  display: grid;
  gap: 22px;
}

.workflow-board {
  display: grid;
  gap: 18px;
}

.workflow-board-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.workflow-board-head h3 {
  margin: 0;
}

.workflow-steps-box,
.workflow-sites-box {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(255,255,255,0.45);
}

.workflow-steps {
  margin: 0;
  padding-left: 22px;
  line-height: 1.7;
}

.workflow-steps li {
  margin: 4px 0;
}

.workflow-steps .muted-step {
  opacity: 0.55;
  text-decoration: line-through;
}

.workflow-task-list {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.workflow-other-tasks {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px dashed var(--line);
  display: grid;
  gap: 10px;
}

.workflow-agent-card {
  position: sticky;
  top: 22px;
  display: grid;
  gap: 14px;
}

.workflow-chat-log {
  display: grid;
  gap: 10px;
  min-height: 260px;
  max-height: 460px;
  overflow: auto;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(241, 245, 249, 0.55);
}

.workflow-message {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  max-width: 100%;
}

.workflow-message.user {
  justify-self: end;
  flex-direction: row-reverse;
}

.workflow-message.user .bubble {
  background: rgba(37, 99, 235, 0.12);
}

.workflow-message.agent .bubble {
  background: rgba(255, 255, 255, 0.75);
}

.workflow-composer {
  display: grid;
  gap: 10px;
}

.workflow-composer textarea {
  width: 100%;
  resize: vertical;
  min-height: 96px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  outline: none;
  background: rgba(255,255,255,0.75);
}

.workflow-composer textarea:focus {
  border-color: rgba(37, 99, 235, 0.55);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

@media (max-width: 1200px) {
  .workflow-layout {
    grid-template-columns: 1fr;
  }
  .workflow-agent-card {
    position: static;
  }
}

.site-services-details {
  margin-top: 14px;
  border-top: 1px solid var(--border, #dbe5f3);
  padding-top: 12px;
}

.site-services-details > summary {
  cursor: pointer;
  color: var(--blue, #2563eb);
  font-weight: 900;
  list-style: none;
}

.site-services-details > summary::-webkit-details-marker {
  display: none;
}

.site-services-details > summary::after {
  content: ' ↓';
}

.site-services-details[open] > summary::after {
  content: ' ↑';
}

.site-service-row {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid var(--border, #dbe5f3);
  border-radius: 16px;
  background: rgba(248, 251, 255, 0.78);
}

.site-service-controls {
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.mini-control {
  display: grid;
  gap: 6px;
  color: var(--muted, #64748b);
  font-size: 13px;
  font-weight: 800;
}

.compact-input {
  width: 100%;
  min-height: 40px;
  padding: 10px 12px;
  border: 1px solid var(--border, #dbe5f3);
  border-radius: 12px;
  background: white;
  color: var(--text, #0f172a);
  font-weight: 700;
}

.gwt-followup span {
  display: block;
  margin-top: 4px;
}

@media (max-width: 980px) {
  .site-service-controls {
    grid-template-columns: 1fr;
  }
}

/* Reference / provider directories */
.reference-layout {
  display: grid;
  gap: 22px;
}

.reference-intro p {
  margin: 8px 0 0;
  color: var(--muted, #64748b);
}

.reference-provider-box {
  display: grid;
  gap: 16px;
}

.reference-box-head h3 {
  margin-bottom: 6px;
}

.reference-add-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.reference-add-form input,
.reference-provider-name {
  width: 100%;
  min-height: 46px;
  padding: 12px 14px;
  border: 1px solid var(--line, #dbe4f0);
  border-radius: 14px;
  background: #fff;
  color: var(--text, #0f172a);
  font-weight: 700;
}

.primary-btn.compact {
  min-height: 46px;
  padding: 0 18px;
}

.reference-provider-list {
  display: grid;
  gap: 10px;
}

.reference-provider-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line, #dbe4f0);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.76);
}

.tiny-btn.danger {
  background: #fee2e2;
  color: #b91c1c;
  border-color: #fecaca;
}

@media (max-width: 760px) {
  .reference-add-form,
  .reference-provider-row {
    grid-template-columns: 1fr;
  }
}

/* Site status dropdowns */
.site-status-controls {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.status-control-label {
  display: grid;
  gap: 4px;
  min-width: 155px;
}

.status-control-label > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.status-select {
  min-width: 155px;
  font-weight: 900;
}

.priority-select {
  background: #fff7ed;
  color: #9a3412;
}

.seo-select {
  background: #eef2f7;
  color: #52647c;
}

@media (max-width: 760px) {
  .site-status-controls {
    justify-content: flex-start;
  }

  .status-control-label,
  .status-select {
    min-width: 100%;
  }
}

/* Stage AI: inline external link editing */
.site-link-edit-wrap {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
}

.link-edit-button {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  text-align: left;
}

.link-edit-button:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.site-link-open {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  color: var(--blue);
  background: rgba(37, 99, 235, 0.10);
  text-decoration: none;
  font-size: 12px;
  font-weight: 900;
}

.site-link-open:hover {
  background: rgba(37, 99, 235, 0.16);
}

.task-site-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
}

.task-site-link {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  color: var(--link, #2563eb);
  font-weight: 800;
  text-decoration: none;
}

.task-site-link:hover {
  text-decoration: underline;
}

.task-site-link.muted {
  color: var(--muted, #64748b);
  text-decoration: none;
}

.inline-site-task-create {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line, #e2e8f0);
}

.compact-task-form {
  margin-top: 10px;
  max-width: 720px;
}

.compact-task-form .tiny-btn {
  width: fit-content;
}

/* Stage AK: task deletion + persistent redirect acceptor */
.tiny-btn.danger {
  background: #fee2e2;
  color: #991b1b;
  border-color: #fecaca;
}

.tiny-btn.danger:hover {
  background: #fecaca;
}

.redirect-acceptor-input.is-saved {
  border-color: #22c55e;
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.16);
}

/* Stage AL: priority/SEO colors, sites filters, multi GEO controls */
.status-select.status-priority-green {
  color: #047857;
  background: #dcfce7;
  border-color: #86efac;
}

.status-select.status-priority-gray {
  color: #64748b;
  background: #f1f5f9;
  border-color: #cbd5e1;
}

.status-select.status-seo-green {
  color: #047857;
  background: #dcfce7;
  border-color: #86efac;
}

.status-select.status-seo-olive {
  color: #3f6212;
  background: #ecfccb;
  border-color: #bef264;
}

.filters-card {
  margin-bottom: 18px;
}

.site-filters-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: end;
}

.site-filters-row label {
  display: grid;
  gap: 6px;
  min-width: 220px;
  color: #64748b;
  font-weight: 800;
  font-size: 13px;
}

.multi-geo-controls {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.geo-language-row {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.geo-language-row .compact-select {
  min-width: 180px;
}

.danger-icon-btn {
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 12px;
  background: #fee2e2;
  color: #b91c1c;
  cursor: pointer;
  font-weight: 900;
}

.danger-icon-btn:hover {
  background: #fecaca;
}

.geo-group-title:first-letter {
  text-transform: uppercase;
}

/* stage_am: workflow/site UX */
.compact-task-list {
  display: grid;
  gap: 12px;
}
.inline-site-workflow-create,
.inline-site-task-create {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.workflow-add-site-form {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(240px, .8fr) auto;
  gap: 12px;
  align-items: end;
  margin: 14px 0 18px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.04);
}
.workflow-add-site-form label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-weight: 800;
}
.workflow-add-site-form input,
.workflow-add-site-form select {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--card-soft, rgba(255,255,255,.7));
}
@media (max-width: 860px) {
  .workflow-add-site-form {
    grid-template-columns: 1fr;
  }
}

/* Stage AN: reference agent and important pages */
.reference-agent-card .mini-chat-log,
#referenceChatLog {
  min-height: 180px;
  max-height: 360px;
  overflow: auto;
}

.compact-composer {
  margin-top: 14px;
}

.reference-menu-card summary,
.reference-menu-details summary,
.site-pages-details summary {
  cursor: pointer;
  color: #2563eb;
  font-weight: 900;
}

.reference-menu-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}

.reference-menu-list a {
  display: inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(37, 99, 235, .1);
  color: #2563eb;
  font-weight: 800;
  text-decoration: none;
}

.reference-custom-list {
  display: grid;
  gap: 18px;
}

.reference-custom-head {
  display: grid;
  gap: 12px;
}

.reference-create-section-form,
.reference-add-item-form,
.inline-page-form {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.reference-create-section-form input,
.reference-add-item-form input,
.inline-page-form input,
.reference-section-title,
.reference-item-title,
.reference-item-link,
.reference-section-content,
.reference-item-value {
  border: 1px solid var(--line, #d9e2f1);
  border-radius: 14px;
  padding: 12px 14px;
  background: #fff;
  color: var(--text, #0f172a);
}

.reference-create-section-form input,
.reference-add-item-form input,
.inline-page-form input {
  flex: 1 1 280px;
}

.reference-custom-section {
  scroll-margin-top: 24px;
}

.reference-section-head {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.reference-section-title {
  flex: 1 1 320px;
  font-size: 18px;
  font-weight: 900;
}

.reference-section-content {
  width: 100%;
  resize: vertical;
  line-height: 1.55;
}

.reference-items-list {
  display: grid;
  gap: 12px;
  margin: 14px 0;
}

.reference-item-row {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid var(--line, #d9e2f1);
  border-radius: 18px;
  background: rgba(248, 250, 252, .78);
}

.reference-item-actions,
.important-page-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.site-pages-details {
  margin-top: 14px;
  border-top: 1px solid var(--line, #d9e2f1);
  padding-top: 14px;
}

.site-pages-panel {
  margin-top: 14px;
}

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

.site-pages-column {
  padding: 16px;
  border: 1px solid var(--line, #d9e2f1);
  border-radius: 18px;
  background: rgba(255, 255, 255, .7);
}

.important-pages-list {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.important-page-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line, #d9e2f1);
  border-radius: 16px;
  background: #fff;
}

.important-page-main {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.important-page-main a {
  font-weight: 900;
  color: #2563eb;
  word-break: break-word;
}

.danger-soft {
  color: #b91c1c;
  background: #fee2e2;
}

@media (max-width: 900px) {
  .site-pages-grid {
    grid-template-columns: 1fr;
  }
}

/* Stage AN: Reference agent + site pages */
.reference-menu-details,
.site-pages-details {
  border-top: 1px solid var(--line);
  margin-top: 14px;
  padding-top: 12px;
}
.reference-menu-details summary,
.site-pages-details summary {
  cursor: pointer;
  color: var(--blue);
  font-weight: 900;
}
.reference-menu-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.reference-menu-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel-soft);
}
.reference-menu-item a {
  color: var(--blue);
  text-decoration: none;
  font-weight: 800;
}
.reference-section-card { scroll-margin-top: 24px; }
.reference-section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 12px;
}
.reference-section-title-input,
.reference-content-input,
.reference-item-row input,
.reference-add-form input,
.reference-add-item-form input,
.inline-page-form input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 14px;
  background: #fff;
  color: var(--text);
  font-weight: 800;
}
.reference-content-input {
  min-height: 120px;
  font-weight: 500;
  resize: vertical;
}
.reference-section-actions,
.reference-add-form,
.reference-add-item-form,
.reference-item-row,
.inline-page-form {
  display: flex;
  gap: 10px;
  align-items: center;
}
.reference-item-row {
  margin: 8px 0;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel-soft);
}
.drag-hint { color: var(--muted); font-weight: 900; cursor: grab; }
.is-dragging { opacity: .55; }
.is-soft-hidden { display: none; }
.site-pages-panel {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 14px;
}
.site-pages-column {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.55);
  padding: 14px;
}
.site-pages-column h4 { margin: 0 0 8px; }
.important-page-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.important-page-main { display: grid; gap: 4px; min-width: 0; }
.important-page-main a { color: var(--blue); font-weight: 900; word-break: break-word; }
.important-page-actions { display: flex; gap: 8px; align-items: center; flex: 0 0 auto; }
.inline-page-form { margin-top: 12px; flex-wrap: wrap; }
.inline-page-form input { min-width: 260px; flex: 1; }
.readonly-seo-status small { display: block; color: var(--muted); margin-top: 4px; }
.seo-readonly-badge {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 14px;
  border-radius: 14px;
  font-weight: 900;
  background: var(--panel-soft);
  border: 1px solid var(--line);
}
@media (max-width: 980px) {
  .site-pages-panel { grid-template-columns: 1fr; }
  .reference-section-head,
  .reference-section-actions,
  .reference-add-form,
  .reference-add-item-form,
  .reference-item-row,
  .inline-page-form { flex-direction: column; align-items: stretch; }
}

/* Stage AO: Sites panel quick creation */
.sites-quick-create-block {
  margin-bottom: 18px;
}

/* Stage AQ: lazy GEO browser and snapshots */
.site-card.collapsed-site-card {
  padding: 0;
  overflow: hidden;
}

.site-card.collapsed-site-card > summary,
.geo-group-summary {
  list-style: none;
  cursor: pointer;
}

.site-card.collapsed-site-card > summary::-webkit-details-marker,
.geo-group-summary::-webkit-details-marker,
.collapsed-create-card > summary::-webkit-details-marker {
  display: none;
}

.site-card-summary {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 16px;
}

.site-summary-title {
  display: grid;
  gap: 8px;
}

.site-card-body {
  padding: 0 16px 16px;
}

.site-card:not([open]) .site-card-summary:hover,
.geo-group-summary:hover,
.collapsed-create-card > summary:hover {
  background: rgba(37, 99, 235, 0.035);
}

.geo-group {
  border-radius: 16px;
}

.geo-group-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.36);
}

.geo-group-count {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  margin-left: auto;
}

.geo-snapshot-link {
  border: 0;
  color: #2563eb;
  background: #dbeafe;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.lazy-geo-content {
  padding: 12px;
}

.collapsed-create-card {
  margin-bottom: 18px;
}

.collapsed-create-card > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--panel);
  font-size: 18px;
  font-weight: 900;
  cursor: pointer;
}

.collapsed-create-card[open] > summary {
  margin-bottom: 12px;
}

.snapshot-grid {
  display: grid;
  gap: 18px;
}

.snapshot-search-card {
  margin-bottom: 18px;
}

.site-snapshot-search {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) auto;
  gap: 12px;
  margin-top: 12px;
}

.site-snapshot-search input {
  width: 100%;
  padding: 13px 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  font-weight: 800;
}

.snapshot-search-results {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.tiny-btn.ghost {
  width: fit-content;
  color: #2563eb;
  background: #dbeafe;
}

.summary-controls {
  min-width: 280px;
}

@media (max-width: 900px) {
  .site-card-summary,
  .site-snapshot-search {
    grid-template-columns: 1fr;
    display: grid;
  }
  .summary-controls {
    min-width: 0;
  }
}


/* Stage AR: brand sites, special GEO groups, reference entities */
.brand-sites-zone {
  margin-top: 14px;
  padding: 12px 14px;
  border: 1px dashed #c9d7ee;
  border-radius: 16px;
  background: rgba(99, 102, 241, 0.04);
}

.brand-sites-zone > summary,
.brand-group > summary,
.brand-site-details > summary {
  cursor: pointer;
  font-weight: 800;
  color: #2563eb;
}

.brand-site-panel,
.reference-entity-row {
  display: grid;
  gap: 12px;
  margin-top: 10px;
}

.brand-site-flag-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 800;
}

.brand-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.brand-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 999px;
  background: #eef2ff;
  color: #1e3a8a;
  font-weight: 800;
}

.inline-brand-add {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.brand-hub-list .brand-group {
  margin: 14px 0;
  padding: 12px;
  border: 1px solid #dbe5f4;
  border-radius: 18px;
  background: rgba(255,255,255,0.64);
}

.special-geo-group .geo-group-title {
  color: #0f172a;
}

.reference-entity-row {
  grid-template-columns: minmax(120px, 0.8fr) minmax(180px, 1.4fr) minmax(80px, 0.5fr) auto auto;
  align-items: center;
}

.reference-entity-row input {
  width: 100%;
}

@media (max-width: 900px) {
  .reference-entity-row,
  .inline-brand-add {
    grid-template-columns: 1fr;
  }
}


.card-title-link {
  border: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  font-weight: 900;
  cursor: pointer;
  text-align: left;
}
.card-title-link:hover { color: #2563eb; text-decoration: underline; }

.site-search-row {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) auto;
  gap: 12px;
  align-items: end;
  margin: 14px 0 16px;
}
.site-search-row label { display: grid; gap: 6px; font-weight: 800; color: #64748b; }
.site-search-row input {
  width: 100%;
  border: 1px solid #dbe5f2;
  border-radius: 16px;
  padding: 13px 14px;
  background: #fff;
  color: #0f172a;
  font-weight: 700;
}

.workflow-compact-row {
  display: block;
  padding: 0;
}
.workflow-compact-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  cursor: pointer;
  list-style: none;
}
.workflow-compact-summary::-webkit-details-marker { display: none; }
.workflow-inline-tasks {
  border-top: 1px solid #e2e8f0;
  margin: 0 16px 14px;
  padding-top: 12px;
}

.site-free-comment {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid #dbe5f2;
}
.site-free-comment-title {
  font-weight: 900;
  color: #0f172a;
  margin-bottom: 8px;
}
.site-free-comment-visible {
  padding: 12px 14px;
  border: 1px solid #dbe5f2;
  border-radius: 14px;
  background: rgba(255,255,255,.72);
  color: #334155;
  line-height: 1.55;
  margin-bottom: 10px;
}
.site-free-comment-editor {
  display: grid;
  gap: 8px;
}
.site-free-comment-editor textarea {
  width: 100%;
  border: 1px solid #dbe5f2;
  border-radius: 14px;
  padding: 12px 14px;
  resize: vertical;
  min-height: 72px;
}
@media (max-width: 720px) {
  .site-search-row { grid-template-columns: 1fr; }
}

/* Stage AU — Links tasks */
.link-task-form textarea,
.placed-links-label textarea {
  width: 100%;
  min-height: 110px;
  resize: vertical;
}
.link-task-extra {
  display: grid;
  gap: 10px;
  margin-top: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(59, 130, 246, 0.05);
}
.placed-links-label {
  display: grid;
  gap: 8px;
  font-weight: 800;
  color: var(--muted);
}
.placed-links-box {
  display: grid;
  gap: 6px;
  max-height: 260px;
  overflow: auto;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.04);
  white-space: pre-wrap;
}
.placed-links-box a {
  color: var(--blue);
  font-weight: 800;
  text-decoration: none;
  word-break: break-all;
}
.placed-links-box a:hover {
  text-decoration: underline;
}
.site-link-tasks-block,
.site-placed-links-details {
  margin-top: 14px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}
.site-link-tasks-block summary,
.site-placed-links-details summary {
  cursor: pointer;
  color: var(--blue);
  font-weight: 900;
}
textarea.is-saved,
.redirect-acceptor-input.is-saved {
  outline: 2px solid rgba(34, 197, 94, 0.35);
}

/* Stage AV — placed links only in Site Snapshot */
.snapshot-placed-links-panel {
  display: grid;
  gap: 16px;
}
.snapshot-link-task-sources,
.snapshot-manual-links-editor,
.snapshot-placed-links-total {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.045);
}
.snapshot-link-source-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(59, 130, 246, 0.045);
}
.snapshot-link-source-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.snapshot-placed-links-panel textarea {
  width: 100%;
  min-height: 120px;
  resize: vertical;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  outline: none;
  background: white;
  color: var(--text);
}
.snapshot-placed-links-panel textarea:focus {
  border-color: rgba(37, 99, 235, 0.55);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.1);
}
.site-card .site-placed-links-details {
  display: none;
}

/* BBP Upgrades + task filters */
.filters-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  gap: 12px;
  align-items: end;
}

.filters-grid label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

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

.upgrade-page {
  display: grid;
  gap: 18px;
}

.upgrade-page-centered {
  max-width: 1480px;
  margin: 0 auto;
}

.upgrade-middle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}

.delivery-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}

.upgrade-metrics {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.metric-card {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(241,245,249,0.78));
}

.metric-card span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.35;
}

.metric-card strong {
  display: block;
  margin-top: 10px;
  font-size: 28px;
  letter-spacing: -0.04em;
}

.upgrade-edit-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px 130px;
  gap: 8px;
  width: min(100%, 760px);
}

.upgrade-idea-row,
.upgrade-reference-row {
  display: grid;
  gap: 10px;
}

.upgrade-reference-row input,
.upgrade-reference-row textarea,
.upgrade-idea-row textarea {
  width: min(100%, 760px);
}

.inline-actions {
  display: flex;
  justify-content: flex-start;
  gap: 8px;
}

.snapshot-workflow-list {
  display: grid;
  gap: 12px;
}

.snapshot-workflow-site {
  background: rgba(248, 250, 252, 0.9);
}

@media (max-width: 1200px) {
  .filters-grid,
  .upgrade-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .filters-grid,
  .upgrade-metrics,
  .upgrade-middle-grid,
  .upgrade-edit-grid {
    grid-template-columns: 1fr;
  }

  .delivery-actions {
    align-items: flex-start;
  }
}

/* Stage UX — richer operations layout */
.sticky-side-card {
  position: sticky;
  top: 22px;
  align-self: start;
}

.assistant-side-card {
  overflow: hidden;
  background:
    radial-gradient(circle at 92% 8%, rgba(124, 58, 237, 0.12), transparent 38%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.9));
}

.agent-side-intro { margin-bottom: 14px; }

.task-action-panel {
  flex: 0 0 260px;
  display: grid;
  gap: 9px;
  justify-items: end;
  align-self: stretch;
}

.task-primary-actions {
  display: flex;
  justify-content: flex-end;
  gap: 7px;
  flex-wrap: wrap;
}

.task-row-main {
  min-width: 0;
  flex: 1 1 auto;
}

.task-row {
  position: relative;
  overflow: hidden;
}

.task-row::before {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: transparent;
}

.task-row.task-type-redirect::before { background: linear-gradient(180deg, #f97316, #ef4444); }
.task-row.task-type-links::before,
.task-row.task-type-links_indexing::before { background: linear-gradient(180deg, #06b6d4, #2563eb); }
.task-row.task-type-workflow::before { background: linear-gradient(180deg, #8b5cf6, #2563eb); }
.task-row.task-type-gwt::before { background: linear-gradient(180deg, #22c55e, #16a34a); }

.task-work-control-polished {
  display: grid;
  justify-items: end;
  gap: 7px;
  padding: 8px 10px;
  border: 1px solid rgba(251, 191, 36, 0.35);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 237, 213, 0.85), rgba(254, 243, 199, 0.72));
}

.task-work-control-polished .assignee-select { max-width: 220px; }

.task-acceptor-field {
  width: min(260px, 100%);
  padding: 8px 10px;
  border: 1px solid rgba(37, 99, 235, 0.14);
  border-radius: 16px;
  background: rgba(239, 246, 255, 0.72);
}

.task-acceptor-field span {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.task-acceptor-field input { width: 100%; }

.workflow-board {
  border-width: 1px;
  border-left-width: 8px;
}

.workflow-kind-chip {
  display: inline-flex;
  margin-bottom: 7px;
  padding: 5px 9px;
  border-radius: 999px;
  color: #0f172a;
  background: rgba(255, 255, 255, 0.68);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.workflow-theme-1 { border-left-color: #2563eb; background: linear-gradient(180deg, rgba(219,234,254,.72), rgba(255,255,255,.92)); }
.workflow-theme-2 { border-left-color: #7c3aed; background: linear-gradient(180deg, rgba(237,233,254,.78), rgba(255,255,255,.92)); }
.workflow-theme-3 { border-left-color: #16a34a; background: linear-gradient(180deg, rgba(220,252,231,.76), rgba(255,255,255,.92)); }
.workflow-theme-4 { border-left-color: #f97316; background: linear-gradient(180deg, rgba(255,237,213,.8), rgba(255,255,255,.92)); }
.workflow-theme-5 { border-left-color: #0891b2; background: linear-gradient(180deg, rgba(207,250,254,.76), rgba(255,255,255,.92)); }
.workflow-theme-6 { border-left-color: #db2777; background: linear-gradient(180deg, rgba(252,231,243,.76), rgba(255,255,255,.92)); }

.inline-agent-console {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(37, 99, 235, 0.12);
  border-radius: 22px;
  background:
    radial-gradient(circle at 96% 0%, rgba(124, 58, 237, 0.12), transparent 38%),
    linear-gradient(180deg, rgba(239,246,255,.8), rgba(255,255,255,.82));
}

.inline-agent-console-spravka {
  border-color: rgba(180, 83, 9, 0.18);
  background:
    radial-gradient(circle at 96% 0%, rgba(180, 83, 9, 0.12), transparent 38%),
    linear-gradient(180deg, rgba(255,251,235,.86), rgba(255,255,255,.84));
}

.inline-agent-log {
  display: grid;
  gap: 10px;
  max-height: 260px;
  overflow: auto;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,.62);
}

.inline-agent-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: stretch;
}

.inline-agent-form textarea {
  width: 100%;
  min-height: 58px;
  resize: vertical;
  padding: 13px 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: white;
}

.upgrade-full-card .upgrade-full-zone {
  display: grid;
  gap: 16px;
}

.upgrade-middle-grid { grid-template-columns: 1fr; }

.links-done-zone {
  border-color: rgba(34, 197, 94, .25);
  background:
    linear-gradient(180deg, rgba(220,252,231,.62), rgba(255,255,255,.92));
}

.section-accent-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 999px;
  color: #065f46;
  background: rgba(187, 247, 208, .92);
  font-weight: 950;
}

.section-accent-title::before {
  content: '✓';
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  color: white;
  background: #16a34a;
}

.delivery-filters-grid { grid-template-columns: repeat(5, minmax(150px, 1fr)); }

.redirect-agent-card {
  background:
    radial-gradient(circle at 96% 6%, rgba(124,58,237,.1), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.9));
}

.snapshot-management-zone,
.snapshot-action-form-block {
  display: grid;
  gap: 14px;
}

.snapshot-inline-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(150px, .45fr) minmax(150px, .45fr) auto;
  gap: 10px;
  align-items: end;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(248,250,252,.78);
}

.snapshot-inline-form label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.snapshot-inline-form textarea,
.snapshot-inline-form input,
.snapshot-inline-form select { width: 100%; }

.snapshot-action-form-block h4 {
  margin: 0;
  font-size: 15px;
}

.snapshot-action-card {
  background:
    radial-gradient(circle at 98% 0%, rgba(37, 99, 235, 0.06), transparent 32%),
    rgba(255,255,255,.95);
}

@media (max-width: 1180px) {
  .sticky-side-card { position: static; }
  .task-action-panel { flex-basis: 100%; justify-items: start; }
  .task-primary-actions { justify-content: flex-start; }
  .task-work-control-polished { justify-items: start; }
  .delivery-filters-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 900px) {
  .task-row { flex-direction: column; }
  .snapshot-inline-form,
  .inline-agent-form,
  .delivery-filters-grid { grid-template-columns: 1fr; }
  .task-action-panel { width: 100%; }
  .task-acceptor-field { width: 100%; }
}

/* UX patch: access modes, Ahrefs links, business ideas, quick capture */
.login-hub-card {
  width: min(1120px, 100%);
}

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

.login-zone-card {
  display: grid;
  gap: 12px;
  align-content: start;
  padding: 22px;
  border: 1px solid rgba(219, 228, 240, 0.92);
  border-radius: 24px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.login-zone-main {
  border-color: rgba(37, 99, 235, 0.22);
  background:
    radial-gradient(circle at 88% 12%, rgba(37,99,235,0.12), transparent 34%),
    linear-gradient(180deg, #ffffff, #eff6ff);
}

.login-zone-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 16px;
  background: #eef4ff;
  font-size: 22px;
}

.login-zone-card h2 {
  margin: 0;
  font-size: 21px;
  letter-spacing: -0.02em;
}

.login-zone-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.login-zone-card .login-row {
  margin-top: 6px;
}

.access-hidden { display: none !important; }

.sidebar-workspace-jump {
  display: none;
  color: #dbeafe;
  text-decoration: none;
  font-weight: 850;
  padding: 11px 13px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 14px;
  background: rgba(255,255,255,0.07);
}

.site-link-edit-wrap-ahrefs {
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.ahrefs-link-button {
  background: linear-gradient(135deg, #eff6ff, #f5f3ff);
}

.site-link-mode {
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
}

.checkbox-filter {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
  min-height: 45px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  font-weight: 850;
}

.checkbox-filter input {
  width: 20px;
  height: 20px;
  min-width: 20px;
}

.mini-filter-row {
  margin-bottom: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #f8fbff;
}

.business-ideas-card {
  border-color: rgba(124, 58, 237, 0.16);
  background:
    radial-gradient(circle at 94% 8%, rgba(124, 58, 237, 0.11), transparent 34%),
    #fff;
}

.business-ideas-zone {
  display: grid;
  gap: 16px;
}

.business-ideas-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.8fr) minmax(320px, 1.2fr);
  gap: 16px;
  align-items: start;
}

.business-idea-row {
  display: grid;
  gap: 10px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
}

.quick-capture-shell {
  width: min(880px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 18px;
}

.quick-capture-hero,
.quick-capture-card {
  padding: 24px;
  border: 1px solid rgba(219, 228, 240, 0.95);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 22px 55px rgba(15, 23, 42, 0.10);
}

.quick-capture-hero h2 {
  margin: 18px 0 8px;
  font-size: clamp(28px, 4vw, 46px);
  letter-spacing: -0.045em;
}

.quick-capture-card {
  display: grid;
  gap: 16px;
  background:
    radial-gradient(circle at 94% 8%, rgba(37, 99, 235, 0.11), transparent 36%),
    rgba(255,255,255,0.94);
}

.quick-capture-log {
  max-height: 42vh;
  min-height: 220px;
}

.quick-capture-form {
  display: grid;
  gap: 12px;
}

.quick-capture-form textarea {
  min-height: 140px;
  font-size: 17px;
}

.quick-capture-hints {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.quick-capture-hints span {
  padding: 8px 11px;
  color: #334155;
  font-size: 13px;
  font-weight: 850;
  border: 1px solid #dbe4f0;
  border-radius: 999px;
  background: #f8fbff;
}

.quick-capture-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  color: #64748b;
  font-size: 14px;
  font-weight: 800;
  border: 1px solid rgba(219, 228, 240, 0.9);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.08);
}

.quick-capture-logout-btn {
  min-width: 112px;
  padding: 12px 18px;
  color: #b91c1c;
  font-weight: 950;
  border: 1px solid #fecaca;
  border-radius: 999px;
  background: linear-gradient(180deg, #fff7f7, #fee2e2);
  cursor: pointer;
}

.quick-capture-logout-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(185, 28, 28, 0.14);
}

body.access-quick-capture .sidebar,
body.access-quick-capture .top-actions,
body.access-quick-capture .page-comment-card {
  display: none !important;
}

body.access-quick-capture .app {
  grid-template-columns: 1fr;
}

body.access-quick-capture .workspace {
  padding: clamp(16px, 4vw, 46px);
}

body.access-quick-capture .topbar {
  justify-content: center;
  text-align: center;
}

body.access-task-panel .page-comment-card {
  display: none;
}

@media (max-width: 1120px) {
  .login-zones { grid-template-columns: 1fr; }
  .sidebar {
    position: relative;
    max-height: 58vh;
    min-height: 0;
    height: auto;
    overflow-y: auto;
  }
  .sidebar-workspace-jump { display: block; }
  .system-card { margin-top: 8px; }
}

@media (max-width: 760px) {
  .login-screen { padding: 14px; align-items: start; overflow-y: auto; }
  .login-card { padding: 22px; border-radius: 26px; }
  .login-card h1 { font-size: clamp(28px, 9vw, 38px); }
  .login-zone-card .login-row { flex-direction: column; gap: 10px; }
  .login-zone-card .login-row button {
    width: 100%;
    min-height: 58px;
    padding: 16px 20px;
    font-size: 17px;
    border-radius: 18px;
  }
  .login-zone-card .login-row input {
    min-height: 56px;
    font-size: 16px;
  }
  .login-welcome-agent {
    align-items: flex-start;
    padding: 12px;
    border-radius: 20px;
  }
  .login-welcome-agent img {
    width: 58px;
    height: 58px;
    border-radius: 19px;
  }
  .business-ideas-grid { grid-template-columns: 1fr; }
  .quick-capture-hero,
  .quick-capture-card { padding: 18px; }
  .quick-capture-footer {
    align-items: stretch;
    flex-direction: column;
    text-align: center;
  }
  .quick-capture-logout-btn { width: 100%; }
}

/* UX patch: important pages block in site card and snapshot */
.important-pages-details {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(148, 163, 184, 0.28);
}

.important-pages-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  list-style: none;
  cursor: pointer;
  color: var(--blue);
  font-weight: 900;
  padding: 12px 14px;
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.08), rgba(124, 58, 237, 0.06));
}

.important-pages-summary::-webkit-details-marker {
  display: none;
}

.important-pages-summary::before {
  content: '▸';
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  flex: 0 0 auto;
  border-radius: 999px;
  color: #2563eb;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.14);
  transition: transform 0.18s ease;
}

.important-pages-details[open] .important-pages-summary::before {
  transform: rotate(90deg);
}

.important-pages-summary-text {
  display: grid;
  gap: 2px;
  flex: 1 1 auto;
  min-width: 0;
}

.important-pages-summary-text strong {
  font-size: 18px;
  line-height: 1.15;
}

.important-pages-summary-text small {
  color: var(--muted);
  font-weight: 800;
}

.important-pages-counts {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.important-pages-counts span,
.section-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  color: #1d4ed8;
  background: rgba(219, 234, 254, 0.92);
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}

.important-pages-panel {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px;
  margin-top: 14px;
}

.important-pages-section {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(148, 163, 184, 0.28);
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,250,252,0.82));
  box-shadow: 0 14px 42px rgba(15, 23, 42, 0.04);
}

.important-landings-section {
  border-left: 5px solid rgba(37, 99, 235, 0.72);
}

.not-indexed-section {
  border-left: 5px solid rgba(239, 68, 68, 0.58);
}

.important-pages-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.important-pages-section-head h4 {
  margin: 0 0 6px;
  font-size: 17px;
  line-height: 1.25;
}

.important-pages-section-head p {
  margin: 0;
  max-width: 780px;
}

.important-pages-list {
  display: grid;
  gap: 10px;
  margin-top: 0;
}

.important-page-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 14px 16px !important;
  border: 1px solid rgba(148, 163, 184, 0.26) !important;
  border-bottom: 1px solid rgba(148, 163, 184, 0.26) !important;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.035);
}

.important-page-row-landing {
  background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(239,246,255,0.82));
}

.important-page-row-not-indexed {
  background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(254,242,242,0.70));
}

.important-page-main {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.important-page-kicker {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.important-page-main a,
.important-page-main strong {
  color: #2563eb;
  font-weight: 950;
  line-height: 1.35;
  word-break: break-word;
}

.important-page-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.not-indexed-pill {
  color: #991b1b;
  background: #fee2e2;
  border-color: rgba(239, 68, 68, 0.20);
}

.important-pages-empty {
  padding: 14px 16px;
  border: 1px dashed rgba(148, 163, 184, 0.42);
  border-radius: 18px;
  color: var(--muted);
  font-weight: 800;
  background: rgba(248, 250, 252, 0.72);
}

.important-page-create-form {
  display: grid !important;
  grid-template-columns: minmax(260px, 1fr) minmax(180px, auto) auto;
  gap: 10px;
  align-items: center;
  margin-top: 0;
  padding-top: 2px;
}

.important-page-create-form input,
.important-page-create-form select {
  width: 100%;
  min-width: 0 !important;
}

.important-page-create-form button {
  min-height: 44px;
  white-space: nowrap;
}

@media (max-width: 860px) {
  .important-pages-summary {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .important-pages-counts {
    width: 100%;
    justify-content: flex-start;
    padding-left: 34px;
  }

  .important-pages-section-head,
  .important-page-row,
  .important-page-actions {
    display: grid !important;
    grid-template-columns: 1fr;
    justify-items: stretch;
  }

  .important-page-actions {
    justify-content: stretch;
  }

  .important-page-create-form {
    grid-template-columns: 1fr;
  }
}

/* Workflow focused group navigation */
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 7px;
  color: var(--accent);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.workflow-group-menu-card {
  position: relative;
  overflow: hidden;
  border-color: rgba(37, 99, 235, 0.16);
  background:
    radial-gradient(circle at 100% 0%, rgba(124, 58, 237, 0.14), transparent 34%),
    radial-gradient(circle at 0% 100%, rgba(37, 99, 235, 0.12), transparent 34%),
    rgba(255, 255, 255, 0.92);
}

.workflow-group-menu-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  background: linear-gradient(90deg, #2563eb, #7c3aed, #06b6d4);
}

.workflow-group-menu-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.workflow-group-menu-head h3 {
  margin: 0 0 8px;
  font-size: 24px;
}

.workflow-group-menu-head p {
  max-width: 760px;
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.workflow-menu-stats,
.workflow-selected-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.workflow-menu-controls {
  display: grid;
  grid-template-columns: minmax(260px, 1.2fr) minmax(260px, .9fr) auto;
  gap: 12px;
  align-items: end;
  margin-top: 18px;
}

.workflow-menu-controls label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.workflow-menu-controls input,
.workflow-menu-controls select {
  width: 100%;
}

.workflow-menu-chip-list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
  max-height: 240px;
  margin-top: 16px;
  padding: 10px;
  overflow: auto;
  border: 1px solid rgba(37, 99, 235, 0.12);
  border-radius: 22px;
  background: rgba(248, 250, 252, 0.72);
}

.workflow-menu-chip-list.is-filter-empty::after {
  content: 'Workflow с таким названием не найден';
  display: block;
  padding: 14px;
  color: var(--muted);
  font-weight: 800;
}

.workflow-menu-chip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 58px;
  padding: 12px 14px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 18px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.04);
  text-align: left;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.workflow-menu-chip:hover {
  transform: translateY(-1px);
  border-color: rgba(37, 99, 235, 0.34);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.10);
}

.workflow-menu-chip.active {
  border-color: rgba(37, 99, 235, 0.55);
  background: linear-gradient(135deg, rgba(219, 234, 254, .92), rgba(237, 233, 254, .9));
  box-shadow: 0 18px 38px rgba(37, 99, 235, 0.16);
}

.workflow-menu-chip.is-hidden {
  display: none;
}

.workflow-menu-chip span {
  font-weight: 950;
  line-height: 1.25;
}

.workflow-menu-chip small {
  flex: 0 0 auto;
  padding: 6px 9px;
  border-radius: 999px;
  color: #475569;
  background: rgba(226, 232, 240, 0.82);
  font-size: 11px;
  font-weight: 950;
}

.workflow-selected-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 22px;
  border: 1px solid rgba(37, 99, 235, 0.15);
  border-left-width: 8px;
  border-radius: 26px;
  box-shadow: 0 20px 42px rgba(15, 23, 42, 0.07);
}

.workflow-selected-hero h2 {
  margin: 0 0 8px;
  font-size: clamp(26px, 3vw, 42px);
}

.workflow-selected-hero p {
  max-width: 820px;
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

@media (max-width: 1100px) {
  .workflow-menu-controls {
    grid-template-columns: 1fr;
  }

  .workflow-selected-hero,
  .workflow-group-menu-head {
    display: grid;
  }

  .workflow-selected-actions,
  .workflow-menu-stats {
    justify-content: flex-start;
  }
}

@media (max-width: 680px) {
  .workflow-menu-chip-list {
    grid-template-columns: 1fr;
    max-height: 280px;
  }

  .workflow-group-menu-card,
  .workflow-selected-hero {
    border-radius: 20px;
  }
}

/* Stage BF: quick site links + persistent panel UX */
.site-summary-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.site-fast-links {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  min-width: 0;
}

.site-fast-links-label {
  color: var(--muted, #64748b);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .01em;
}

.site-fast-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 6px 10px;
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 999px;
  background: rgba(219, 234, 254, 0.68);
  color: #2563eb;
  font-size: 12px;
  font-weight: 950;
  line-height: 1;
  text-decoration: none;
  box-shadow: 0 6px 16px rgba(37, 99, 235, 0.06);
  cursor: pointer;
  white-space: nowrap;
}

.site-fast-link:hover {
  transform: translateY(-1px);
  background: rgba(191, 219, 254, 0.92);
  box-shadow: 0 10px 20px rgba(37, 99, 235, 0.10);
  text-decoration: none;
}

.site-fast-link.is-default {
  background: rgba(237, 233, 254, 0.86);
  border-color: rgba(124, 58, 237, 0.18);
  color: #6d28d9;
}

.site-fast-link.is-missing,
.site-fast-link.is-muted {
  color: #64748b;
  background: rgba(248, 250, 252, 0.9);
  border-color: rgba(203, 213, 225, 0.9);
  box-shadow: none;
}

button.site-fast-link {
  font-family: inherit;
}

.site-summary-fast-links {
  padding: 6px;
  border: 1px solid rgba(226, 232, 240, 0.86);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.58);
}

.task-site-links,
.workflow-site-fast-links,
.delivery-site-fast-links {
  margin-top: 8px;
}

.workflow-site-fast-links .site-fast-link,
.delivery-site-fast-links .site-fast-link {
  min-height: 26px;
  padding: 5px 9px;
}

.site-card[open] .site-card-summary {
  border-bottom: 1px solid rgba(226, 232, 240, 0.74);
}

.site-card-body details > summary {
  user-select: none;
}

@media (max-width: 900px) {
  .site-card-summary {
    flex-direction: column;
    align-items: stretch;
  }

  .site-summary-actions,
  .site-summary-fast-links {
    width: 100%;
  }

  .site-fast-links {
    gap: 6px;
  }

  .site-fast-link {
    flex: 1 1 auto;
    min-width: 92px;
  }
}


/* Stage BK: workflow comments + reliable workflow quick links */
.workflow-site-comment-box {
  margin: 12px 0 10px;
  padding: 12px 14px;
  border: 1px solid rgba(124, 58, 237, 0.16);
  border-left: 4px solid #7c3aed;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(237, 233, 254, 0.84), rgba(255, 255, 255, 0.78));
  box-shadow: 0 12px 28px rgba(124, 58, 237, 0.06);
}

.workflow-site-comment-kicker {
  color: #6d28d9;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 5px;
}

.workflow-site-comment-text {
  color: var(--text, #0f172a);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.55;
  white-space: pre-wrap;
}

.workflow-compact-summary .workflow-site-comment-box {
  margin-top: 10px;
  margin-bottom: 0;
  max-width: 760px;
}

.workflow-add-site-form label:nth-of-type(2) {
  min-width: 0;
}

@media (max-width: 1100px) {
  .workflow-add-site-form {
    grid-template-columns: 1fr 1fr;
  }

  .workflow-add-site-form .tiny-btn,
  .workflow-add-site-form button[type="submit"] {
    width: 100%;
  }
}

@media (max-width: 860px) {
  .workflow-add-site-form {
    grid-template-columns: 1fr;
  }
}

/* Stage BL: workflow task comments everywhere + long Workflow notes */
.workflow-task-comment-inline {
  margin: 10px 0 8px;
  max-width: 820px;
  padding: 10px 12px;
  border: 1px solid rgba(124, 58, 237, 0.18);
  border-left: 4px solid #7c3aed;
  border-radius: 15px;
  background:
    radial-gradient(circle at 96% 12%, rgba(124, 58, 237, 0.12), transparent 28%),
    linear-gradient(135deg, rgba(245, 243, 255, 0.94), rgba(255, 255, 255, 0.86));
  box-shadow: 0 10px 24px rgba(124, 58, 237, 0.06);
}

.workflow-task-comment-label {
  display: block;
  margin-bottom: 4px;
  color: #6d28d9;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.workflow-task-comment-text {
  color: var(--text, #0f172a);
  font-size: 13px;
  font-weight: 750;
  line-height: 1.5;
  white-space: pre-wrap;
}

.workflow-add-site-form.workflow-add-site-form-stacked {
  grid-template-columns: 1fr;
  align-items: stretch;
  gap: 12px;
}

.workflow-add-site-main-row {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(180px, 0.35fr) minmax(210px, 0.45fr) auto;
  gap: 12px;
  align-items: end;
}

.assignee-create-field,
.workflow-add-site-main-row label,
.workflow-note-field {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-weight: 850;
}

.workflow-note-field textarea,
.workflow-add-site-form textarea {
  width: 100%;
  min-height: 92px;
  resize: vertical;
  padding: 13px 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--card-soft, rgba(255, 255, 255, 0.78));
  color: var(--text, #0f172a);
  font: inherit;
  line-height: 1.5;
}

.workflow-note-field textarea:focus,
.workflow-add-site-form textarea:focus {
  outline: 3px solid rgba(37, 99, 235, 0.13);
  border-color: rgba(37, 99, 235, 0.35);
  background: #fff;
}

.workflow-add-site-note {
  grid-column: 1 / -1;
}

.inline-site-workflow-create .workflow-note-field {
  margin-top: 2px;
}

.inline-site-workflow-create .workflow-note-field textarea {
  min-height: 88px;
}

.assignee-create-field select {
  width: 100%;
}

.dmca-workflow-add-form select[name="assignee_id"] {
  min-width: 210px;
}

@media (max-width: 860px) {
  .workflow-add-site-main-row {
    grid-template-columns: 1fr;
  }

  .workflow-add-site-main-row .tiny-btn,
  .workflow-add-site-main-row button[type="submit"] {
    width: 100%;
  }
}

/* Task priority UX */
.task-row-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.task-priority-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .01em;
  white-space: nowrap;
  border: 1px solid rgba(37, 99, 235, .16);
  background: #eef4ff;
  color: #1d4ed8;
}

.task-priority-badge.task-priority-high,
.task-priority-control.task-priority-high {
  border-color: rgba(239, 68, 68, .28);
  background: linear-gradient(135deg, #fff1f2, #ffe4e6);
  color: #be123c;
}

.task-priority-badge.task-priority-normal,
.task-priority-control.task-priority-normal {
  border-color: rgba(37, 99, 235, .22);
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  color: #1d4ed8;
}

.task-priority-badge.task-priority-low,
.task-priority-control.task-priority-low {
  border-color: rgba(100, 116, 139, .22);
  background: linear-gradient(135deg, #f8fafc, #f1f5f9);
  color: #475569;
}

.task-priority-action {
  width: 100%;
}

.task-priority-control {
  display: grid;
  gap: 6px;
  width: 100%;
  padding: 10px;
  border: 1px solid rgba(148, 163, 184, .25);
  border-radius: 16px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
}

.task-priority-control span {
  font-size: 12px;
  font-weight: 900;
  color: inherit;
}

.task-priority-control select {
  min-height: 38px;
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(148, 163, 184, .35);
  background: rgba(255,255,255,.9);
  font-weight: 900;
  color: #0f172a;
}

.workflow-add-site-priority {
  min-width: 230px;
}

.priority-task-filter-row {
  align-items: end;
}

.priority-task-filter-row label {
  min-width: 220px;
}

@media (max-width: 760px) {
  .task-priority-action,
  .task-priority-control,
  .workflow-add-site-priority,
  .priority-task-filter-row label {
    width: 100%;
    min-width: 0;
  }
}

/* Stage: smarter reference UX and rich agent text */
.rich-text p { margin: 0 0 10px; }
.rich-text p:last-child { margin-bottom: 0; }
.rich-text strong { font-weight: 950; color: var(--text); }
.rich-text a {
  color: var(--blue);
  font-weight: 900;
  text-decoration: none;
  border-bottom: 1px solid rgba(37, 99, 235, .28);
}
.rich-text a:hover { border-bottom-color: currentColor; }

.reference-menu-search-wrap {
  margin-top: 12px;
}
.reference-menu-search {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  padding: 0 16px;
  color: var(--text);
  font-weight: 850;
  outline: none;
}
.reference-menu-search:focus {
  border-color: rgba(37, 99, 235, .45);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, .10);
}
.reference-menu-item {
  gap: 10px;
}
.reference-menu-item a {
  flex: 1;
  overflow-wrap: anywhere;
}
.reference-menu-type {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 5px 9px;
  background: var(--blue-soft);
  color: var(--blue);
  font-size: 11px;
  font-weight: 950;
}
.reference-menu-empty {
  padding: 14px 16px;
  border: 1px dashed var(--line);
  border-radius: 16px;
  color: var(--muted);
  font-weight: 800;
  background: rgba(255,255,255,.72);
}
.reference-section-head-polished {
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.reference-title-editor-wrap {
  flex: 1;
  min-width: 0;
}
.reference-section-kicker {
  display: block;
  margin-bottom: 6px;
  color: var(--blue);
  font-size: 11px;
  line-height: 1;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.reference-section-title-editor {
  min-height: 58px;
  resize: vertical;
  line-height: 1.3;
  font-size: 16px;
}
.reference-edit-preview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .95fr);
  gap: 16px;
  align-items: stretch;
}
.reference-editor-block,
.reference-preview-block {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.reference-editor-block > span,
.reference-preview-head strong {
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.reference-preview-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.reference-rendered-content,
.reference-rendered-empty {
  min-height: 160px;
  max-height: 360px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 18px;
  background: linear-gradient(135deg, rgba(239,246,255,.92), rgba(255,255,255,.96));
  color: var(--text);
  line-height: 1.62;
  font-weight: 650;
}
.reference-rendered-empty {
  color: var(--muted);
  font-weight: 800;
  border-style: dashed;
}
.reference-add-form textarea[name="title"] {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 14px;
  background: #fff;
  color: var(--text);
  font-weight: 850;
  resize: vertical;
}
.reference-item-open-link {
  text-decoration: none;
  white-space: nowrap;
}

@media (max-width: 1100px) {
  .reference-edit-preview-grid { grid-template-columns: 1fr; }
}

/* Stage: Agent sanity UX — readable rich task text, compact actions, reference view-first */
.task-title-line {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}

.task-title-line .row-title {
  flex: 1 1 auto;
  min-width: 220px;
}

.task-edit-text-btn {
  flex: 0 0 auto;
  border: 1px solid rgba(37, 99, 235, .18);
  border-radius: 999px;
  background: rgba(239, 246, 255, .9);
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  padding: 7px 10px;
  cursor: pointer;
}
.task-edit-text-btn:hover { background: #dbeafe; }

.task-description-display {
  margin-top: 10px;
  color: #475569;
  font-size: 14px;
  line-height: 1.55;
  user-select: text;
  overflow-wrap: anywhere;
}
.task-description-display.task-description-empty {
  display: none;
}
.task-description-display.rich-text p {
  margin-bottom: 8px;
}

.task-text-editor {
  display: grid;
  gap: 10px;
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(37, 99, 235, .16);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(239,246,255,.92), rgba(255,255,255,.98));
}
.task-text-editor label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
}
.task-text-editor input,
.task-text-editor textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 11px 12px;
  background: #fff;
  color: var(--text);
  font-weight: 800;
}
.task-text-editor textarea {
  resize: vertical;
  min-height: 112px;
  line-height: 1.48;
}

.task-title-extra-editor {
  border: 1px dashed rgba(37, 99, 235, .18);
  border-radius: 14px;
  padding: 9px 11px;
  background: rgba(255, 255, 255, .72);
}
.task-title-extra-editor summary {
  color: var(--blue);
  font-size: 12px;
  font-weight: 950;
  cursor: pointer;
  user-select: none;
}
.task-title-extra-editor label {
  margin-top: 10px;
}
.task-row.is-editing-text .task-description-display {
  display: none;
}
.task-text-editor-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.task-action-panel-pro {
  flex-basis: 236px;
  align-self: flex-start;
  padding: 10px;
  border: 1px solid rgba(148, 163, 184, .22);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(248,250,252,.72));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
}

.task-action-btn {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 9px 12px;
  background: #fff;
  color: var(--text);
  font-size: 13px;
  font-weight: 950;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(15, 23, 42, .04);
}
.task-action-btn.primary {
  border-color: rgba(37, 99, 235, .35);
  background: linear-gradient(135deg, #2563eb, #3b82f6);
  color: #fff;
}
.task-action-btn.danger {
  border-color: rgba(239, 68, 68, .26);
  background: #fee2e2;
  color: #991b1b;
}
.task-action-btn.ghost {
  border-color: rgba(37, 99, 235, .14);
  background: #dbeafe;
  color: #2563eb;
}
.task-action-btn.work {
  border-color: rgba(245, 158, 11, .35);
  background: #ffb84d;
  color: #92400e;
}
.task-action-btn.secondary {
  background: #fff;
  color: #334155;
}
.task-action-btn:hover {
  transform: translateY(-1px);
}

.task-primary-actions-pro {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
}
.task-primary-actions-pro .task-action-btn.ghost:first-child:nth-last-child(3) {
  grid-column: 1 / -1;
}

.task-priority-control-compact {
  padding: 8px;
  border-radius: 14px;
}
.task-priority-control-compact span {
  font-size: 11px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.task-priority-control-compact select {
  min-height: 34px;
  font-size: 13px;
}

.task-work-control-compact {
  width: 100%;
  justify-items: stretch;
  padding: 9px;
  gap: 7px;
}
.task-work-control-compact .work-status {
  text-align: center;
}
.task-work-control-compact .task-action-btn {
  width: 100%;
}
.task-action-field {
  width: 100%;
}

.workflow-task-comment-inline.rich-text {
  user-select: text;
}
.workflow-task-comment-inline .workflow-task-comment-text {
  overflow-wrap: anywhere;
}

.reference-section-card-view {
  user-select: text;
}
.reference-title-view-wrap {
  flex: 1;
  min-width: 0;
}
.reference-section-view-title {
  margin: 0;
  font-size: 22px;
  line-height: 1.18;
  letter-spacing: -.02em;
  overflow-wrap: anywhere;
}
.reference-section-kind-pill {
  display: inline-flex;
  margin-top: 8px;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--blue-soft);
  color: var(--blue);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.reference-main-view {
  margin-top: 14px;
}
.reference-main-view .reference-rendered-content,
.reference-main-view .reference-rendered-empty {
  min-height: 120px;
  max-height: none;
  user-select: text;
  cursor: text;
}
.reference-section-card.is-reference-editing .reference-section-head {
  border-bottom-color: rgba(37, 99, 235, .18);
}
.reference-section-card.is-reference-editing .reference-section-actions .tiny-btn:first-child {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
}
.reference-items-editor {
  margin-top: 14px;
}
.reference-section-editor {
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding: 14px;
  border: 1px solid rgba(37, 99, 235, .16);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(239,246,255,.92), rgba(255,255,255,.98));
}
.reference-section-editor label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
}
.reference-section-editor .reference-content-input,
.reference-section-editor .reference-section-title-editor {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 12px 14px;
  background: #fff;
  color: var(--text);
  font-weight: 800;
  resize: vertical;
}
.reference-editor-toolbar {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.reference-editor-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

@media (max-width: 900px) {
  .task-action-panel-pro {
    flex-basis: 100%;
    width: 100%;
  }
  .task-primary-actions-pro {
    grid-template-columns: 1fr;
  }
  .task-title-line .row-title {
    min-width: 0;
    flex-basis: 100%;
  }
}

/* Stage: editable Workflow templates */
.workflow-board-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.workflow-edit-toggle {
  border-color: rgba(124, 58, 237, .25);
  background: linear-gradient(135deg, rgba(255,255,255,.92), rgba(238, 242, 255, .92));
  color: #4f46e5;
  box-shadow: 0 10px 26px rgba(79, 70, 229, .08);
}

.workflow-edit-panel {
  display: grid;
  gap: 16px;
  padding: 18px;
  border: 1px solid rgba(124, 58, 237, .18);
  border-radius: 24px;
  background:
    radial-gradient(circle at top left, rgba(124, 58, 237, .10), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.94), rgba(248,250,252,.86));
  box-shadow: 0 22px 50px rgba(15, 23, 42, .08);
}

.workflow-edit-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.workflow-edit-panel-head h4 {
  margin: 2px 0 4px;
  font-size: 20px;
}

.workflow-edit-panel-head p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.workflow-edit-grid {
  display: grid;
  gap: 12px;
}

.workflow-edit-grid label,
.workflow-steps-editor label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-weight: 900;
}

.workflow-edit-grid input,
.workflow-edit-grid textarea,
.workflow-steps-editor textarea {
  width: 100%;
  border: 1px solid rgba(148, 163, 184, .34);
  border-radius: 17px;
  background: rgba(255,255,255,.92);
  padding: 13px 15px;
  color: var(--text);
  font: inherit;
  font-weight: 800;
  line-height: 1.55;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
}

.workflow-edit-grid textarea,
.workflow-steps-editor textarea {
  resize: vertical;
  min-height: 72px;
}

.workflow-edit-grid input:focus,
.workflow-edit-grid textarea:focus,
.workflow-steps-editor textarea:focus {
  outline: 3px solid rgba(99, 102, 241, .14);
  border-color: rgba(99, 102, 241, .42);
  background: #fff;
}

.workflow-steps-editor {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(148, 163, 184, .24);
  border-radius: 20px;
  background: rgba(248,250,252,.72);
}

.workflow-steps-editor-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}

.workflow-step-edit-list {
  display: grid;
  gap: 10px;
}

.workflow-step-edit-row {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) 150px;
  gap: 12px;
  align-items: stretch;
  padding: 12px;
  border: 1px solid rgba(148, 163, 184, .28);
  border-radius: 18px;
  background: rgba(255,255,255,.78);
}

.workflow-step-edit-order {
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 7px;
  padding-top: 2px;
}

.workflow-step-edit-order span {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: linear-gradient(135deg, #e0e7ff, #f5f3ff);
  color: #4f46e5;
  font-weight: 1000;
}

.icon-mini-btn {
  width: 32px;
  height: 28px;
  border: 1px solid rgba(148, 163, 184, .32);
  border-radius: 10px;
  background: rgba(255,255,255,.9);
  color: #475569;
  font-weight: 1000;
  cursor: pointer;
}

.icon-mini-btn:hover {
  border-color: rgba(99, 102, 241, .45);
  color: #4f46e5;
  transform: translateY(-1px);
}

.workflow-step-edit-fields {
  display: grid;
  gap: 10px;
}

.workflow-step-active-toggle {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px !important;
  min-height: 58px;
  padding: 10px;
  border: 1px solid rgba(34, 197, 94, .22);
  border-radius: 16px;
  background: rgba(240, 253, 244, .72);
  color: #166534 !important;
  text-align: center;
}

.workflow-step-active-toggle input {
  width: 18px;
  height: 18px;
}

.workflow-new-steps-field textarea {
  min-height: 110px;
}

.workflow-edit-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.workflow-steps-box-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}

.workflow-steps-modern {
  display: grid;
  gap: 10px;
  padding-left: 0;
  list-style: none;
}

.workflow-step-view {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px 12px;
  border: 1px solid rgba(148, 163, 184, .22);
  border-radius: 16px;
  background: rgba(255,255,255,.64);
}

.workflow-step-view .workflow-step-number {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: rgba(37, 99, 235, .10);
  color: #2563eb;
  font-weight: 1000;
  font-size: 13px;
}

.workflow-step-view strong {
  display: block;
  line-height: 1.45;
}

.workflow-step-view p {
  margin: 5px 0 0;
  color: var(--muted);
  line-height: 1.5;
}

@media (max-width: 860px) {
  .workflow-board-head,
  .workflow-board-actions,
  .workflow-edit-actions {
    justify-content: stretch;
  }

  .workflow-board-actions,
  .workflow-edit-actions {
    width: 100%;
  }

  .workflow-board-actions .tiny-btn,
  .workflow-edit-actions .tiny-btn {
    flex: 1 1 180px;
  }

  .workflow-step-edit-row {
    grid-template-columns: 1fr;
  }

  .workflow-step-edit-order {
    display: flex;
    align-items: center;
    justify-content: flex-start;
  }

  .workflow-step-active-toggle {
    justify-content: flex-start;
  }
}

.workflow-description,
.workflow-step-description {
  margin-top: 6px;
  color: var(--muted);
  line-height: 1.55;
}

.workflow-description p,
.workflow-step-description p {
  margin: 0 0 6px;
}

.workflow-description p:last-child,
.workflow-step-description p:last-child {
  margin-bottom: 0;
}

.workflow-step-edit-controls {
  display: grid;
  gap: 8px;
  align-content: start;
}

.workflow-step-delete-btn,
.workflow-step-restore-btn {
  border: 1px solid rgba(248, 113, 113, .30);
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(254, 226, 226, .96), rgba(255, 241, 242, .92));
  color: #b91c1c;
  padding: 11px 12px;
  font-weight: 1000;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(239, 68, 68, .08);
}

.workflow-step-restore-btn {
  border-color: rgba(34, 197, 94, .30);
  background: linear-gradient(135deg, rgba(220, 252, 231, .98), rgba(240, 253, 244, .92));
  color: #15803d;
}

.workflow-step-delete-btn:hover,
.workflow-step-restore-btn:hover {
  transform: translateY(-1px);
}

.workflow-step-delete-note {
  margin: 0;
  color: #b45309;
  font-size: 12px;
  line-height: 1.35;
  font-weight: 800;
}

.workflow-step-edit-row.is-delete-pending {
  border-color: rgba(248, 113, 113, .45);
  background:
    linear-gradient(135deg, rgba(254, 242, 242, .98), rgba(255, 247, 237, .9));
  box-shadow: inset 4px 0 0 rgba(239, 68, 68, .65);
}

.workflow-step-edit-row.is-delete-pending .workflow-step-edit-fields,
.workflow-step-edit-row.is-delete-pending .workflow-step-active-toggle {
  opacity: .48;
}

.workflow-step-edit-row.is-delete-pending .workflow-step-edit-fields textarea {
  text-decoration: line-through;
}

.workflow-step-edit-row.is-delete-pending .workflow-step-delete-note::before {
  content: 'Будет удалён. ';
  color: #dc2626;
  font-weight: 1000;
}

@media (max-width: 900px) {
  .workflow-step-edit-row {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .workflow-step-edit-controls {
    grid-column: 1 / -1;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: center;
  }

  .workflow-step-delete-note {
    grid-column: 1 / -1;
  }
}

/* UX upgrade: compact task cards with expandable details */
.task-row.task-row-collapsible {
  display: block;
  padding: 0;
  overflow: hidden;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.9));
  box-shadow: 0 10px 28px rgba(15, 23, 42, .035);
}
.task-row.task-row-collapsible > summary {
  list-style: none;
}
.task-row.task-row-collapsible > summary::-webkit-details-marker { display: none; }
.task-row-summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  min-height: 82px;
  padding: 18px 20px 18px 22px;
  cursor: pointer;
  user-select: none;
}
.task-row-summary:hover {
  background: linear-gradient(135deg, rgba(37, 99, 235, .045), rgba(124, 58, 237, .035));
}
.task-summary-chevron {
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  margin-top: 2px;
  border-radius: 999px;
  background: #eaf2ff;
  color: #2563eb;
  font-size: 13px;
  font-weight: 950;
  transition: transform .16s ease, background .16s ease;
}
.task-row-collapsible[open] .task-summary-chevron { transform: rotate(90deg); background: #dbeafe; }
.task-summary-main { min-width: 0; display: grid; gap: 8px; }
.task-summary-title-line {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px 12px;
}
.task-summary-title {
  color: var(--text);
  font-size: 16px;
  line-height: 1.25;
  letter-spacing: -.01em;
}
.task-summary-type {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.task-summary-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.task-summary-site,
.task-summary-site .site-title-link {
  color: #0f172a;
  font-size: 13px;
  font-weight: 900;
}
.task-summary-site.is-empty {
  color: var(--muted);
  font-weight: 800;
}
.task-summary-badges { display: inline-flex; flex-wrap: wrap; align-items: center; gap: 7px; }
.task-summary-badge,
.site-priority-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 9px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, .24);
  background: #f8fafc;
  color: #475569;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}
.task-assignee-badge.is-assigned {
  border-color: rgba(34, 197, 94, .28);
  background: #dcfce7;
  color: #15803d;
}
.task-assignee-badge.is-empty {
  border-color: rgba(148, 163, 184, .24);
  background: #f1f5f9;
  color: #64748b;
}
.site-priority-badge.status-priority-green {
  border-color: rgba(34, 197, 94, .35);
  background: #dcfce7;
  color: #047857;
}
.site-priority-badge.status-priority-standard {
  border-color: rgba(37, 99, 235, .20);
  background: #eff6ff;
  color: #1d4ed8;
}
.site-priority-badge.status-priority-gray,
.site-priority-badge.site-priority-unknown {
  border-color: rgba(148, 163, 184, .28);
  background: #f1f5f9;
  color: #64748b;
}
.task-row-expanded {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(210px, 260px);
  gap: 18px;
  padding: 0 20px 20px 22px;
}
.task-title-line-expanded {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.task-action-panel-collapsed-ui {
  width: 100%;
  flex-basis: auto;
  gap: 10px;
  align-self: start;
}
.task-action-panel-collapsed-ui .task-primary-actions-pro {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
}
.task-action-panel-collapsed-ui .task-action-btn {
  justify-content: center;
  width: 100%;
  min-height: 42px;
}
.task-priority-control-compact span { text-transform: uppercase; letter-spacing: .04em; }
.task-row-collapsible .link-task-extra,
.task-row-collapsible .workflow-task-comment-inline,
.task-row-collapsible .task-description-display,
.task-row-collapsible .task-site-links,
.task-row-collapsible .gwt-task-info {
  margin-top: 12px;
}
.task-row.done .task-summary-title { text-decoration: line-through; color: var(--muted); }

/* Workflow sites now behave like compact site panels */
.workflow-site.workflow-site-collapsible {
  padding: 0;
  display: block;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,250,252,.86));
}
.workflow-site-collapsible > summary { list-style: none; }
.workflow-site-collapsible > summary::-webkit-details-marker { display: none; }
.workflow-site-summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
  padding: 16px 18px;
  cursor: pointer;
}
.workflow-site-summary:hover { background: rgba(37, 99, 235, .035); }
.workflow-site-chevron {
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: #eef4ff;
  color: #2563eb;
  font-weight: 950;
  transition: transform .16s ease;
}
.workflow-site-collapsible[open] .workflow-site-chevron { transform: rotate(90deg); }
.workflow-site-summary-main { display: grid; gap: 7px; min-width: 0; }
.workflow-site-summary-side { display: inline-flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; align-items: center; }
.workflow-site-expanded { padding: 0 18px 18px 56px; }
.workflow-site-expanded .workflow-task-list { margin-top: 12px; }

/* Richer task filters */
.task-filters-grid,
.link-task-filters-grid {
  align-items: end;
}
.checkbox-filter.brand-task-filter {
  background: linear-gradient(135deg, #fff7ed, #eff6ff);
}
.brand-hub-workspace .brand-hub-tasks-card {
  align-self: start;
  position: sticky;
  top: 22px;
}
.brand-hub-task-filter-row {
  display: grid;
  gap: 10px;
}

@media (max-width: 1100px) {
  .task-row-expanded { grid-template-columns: 1fr; }
  .task-action-panel-collapsed-ui { max-width: none; }
  .brand-hub-workspace .brand-hub-tasks-card { position: static; }
}

@media (max-width: 720px) {
  .task-row-summary { padding: 15px 14px; grid-template-columns: auto minmax(0, 1fr); }
  .task-row-expanded { padding: 0 14px 16px 18px; }
  .task-action-panel-collapsed-ui .task-primary-actions-pro { grid-template-columns: 1fr; }
  .workflow-site-summary { grid-template-columns: auto minmax(0, 1fr); }
  .workflow-site-summary-side { grid-column: 2; justify-content: flex-start; }
  .workflow-site-expanded { padding: 0 14px 16px 44px; }
}

/* DMCA / Lumen Counter-Notice Agent */
.dmca-page {
  display: grid;
  gap: 18px;
}

.dmca-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 380px);
  gap: 18px;
  align-items: center;
  background: linear-gradient(135deg, rgba(15, 23, 42, 0.96), rgba(88, 28, 135, 0.9));
  color: #fff;
  overflow: hidden;
  position: relative;
}

.dmca-hero::after {
  content: '';
  position: absolute;
  width: 260px;
  height: 260px;
  right: -80px;
  top: -100px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
}

.dmca-hero .agent-profile {
  position: relative;
  z-index: 1;
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.22);
}

.dmca-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(120px, 1fr));
  gap: 12px;
}

.dmca-metric {
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 18px;
  padding: 14px 16px;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.07);
}

.dmca-metric span {
  display: block;
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dmca-metric strong {
  display: block;
  margin-top: 6px;
  font-size: 26px;
  color: #0f172a;
}

.dmca-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 410px);
  gap: 18px;
  align-items: start;
}

.dmca-main-column,
.dmca-side-column {
  display: grid;
  gap: 18px;
}

.dmca-side-column {
  position: sticky;
  top: 18px;
}

.dmca-card-head {
  display: grid;
  grid-template-columns: minmax(220px, 330px) minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  margin-bottom: 16px;
}

.dmca-generate-form,
.dmca-template-editor {
  display: grid;
  gap: 14px;
}

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

.dmca-generate-form label,
.dmca-template-editor label {
  display: grid;
  gap: 6px;
  color: #334155;
  font-weight: 800;
}

.dmca-generate-form input,
.dmca-generate-form select,
.dmca-generate-form textarea,
.dmca-template-editor input,
.dmca-template-editor textarea,
.dmca-case-body input,
.dmca-case-body textarea {
  width: 100%;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 14px;
  padding: 11px 12px;
  font: inherit;
  color: #0f172a;
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(15, 23, 42, 0.03);
}

.dmca-generate-form textarea,
.dmca-template-editor textarea,
.dmca-case-body textarea {
  resize: vertical;
  min-height: 110px;
}

.dmca-lumen-tools {
  border: 1px dashed rgba(99, 102, 241, 0.35);
  border-radius: 18px;
  padding: 12px;
  background: rgba(238, 242, 255, 0.7);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.dmca-lumen-links-preview {
  flex: 1 1 100%;
}

.dmca-lumen-link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dmca-lumen-link-list a {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 7px 10px;
  background: #fff;
  color: #3730a3;
  text-decoration: none;
  font-size: 12px;
  font-weight: 800;
  border: 1px solid rgba(99, 102, 241, 0.25);
}

.dmca-generate-btn {
  min-height: 48px;
  font-size: 15px;
}

.dmca-generated-result {
  margin-top: 16px;
}

.dmca-filter-card .site-filters-row {
  align-items: end;
}

.dmca-cases-list {
  display: grid;
  gap: 12px;
}

.dmca-case-card {
  border: 1px solid rgba(148, 163, 184, 0.32);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}

.dmca-case-card[open] {
  border-color: rgba(99, 102, 241, 0.42);
  box-shadow: 0 18px 42px rgba(67, 56, 202, 0.11);
}

.dmca-case-summary {
  cursor: pointer;
  list-style: none;
  padding: 15px 16px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}

.dmca-case-summary::-webkit-details-marker {
  display: none;
}

.dmca-case-title {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.dmca-case-title strong {
  color: #0f172a;
}

.dmca-case-title span {
  color: #64748b;
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 760px;
}

.dmca-case-badges {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: end;
}

.dmca-status {
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 900;
  background: #e2e8f0;
  color: #334155;
}

.dmca-status-generated,
.dmca-status-copied {
  background: #dcfce7;
  color: #166534;
}

.dmca-status-sent_manually {
  background: #e0f2fe;
  color: #075985;
}

.dmca-status-new {
  background: #fef3c7;
  color: #92400e;
}

.dmca-status-closed {
  background: #f1f5f9;
  color: #475569;
}

.dmca-case-body {
  padding: 16px;
  display: grid;
  gap: 14px;
}

.dmca-case-meta,
.dmca-case-actions,
.dmca-snapshot-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.dmca-case-meta a {
  color: #4f46e5;
  font-weight: 800;
  text-decoration: none;
}

.dmca-note,
.dmca-notice-data {
  border-radius: 16px;
  padding: 12px;
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.dmca-notice-data pre {
  white-space: pre-wrap;
  overflow: auto;
  max-height: 280px;
  color: #334155;
  font-size: 12px;
}

.dmca-response-box {
  display: grid;
  gap: 12px;
  border-radius: 18px;
  padding: 14px;
  background: linear-gradient(180deg, #f8fafc, #ffffff);
  border: 1px solid rgba(148, 163, 184, 0.28);
}

.dmca-response-box label {
  display: grid;
  gap: 6px;
  color: #334155;
  font-weight: 800;
}

.dmca-agent-card .mini-chat-log {
  max-height: 420px;
}

.snapshot-dmca-block {
  display: grid;
  gap: 14px;
}

.snapshot-dmca-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  border-radius: 18px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(238, 242, 255, 0.95), rgba(245, 243, 255, 0.95));
  border: 1px solid rgba(99, 102, 241, 0.22);
}

.dmca-snapshot-summary span {
  border-radius: 999px;
  padding: 7px 10px;
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.25);
  color: #475569;
  font-size: 12px;
  font-weight: 800;
}

@media (max-width: 1180px) {
  .dmca-dashboard-grid {
    grid-template-columns: repeat(3, minmax(120px, 1fr));
  }
  .dmca-main-grid,
  .dmca-hero,
  .dmca-card-head {
    grid-template-columns: 1fr;
  }
  .dmca-side-column {
    position: static;
  }
}

@media (max-width: 720px) {
  .dmca-dashboard-grid,
  .dmca-form-grid {
    grid-template-columns: 1fr;
  }
  .dmca-case-summary,
  .snapshot-dmca-head {
    flex-direction: column;
    align-items: stretch;
  }
  .dmca-case-badges {
    justify-content: start;
  }
}

/* DMCA v1.1 tabs, analysis and workflow UX */
.dmca-tabs-card {
  display: grid;
  gap: 18px;
  margin-bottom: 20px;
}

.dmca-tabs-head h3 {
  margin: 4px 0 0;
}

.dmca-tabs-nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.dmca-tab-btn {
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255,255,255,.8);
  padding: 18px 20px;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 12px 26px rgba(15, 23, 42, .04);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

.dmca-tab-btn strong {
  display: block;
  color: var(--ink);
  font-size: 17px;
  margin-bottom: 6px;
}

.dmca-tab-btn span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.dmca-tab-btn:hover,
.dmca-tab-btn.is-active {
  transform: translateY(-1px);
  border-color: rgba(37, 99, 235, .35);
  background: linear-gradient(135deg, rgba(37,99,235,.10), rgba(124,58,237,.10));
  box-shadow: 0 18px 38px rgba(37, 99, 235, .12);
}

.dmca-analysis-hero,
.dmca-workflow-empty-card,
.dmca-workflow-board {
  background: linear-gradient(135deg, rgba(255,255,255,.92), rgba(239,246,255,.78));
}

.dmca-analysis-filter-head h3 { margin-bottom: 4px; }

.dmca-analysis-list-card > h3 {
  display: flex;
  align-items: center;
  gap: 10px;
}

.dmca-analysis-site-card {
  border-left: 5px solid #2563eb;
}

.dmca-analysis-summary {
  gap: 18px;
}

.dmca-analysis-site-main {
  display: grid;
  gap: 12px;
  min-width: 0;
}

.dmca-summary-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.dmca-lumen-main-btn {
  border: 0;
  border-radius: 18px;
  padding: 14px 18px;
  background: linear-gradient(135deg, #111827, #475569 58%, #7c6a37);
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 3px;
  box-shadow: 0 16px 32px rgba(15,23,42,.18);
  font-weight: 900;
  transition: transform .18s ease, box-shadow .18s ease;
}

.dmca-lumen-main-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 20px 40px rgba(15,23,42,.22);
}

.dmca-lumen-main-btn small {
  color: rgba(255,255,255,.78);
  font-size: 12px;
  font-weight: 700;
}

.dmca-lumen-main-btn.compact {
  padding: 9px 13px;
  border-radius: 999px;
  font-size: 13px;
  box-shadow: 0 10px 22px rgba(15,23,42,.12);
}

.dmca-lumen-main-btn.compact small { display: none; }

.dmca-lumen-tools-panel {
  border: 1px solid rgba(37, 99, 235, .16);
  border-radius: 22px;
  padding: 18px;
  display: grid;
  gap: 14px;
  background: linear-gradient(135deg, rgba(239,246,255,.88), rgba(250,245,255,.82));
  margin-bottom: 18px;
}

.dmca-lumen-tools-panel h4 { margin: 4px 0 4px; }
.dmca-lumen-tools-panel p { margin: 0; color: var(--muted); }

.dmca-workflow-empty-content {
  display: grid;
  gap: 14px;
  max-width: 880px;
}

.dmca-workflow-steps-preview {
  white-space: pre-wrap;
  background: rgba(15,23,42,.04);
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  padding: 16px;
  font-family: inherit;
  font-weight: 800;
  color: var(--ink);
}

.dmca-workflow-add-site-panel {
  display: grid;
  gap: 14px;
  margin: 20px 0;
  padding: 20px;
  border-radius: 24px;
  border: 1px solid rgba(37,99,235,.18);
  background: rgba(255,255,255,.7);
}

.dmca-workflow-add-site-panel h4 { margin-bottom: 4px; }
.dmca-workflow-add-site-panel p { color: var(--muted); margin: 0; }

.dmca-workflow-add-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 220px;
  gap: 12px;
  align-items: end;
}

.dmca-workflow-add-form textarea,
.dmca-workflow-add-form button {
  grid-column: 1 / -1;
}

.dmca-workflow-sites-box {
  margin-top: 14px;
}

.snapshot-jump-nav {
  position: sticky;
  top: 12px;
  z-index: 15;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  margin-bottom: 18px;
  backdrop-filter: blur(14px);
  background: rgba(255,255,255,.86);
}

.snapshot-jump-nav strong {
  display: block;
  color: var(--ink);
}

.snapshot-jump-chips {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.snapshot-jump-chip {
  white-space: nowrap;
  border: 1px solid rgba(37,99,235,.18);
  background: linear-gradient(135deg, #fff, rgba(239,246,255,.9));
  color: #2563eb;
  border-radius: 999px;
  padding: 9px 13px;
  font-weight: 900;
  cursor: pointer;
}

.snapshot-jump-chip:hover {
  background: #2563eb;
  color: #fff;
}

.snapshot-section-card {
  scroll-margin-top: 110px;
}

@media (max-width: 980px) {
  .dmca-tabs-nav { grid-template-columns: 1fr; }
  .dmca-workflow-add-form { grid-template-columns: 1fr; }
  .snapshot-jump-nav { grid-template-columns: 1fr; position: static; }
}

/* DMCA parties / Lumen UX upgrade */
.dmca-lumen-button-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 10px;
  width: 100%;
}
.dmca-lumen-button-grid.compact {
  grid-template-columns: repeat(4, minmax(92px, auto));
  justify-content: start;
}
.dmca-lumen-search-btn {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(37, 99, 235, .18);
  background: linear-gradient(135deg, #eff6ff, #ffffff);
  color: var(--accent);
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(37, 99, 235, .07);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.dmca-lumen-search-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 32px rgba(37, 99, 235, .14);
  border-color: rgba(37, 99, 235, .35);
}
.dmca-lumen-search-btn span {
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 900;
}
.dmca-lumen-search-btn strong {
  font-size: 14px;
  line-height: 1.25;
  word-break: break-word;
}
.dmca-lumen-button-grid.compact .dmca-lumen-search-btn {
  padding: 8px 10px;
  border-radius: 14px;
}
.dmca-lumen-button-grid.compact .dmca-lumen-search-btn span { font-size: 10px; }
.dmca-lumen-button-grid.compact .dmca-lumen-search-btn strong { font-size: 12px; }
.dmca-lumen-tools {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}
.dmca-selected-parties {
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, .22);
  background: linear-gradient(135deg, rgba(239, 246, 255, .7), rgba(250, 245, 255, .7));
}
.dmca-party-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.dmca-party-badge {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  border: 1px solid rgba(148, 163, 184, .22);
  background: #fff;
  color: var(--text);
}
.dmca-party-badge strong {
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}
.dmca-party-badge.owner { background: #ecfeff; border-color: rgba(6, 182, 212, .22); }
.dmca-party-badge.representative { background: #f5f3ff; border-color: rgba(124, 58, 237, .22); }
.dmca-parties-panel {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(124, 58, 237, .16);
  background: linear-gradient(135deg, #ffffff, #f8f7ff);
}
.dmca-parties-panel-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
}
.dmca-parties-panel-head h4 { margin: 3px 0 5px; }
.dmca-site-party-form {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(148, 163, 184, .22);
  background: rgba(255,255,255,.82);
}
.dmca-site-party-form-head { display: grid; gap: 3px; }
.dmca-site-party-grid,
.dmca-party-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.dmca-site-party-form label,
.dmca-party-editor label,
.dmca-party-create-form label,
.dmca-ai-party-box label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-weight: 900;
  font-size: 13px;
}
.dmca-site-party-form input,
.dmca-site-party-form select,
.dmca-party-editor input,
.dmca-party-editor select,
.dmca-party-editor textarea,
.dmca-party-create-form input,
.dmca-party-create-form select,
.dmca-party-create-form textarea,
.dmca-ai-party-box select,
.dmca-ai-party-box textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 12px 14px;
  font: inherit;
  background: #fff;
  color: var(--text);
}
.dmca-representatives-tab { display: grid; gap: 18px; }
.dmca-representatives-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  background: linear-gradient(135deg, #111827, #312e81);
  color: #fff;
}
.dmca-representatives-hero p { color: rgba(255,255,255,.75); }
.dmca-representatives-stats { display: flex; gap: 10px; flex-wrap: wrap; }
.dmca-representatives-stats span {
  display: grid;
  gap: 2px;
  min-width: 120px;
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
}
.dmca-representatives-stats strong { font-size: 28px; }
.dmca-representatives-grid {
  display: grid;
  grid-template-columns: minmax(320px, .8fr) minmax(0, 1.2fr);
  gap: 18px;
  align-items: start;
}
.dmca-party-create-card,
.dmca-party-list-card,
.dmca-site-party-map-card { display: grid; gap: 16px; }
.dmca-party-create-form,
.dmca-ai-party-box form { display: grid; gap: 12px; }
.dmca-ai-party-box {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(124, 58, 237, .18);
  background: linear-gradient(135deg, #f5f3ff, #fff);
}
.dmca-party-list-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}
.dmca-party-list { display: grid; gap: 12px; }
.dmca-party-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(148, 163, 184, .22);
  background: linear-gradient(135deg, #fff, #f8fafc);
}
.dmca-party-card-head {
  display: flex;
  gap: 12px;
  justify-content: space-between;
  align-items: start;
}
.dmca-party-card-head h4 { margin: 4px 0 0; }
.dmca-party-type {
  display: inline-flex;
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 900;
  background: #e0f2fe;
  color: #0369a1;
}
.dmca-party-type.representative { background: #ede9fe; color: #6d28d9; }
.dmca-party-extra { color: var(--muted); line-height: 1.45; }
.dmca-site-party-map-list { display: grid; gap: 10px; max-height: 720px; overflow: auto; padding-right: 6px; }
.dmca-site-party-row {
  border: 1px solid rgba(148, 163, 184, .2);
  border-radius: 18px;
  background: #fff;
  padding: 10px;
}
.dmca-site-party-row summary {
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.dmca-workflow-site .dmca-party-badges { margin-top: 4px; }
.dmca-workflow-site-expanded { display: grid; gap: 14px; }
.dmca-lumen-mini-panel {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(37, 99, 235, .15);
  background: linear-gradient(135deg, #eff6ff, #fff);
}
.dmca-revision-box {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: 18px;
  background: linear-gradient(135deg, #fff7ed, #fff);
  border: 1px solid rgba(251, 146, 60, .24);
}
.dmca-revision-box label { display: grid; gap: 6px; font-weight: 900; color: var(--muted); }
.dmca-revision-box textarea { min-height: 90px; }

@media (max-width: 980px) {
  .dmca-lumen-button-grid,
  .dmca-lumen-button-grid.compact,
  .dmca-site-party-grid,
  .dmca-party-field-grid,
  .dmca-representatives-grid,
  .dmca-representatives-hero,
  .dmca-parties-panel-head,
  .dmca-lumen-tools {
    grid-template-columns: 1fr;
  }
  .dmca-site-party-row summary { align-items: flex-start; flex-direction: column; }
}
.snapshot-dmca-lumen-searches {
  display: grid;
  gap: 10px;
  margin: 12px 0 16px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(37, 99, 235, .14);
  background: linear-gradient(135deg, #eff6ff, #fff);
}

/* UX update: richer site filters and DMCA binding workspace */
.site-filters-row .site-brand-filter,
.dmca-site-filter-row .site-brand-filter {
  min-height: 58px;
  justify-content: center;
  align-items: center;
}

.site-brand-filter span {
  color: var(--muted);
  font-weight: 900;
}

.dmca-site-lookup-wrap {
  display: grid;
  gap: 7px;
}

.dmca-site-lookup-wrap input {
  width: 100%;
}

.dmca-site-party-map-card {
  background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(239,246,255,.72));
}

.dmca-site-party-map-card .site-search-row {
  margin-top: 2px;
}

.dmca-site-party-map-groups {
  max-height: none;
  overflow: visible;
  padding-right: 0;
}

.dmca-site-party-card {
  padding: 0;
  overflow: hidden;
  border-left: 4px solid rgba(37,99,235,.7);
  background: linear-gradient(135deg, #fff, #f8fbff);
}

.dmca-site-party-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  cursor: pointer;
}

.dmca-site-party-main {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.dmca-site-party-main .site-fast-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dmca-site-party-expanded {
  padding: 0 18px 18px;
}

.dmca-site-party-card[open] .dmca-site-party-summary {
  border-bottom: 1px solid rgba(148,163,184,.18);
  background: linear-gradient(135deg, rgba(239,246,255,.76), rgba(250,245,255,.66));
}

.brand-site-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 11px;
  background: #f5f3ff;
  color: #6d28d9;
  border: 1px solid rgba(124,58,237,.18);
  font-weight: 900;
  font-size: 12px;
}

@media (max-width: 860px) {
  .dmca-site-party-summary {
    grid-template-columns: 1fr;
  }
}

.pill-soft {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border-radius: 999px;
  padding: 8px 12px;
  background: #eff6ff;
  border: 1px solid rgba(37, 99, 235, .16);
  color: #2563eb;
  font-weight: 900;
  font-size: 13px;
}

/* DMCA v2 batch / mail / acceptance UX */
.dmca-tabs-nav-wide {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
}
.dmca-dashboard-grid-wide {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.dmca-metric {
  text-align: left;
  border: 1px solid rgba(104, 124, 160, 0.18);
  background: linear-gradient(145deg, #ffffff 0%, #f6f9ff 100%);
  border-radius: 22px;
  padding: 18px;
  box-shadow: 0 18px 45px rgba(24, 35, 70, 0.06);
  cursor: pointer;
}
.dmca-metric span { display:block; color:#64748b; font-weight:800; font-size:13px; }
.dmca-metric strong { display:block; margin-top:8px; font-size:34px; color:#101828; }
.dmca-hub-grid,
.dmca-acceptance-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 430px;
  gap: 20px;
  align-items: start;
}
.dmca-hub-card,
.dmca-mail-create-card,
.dmca-mail-list-card,
.dmca-batch-create-card,
.dmca-acceptance-hero,
.dmca-delivery-hero {
  border-radius: 26px;
}
.dmca-hub-card-head,
.dmca-party-list-head,
.dmca-card-head,
.dmca-batch-summary,
.dmca-acceptance-summary {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
}
.dmca-hub-site-list,
.dmca-mail-list,
.dmca-batch-list,
.dmca-delivery-feed {
  display:flex;
  flex-direction:column;
  gap:12px;
}
.dmca-hub-site-row,
.dmca-mail-account-row,
.dmca-delivery-row,
.dmca-batch-card,
.dmca-acceptance-site-card {
  border:1px solid rgba(111, 132, 170, .18);
  border-radius:20px;
  background:rgba(255,255,255,.86);
  padding:14px 16px;
}
.dmca-hub-site-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.dmca-profile-badges,
.dmca-batch-summary-side,
.dmca-acceptance-summary-side {
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
.dmca-profile-badge,
.dmca-mail-status,
.dmca-batch-status-line span {
  border-radius:999px;
  padding:8px 12px;
  font-weight:900;
  font-size:12px;
  background:#eef4ff;
  color:#3454d1;
}
.dmca-profile-badge.status-ready,
.dmca-mail-status.status-ready,
.dmca-profile-badge.mail.ready {
  background:#dcfce7;
  color:#047857;
}
.dmca-profile-badge.status-partial,
.dmca-mail-status.status-draft {
  background:#fff7ed;
  color:#b45309;
}
.dmca-profile-badge.status-not_ready,
.dmca-mail-status.status-error,
.error-text {
  background:#fee2e2;
  color:#be123c;
}
.dmca-hostinger-instruction {
  border:1px solid rgba(59,130,246,.18);
  background:linear-gradient(135deg,#eff6ff,#f8fbff);
  border-radius:18px;
  padding:12px 14px;
  margin:12px 0;
}
.dmca-hostinger-instruction summary {
  font-weight:900;
  color:#2563eb;
  cursor:pointer;
}
.dmca-instruction-body {
  margin-top:12px;
  color:#334155;
  line-height:1.55;
}
.dmca-mail-grid,
.dmca-form-grid,
.dmca-site-profile-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap:12px;
}
.dmca-mail-form label,
.dmca-batch-form label,
.dmca-site-profile-form label {
  display:flex;
  flex-direction:column;
  gap:7px;
  color:#64748b;
  font-weight:900;
  font-size:13px;
}
.dmca-mail-form input,
.dmca-mail-form select,
.dmca-mail-form textarea,
.dmca-batch-form input,
.dmca-batch-form select,
.dmca-batch-form textarea,
.dmca-site-profile-form input,
.dmca-site-profile-form select,
.dmca-site-profile-form textarea,
.dmca-quick-profile-form input,
.dmca-quick-profile-form select {
  border:1px solid #dbe5f5;
  border-radius:16px;
  padding:13px 15px;
  background:#fff;
  font-weight:800;
  color:#111827;
}
.dmca-quick-profile-form {
  display:grid;
  grid-template-columns: minmax(220px, 1fr) repeat(3, minmax(170px, 240px));
  gap:10px;
  align-items:center;
}
.dmca-acceptance-side {
  position: sticky;
  top: 18px;
  display:flex;
  flex-direction:column;
  gap:18px;
}
.dmca-acceptance-summary {
  cursor:pointer;
  padding: 6px 0;
}
.dmca-acceptance-expanded {
  margin-top:16px;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.dmca-profile-current-mail {
  border:1px solid rgba(99,102,241,.16);
  border-radius:18px;
  padding:14px 16px;
  background:linear-gradient(135deg,#f8faff,#ffffff);
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.dmca-batch-warning,
.dmca-batch-error {
  border-radius:16px;
  padding:12px 14px;
  background:#fff7ed;
  color:#9a3412;
  font-weight:800;
}
.dmca-batch-error { background:#fee2e2; color:#be123c; }
.dmca-batch-progress {
  border:1px solid rgba(99,102,241,.18);
  border-radius:20px;
  padding:14px;
  background:linear-gradient(135deg,#f8fbff,#ffffff);
}
.dmca-batch-progress-bar {
  height:12px;
  border-radius:999px;
  background:#e5edf8;
  overflow:hidden;
  margin-bottom:12px;
}
.dmca-batch-progress-bar span {
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#2563eb,#7c3aed);
}
.dmca-batch-status-line {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.dmca-batch-body {
  margin-top:16px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.dmca-batch-meta,
.dmca-batch-actions {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.dmca-batch-meta span {
  border:1px solid #e2e8f0;
  border-radius:999px;
  padding:8px 12px;
  color:#64748b;
  font-weight:800;
}
.dmca-batch-items {
  display:flex;
  flex-direction:column;
  gap:10px;
}
.dmca-batch-item {
  border:1px solid #e2e8f0;
  border-left:5px solid #93c5fd;
  border-radius:18px;
  padding:12px 14px;
  background:#fff;
}
.dmca-batch-item.status-sent { border-left-color:#22c55e; }
.dmca-batch-item.status-error { border-left-color:#ef4444; }
.dmca-batch-item.status-generated { border-left-color:#8b5cf6; }
.dmca-batch-item pre,
.dmca-batch-item details pre {
  white-space:pre-wrap;
  word-break:break-word;
  background:#f8fafc;
  border-radius:14px;
  padding:10px;
  font-size:13px;
}
.dmca-delivery-row p {
  margin:.5rem 0 0;
  color:#64748b;
}
.dmca-tasks-tab .filters-card .site-filters-row {
  align-items:end;
}
@media (max-width: 1200px) {
  .dmca-hub-grid,
  .dmca-acceptance-grid { grid-template-columns: 1fr; }
  .dmca-acceptance-side { position: static; }
  .dmca-quick-profile-form { grid-template-columns: 1fr; }
}

/* DMCA batch automation / acceptance UX */
.dmca-batch-form-grid {
  align-items: stretch;
}
.dmca-auto-field {
  border: 1px solid rgba(37, 99, 235, .14);
  border-radius: 18px;
  padding: 14px 16px;
  background: linear-gradient(135deg, #f8fbff, #ffffff);
  box-shadow: 0 10px 24px rgba(15, 23, 42, .035);
  min-height: 76px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
}
.dmca-auto-field strong {
  font-size: 1rem;
  color: #0f172a;
}
.dmca-auto-field p {
  margin: 0;
  color: #64748b;
  font-size: .88rem;
  font-weight: 700;
}
.dmca-mail-autofill {
  background: linear-gradient(135deg, #eff6ff, #ffffff);
}
.dmca-recipient-autofill {
  background: linear-gradient(135deg, #f5f3ff, #ffffff);
}
.dmca-mode-autofill {
  background: linear-gradient(135deg, #ecfdf5, #ffffff);
}
.dmca-quick-profile-card {
  overflow: hidden;
}
.dmca-quick-profile-details > summary,
.dmca-workflow-create-details > summary {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  cursor: pointer;
  padding: 4px 0;
}
.dmca-quick-profile-details > summary::-webkit-details-marker,
.dmca-workflow-create-details > summary::-webkit-details-marker {
  display: none;
}
.dmca-quick-profile-details h3,
.dmca-workflow-create-details h3 {
  margin: .25rem 0;
}
.dmca-quick-profile-details p,
.dmca-workflow-create-details p {
  margin: 0;
  color: #64748b;
}
.dmca-quick-profile-expanded,
.dmca-workflow-create-form {
  margin-top: 18px;
  border-top: 1px solid #e2e8f0;
  padding-top: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.dmca-quick-profile-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  gap: 12px;
}
.dmca-quick-mail-inline {
  border: 1px solid rgba(37, 99, 235, .18);
  border-radius: 20px;
  padding: 14px;
  background: linear-gradient(135deg, #eff6ff, #ffffff);
}
.dmca-quick-mail-inline > summary {
  cursor: pointer;
  font-weight: 900;
  color: #2563eb;
}
.dmca-workflow-create-card {
  border-left: 5px solid #f59e0b;
  background: linear-gradient(135deg, #fff7ed, #ffffff 55%);
}
.dmca-workflow-board-list {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.dmca-workflow-board .workflow-edit-panel {
  margin: 16px 0;
}
@media (max-width: 1200px) {
  .dmca-quick-profile-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .dmca-quick-profile-grid { grid-template-columns: 1fr; }
  .dmca-quick-profile-details > summary,
  .dmca-workflow-create-details > summary { align-items: flex-start; flex-direction: column; }
}

/* DMCA hotfix: restore packet processing, acceptance and workflow agent UX */
.dmca-workflow-tab-with-agent {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  gap: 18px;
  align-items: start;
}

.dmca-workflow-main-column {
  display: grid;
  gap: 18px;
  min-width: 0;
}

.dmca-workflow-agent-card {
  position: sticky;
  top: 18px;
  max-height: calc(100vh - 36px);
  overflow: auto;
}

.dmca-workflow-agent-card .workflow-chat-log {
  max-height: 430px;
}

.dmca-batch-create-card {
  border-left: 5px solid #7c3aed;
  background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(245,243,255,.78));
}

.dmca-batch-form-grid {
  grid-template-columns: minmax(240px, 1fr) minmax(220px, .9fr);
}

.dmca-auto-field {
  border: 1px solid rgba(148, 163, 184, .24);
  border-radius: 18px;
  padding: 14px 16px;
  background: linear-gradient(135deg, #ffffff, #f8fafc);
  display: grid;
  gap: 4px;
}

.dmca-auto-field strong {
  color: var(--ink);
  font-size: 16px;
}

.dmca-auto-field p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.dmca-mail-autofill strong.error-text {
  color: #b91c1c;
}

.dmca-recipient-autofill {
  background: linear-gradient(135deg, #ecfeff, #ffffff);
}

.dmca-mode-autofill {
  background: linear-gradient(135deg, #fef3c7, #ffffff);
}

.dmca-batch-warning {
  padding: 12px 14px;
  border-radius: 16px;
  background: #fff7ed;
  border: 1px solid rgba(251, 146, 60, .28);
  color: #9a3412;
  font-weight: 800;
}

.dmca-quick-profile-card details > summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}

.dmca-quick-profile-card details > summary::-webkit-details-marker {
  display: none;
}

.dmca-quick-profile-expanded {
  margin-top: 16px;
}

@media (max-width: 1180px) {
  .dmca-workflow-tab-with-agent,
  .dmca-batch-form-grid {
    grid-template-columns: 1fr;
  }
  .dmca-workflow-agent-card {
    position: static;
    max-height: none;
  }
}

/* Push 4: one-column task/workflow UX and grouped workflow tasks */
.workflow-layout-single {
  grid-template-columns: minmax(0, 1fr);
}

.single-column-work-card,
.assistant-inline-card,
.task-create-inline-card,
.task-section-card {
  width: 100%;
}

.collapsible-work-card {
  padding: 0;
  overflow: hidden;
  border-color: rgba(191, 219, 254, 0.72);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.9));
}

.collapsible-work-card > summary,
.task-subsection-card > summary,
.workflow-task-group-card > summary,
.workflow-task-reveal > summary,
.inline-site-action-panel > summary,
.site-workflow-tasks-block > summary,
.site-link-tasks-block > summary {
  list-style: none;
  cursor: pointer;
}

.collapsible-work-card > summary::-webkit-details-marker,
.task-subsection-card > summary::-webkit-details-marker,
.workflow-task-group-card > summary::-webkit-details-marker,
.workflow-task-reveal > summary::-webkit-details-marker,
.inline-site-action-panel > summary::-webkit-details-marker,
.site-workflow-tasks-block > summary::-webkit-details-marker,
.site-link-tasks-block > summary::-webkit-details-marker {
  display: none;
}

.collapsible-work-summary,
.task-subsection-summary,
.workflow-task-reveal-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px 20px;
  border-radius: 22px;
}

.collapsible-work-summary:hover,
.task-subsection-summary:hover,
.workflow-task-reveal-summary:hover,
.workflow-task-group-summary:hover {
  background: rgba(37, 99, 235, 0.045);
}

.collapsible-work-summary strong,
.task-subsection-summary strong,
.workflow-task-reveal-summary strong {
  display: block;
  color: var(--text);
  font-size: 18px;
  letter-spacing: -0.02em;
}

.collapsible-work-summary small,
.task-subsection-summary small,
.workflow-task-reveal-summary small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 650;
  line-height: 1.45;
}

.collapsible-work-body {
  display: grid;
  gap: 16px;
  padding: 0 20px 20px;
}

.task-section-card {
  background:
    radial-gradient(circle at 0% 0%, rgba(37, 99, 235, 0.10), transparent 38%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
}

.task-subsection-card,
.workflow-task-reveal,
.site-workflow-tasks-block,
.site-link-tasks-block,
.inline-site-action-panel {
  border: 1px solid rgba(219, 228, 240, 0.96);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.045);
}

.task-board-grouped {
  display: grid;
  gap: 12px;
}

.task-subsection-body,
.workflow-task-group-body {
  display: grid;
  gap: 12px;
  padding: 0 14px 14px;
}

.task-subsection-count {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  min-height: 30px;
  padding: 5px 10px;
  color: #1d4ed8;
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 999px;
  background: #dbeafe;
  font-size: 13px;
  font-weight: 950;
}

.workflow-task-subsection .task-subsection-count {
  color: #6d28d9;
  border-color: rgba(124, 58, 237, 0.18);
  background: #ede9fe;
}

.workflow-task-groups-list,
.progressive-list {
  display: grid;
  gap: 10px;
}

.progressive-list-extra.is-extra {
  display: none;
}

.progressive-list.is-expanded .progressive-list-extra.is-extra {
  display: block;
}

.progressive-list-toggle {
  margin-top: 4px;
  font-weight: 900;
}

.workflow-task-group-card {
  overflow: hidden;
  border: 1px solid rgba(191, 219, 254, 0.84);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(239, 246, 255, 0.94), rgba(245, 243, 255, 0.78));
}

.workflow-task-group-summary {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px;
}

.workflow-task-group-main {
  display: grid;
  gap: 5px;
  min-width: 0;
  flex: 1 1 auto;
}

.workflow-task-group-main strong {
  font-size: 15px;
  letter-spacing: -0.01em;
}

.workflow-task-group-side {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.tiny-btn.as-chip {
  pointer-events: none;
  color: #1d4ed8;
  border-color: rgba(37, 99, 235, 0.18);
  background: rgba(219, 234, 254, 0.92);
  box-shadow: none;
}

.workflow-task-reveal {
  margin-top: 12px;
}

.workflow-task-reveal .workflow-task-list-hidden-first {
  padding: 0 14px 14px;
}

.workflow-agent-inline-card {
  position: static;
  top: auto;
}

.workflow-agent-inline-card .workflow-chat-log {
  max-height: 360px;
}

.workflow-agent-body {
  padding-top: 0;
}

.inline-site-action-panel {
  margin-top: 12px;
  padding: 0;
}

.inline-site-action-panel > summary,
.site-workflow-tasks-block > summary,
.site-link-tasks-block > summary {
  padding: 12px 14px;
  color: var(--blue);
  font-weight: 950;
}

.inline-site-action-panel > form,
.inline-site-action-panel > .inline-site-workflow-create,
.inline-site-action-panel .stack-form,
.site-workflow-tasks-block > .workflow-task-groups-list,
.site-link-tasks-block > .progressive-list,
.site-link-tasks-block > .link-task-form {
  margin: 0 12px 12px;
}

.site-tasks-polished {
  gap: 12px;
}

.collapsible-filter-slot {
  padding: 12px;
  border: 1px solid rgba(219, 228, 240, 0.96);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.72);
}

.brand-hub-workspace,
.single-column-work-card {
  display: block;
}

@media (max-width: 720px) {
  .collapsible-work-summary,
  .task-subsection-summary,
  .workflow-task-reveal-summary,
  .workflow-task-group-summary {
    align-items: flex-start;
    flex-direction: column;
  }

  .workflow-task-group-side {
    justify-content: flex-start;
  }

  .collapsible-work-body,
  .task-subsection-body,
  .workflow-task-group-body {
    padding-left: 12px;
    padding-right: 12px;
  }
}

/* Push 5: unified task feed with Workflow groups inside the same list */
.task-section-card-open {
  display: grid;
  gap: 14px;
}

.task-section-open-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 4px;
}

.task-section-open-head p {
  margin: 0;
  max-width: 920px;
}

.task-filter-slot {
  padding: 12px;
  border: 1px solid rgba(219, 228, 240, 0.96);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.72);
}

.task-unified-feed {
  display: grid;
  gap: 12px;
}

.task-feed-workflow-card {
  border-color: rgba(124, 58, 237, 0.22);
  background:
    radial-gradient(circle at 0% 0%, rgba(124, 58, 237, 0.10), transparent 34%),
    linear-gradient(135deg, rgba(245, 243, 255, 0.96), rgba(239, 246, 255, 0.82));
}

.task-feed-workflow-card .workflow-task-group-summary {
  min-height: 72px;
}

.task-feed-workflow-card[open] .tiny-btn.as-chip {
  color: #6d28d9;
  border-color: rgba(124, 58, 237, 0.22);
  background: #ede9fe;
}

.task-feed-workflow-card[open] .tiny-btn.as-chip::before {
  content: 'Скрыть';
  font-size: 0;
}

.task-feed-workflow-card[open] .tiny-btn.as-chip {
  font-size: 0;
}

.task-feed-workflow-card[open] .tiny-btn.as-chip::after {
  content: 'Скрыть';
  font-size: 13px;
}

.site-unified-task-feed {
  margin-top: 8px;
}

@media (max-width: 720px) {
  .task-section-open-head {
    align-items: stretch;
    flex-direction: column;
  }

  .task-section-open-head .task-subsection-count {
    width: fit-content;
  }
}

/* Push 6: STR flag and site update cadence */
.site-strapi-chip {
  border: 1px solid #cbd5e1;
  color: #64748b;
  background: #f1f5f9;
  font-weight: 950;
  letter-spacing: 0.04em;
}

.site-strapi-chip.is-strapi-active {
  border-color: #86efac;
  color: #047857;
  background: #dcfce7;
  box-shadow: 0 8px 18px rgba(22, 163, 74, 0.14);
}

.site-strapi-chip.is-strapi-muted {
  border-color: #dbe4f0;
  color: #64748b;
  background: #f8fafc;
}

.site-strapi-chip:hover {
  transform: translateY(-1px);
  filter: brightness(0.99);
}

.site-update-line {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 8px;
  padding: 9px 11px;
  border: 1px solid rgba(219, 228, 240, 0.9);
  border-radius: 16px;
  background: rgba(248, 251, 255, 0.72);
}

.site-update-label {
  color: #64748b;
  font-size: 13px;
  font-weight: 900;
}

.site-update-select {
  min-width: 180px;
  max-width: 240px;
  background: #ffffff;
}

@media (max-width: 720px) {
  .site-update-line,
  .site-update-select {
    width: 100%;
  }
}

/* Push 7: contextual task blocks and polished task filters */
.contextual-task-feed-panel {
  padding: 0;
  overflow: hidden;
  border-color: rgba(191, 219, 254, 0.78);
  background:
    radial-gradient(circle at 100% 0%, rgba(37, 99, 235, 0.10), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92));
}

.contextual-task-feed-panel > summary {
  min-height: 82px;
}

.contextual-task-feed-panel > summary::after {
  content: 'Раскрыть';
  flex: 0 0 auto;
  margin-left: 8px;
  padding: 8px 12px;
  border: 1px solid rgba(37, 99, 235, 0.18);
  border-radius: 999px;
  color: #1d4ed8;
  background: #dbeafe;
  font-size: 13px;
  font-weight: 950;
}

.contextual-task-feed-panel[open] > summary::after {
  content: 'Скрыть';
  color: #6d28d9;
  border-color: rgba(124, 58, 237, 0.22);
  background: #ede9fe;
}

.contextual-task-feed-panel .collapsible-work-body {
  padding-top: 0;
}

.task-filter-slot-polished {
  margin-bottom: 2px;
  padding: 14px;
  border-color: rgba(191, 219, 254, 0.82);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(239, 246, 255, 0.70));
}

.context-task-filter-shell {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.context-task-filter-shell label {
  display: grid;
  gap: 6px;
  min-width: 0;
  color: #64748b;
  font-size: 12px;
  font-weight: 900;
}

.context-task-filter-shell select,
.context-task-filter-shell input {
  min-height: 42px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.94);
  font-weight: 850;
}

.task-search-card {
  padding: 0;
  overflow: hidden;
  border-color: rgba(191, 219, 254, 0.82);
  background:
    radial-gradient(circle at 96% 4%, rgba(124, 58, 237, 0.10), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.94));
}

.task-search-card > h3 {
  margin: 0;
  padding: 18px 20px 0;
  font-size: 20px;
  letter-spacing: -0.025em;
}

.task-search-filter-panel {
  display: grid;
  gap: 14px;
  padding: 16px 20px 20px;
}

.task-search-primary-row {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) auto;
  gap: 14px;
  align-items: end;
  padding: 14px;
  border: 1px solid rgba(191, 219, 254, 0.76);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(239, 246, 255, 0.86), rgba(255, 255, 255, 0.94));
}

.task-site-search-control {
  display: grid;
  gap: 7px;
  color: #475569;
  font-size: 13px;
  font-weight: 950;
}

.task-site-search-control input {
  min-height: 52px;
  border-radius: 18px;
  background: #ffffff;
  font-size: 15px;
  font-weight: 850;
}

.task-filter-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.task-filter-actions .primary-btn.compact,
.task-filter-actions .ghost-btn {
  min-height: 50px;
  padding: 0 18px;
  white-space: nowrap;
}

.task-filter-control-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
}

.task-filter-control-grid label {
  display: grid;
  gap: 7px;
  color: #64748b;
  font-size: 12px;
  font-weight: 950;
}

.task-filter-control-grid select,
.task-filter-control-grid input {
  min-height: 46px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.96);
  font-weight: 850;
}

.task-filter-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.task-filter-chip-row .checkbox-filter {
  width: auto;
  min-height: 44px;
  padding: 9px 12px;
  border: 1px solid rgba(219, 228, 240, 0.96);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: #334155;
  font-size: 13px;
  font-weight: 900;
}

.task-filter-chip-row .brand-task-filter {
  background: linear-gradient(135deg, #fff7ed, #eff6ff);
}

@media (max-width: 760px) {
  .task-search-primary-row {
    grid-template-columns: 1fr;
  }

  .task-filter-actions,
  .task-filter-actions .primary-btn.compact,
  .task-filter-actions .ghost-btn,
  .task-filter-chip-row .checkbox-filter {
    width: 100%;
  }

  .contextual-task-feed-panel > summary::after {
    margin-left: 0;
  }
}
