.vsm-todo-wrap {
  --vsm-border: #d7e0d9;
  --vsm-bg: #f6f8f4;
  --vsm-card: #ffffff;
  --vsm-text: #253126;
  --vsm-muted: #5f6d61;
  --vsm-primary: #2d6a4f;
  --vsm-primary-dark: #1f513b;
  --vsm-danger: #9d2b2b;
  --vsm-shadow: 0 12px 30px rgba(25, 45, 30, 0.08);
  color: var(--vsm-text);
}

.vsm-todo-wrap * { box-sizing: border-box; }
.vsm-todo-header,
.vsm-todo-form-header,
.vsm-todo-actions,
.vsm-todo-checkboxes,
.vsm-quick-statuses {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.vsm-todo-header,
.vsm-todo-form-header {
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
}

.vsm-todo-header h2,
.vsm-todo-form-header h3 {
  margin: 0 0 6px;
}

.vsm-todo-header p,
.vsm-inline-help,
.vsm-subtask-note {
  margin: 0;
  color: var(--vsm-muted);
}

.vsm-todo-card {
  background: var(--vsm-card);
  border: 1px solid var(--vsm-border);
  border-radius: 18px;
  padding: 24px;
  box-shadow: var(--vsm-shadow);
  margin-bottom: 24px;
}

.vsm-todo-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 18px;
}

.vsm-todo-grid--form {
  grid-template-columns: 1fr 1fr;
}

.vsm-todo-wrap label {
  display: block;
  font-weight: 600;
  margin-bottom: 8px;
}

.vsm-todo-wrap input[type="text"],
.vsm-todo-wrap input[type="date"],
.vsm-todo-wrap textarea,
.vsm-todo-wrap select {
  width: 100%;
  border: 1px solid var(--vsm-border);
  border-radius: 12px;
  padding: 12px 14px;
  background: #fff;
  color: var(--vsm-text);
}

.vsm-todo-wrap textarea { resize: vertical; }

.vsm-todo-checkboxes label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 16px 6px 0;
  font-weight: 500;
}

.vsm-todo-actions { margin-top: 20px; align-items: center; }

.vsm-todo-button,
.vsm-todo-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 10px 16px;
  text-decoration: none;
  border: 1px solid var(--vsm-border);
  background: #fff;
  color: var(--vsm-text);
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.vsm-todo-button:hover,
.vsm-todo-chip:hover {
  transform: translateY(-1px);
  border-color: var(--vsm-primary);
}

.vsm-todo-button--primary,
.vsm-todo-chip.is-active {
  background: var(--vsm-primary);
  color: #fff;
  border-color: var(--vsm-primary);
}

.vsm-todo-button--primary:hover,
.vsm-todo-chip.is-active:hover {
  background: var(--vsm-primary-dark);
  border-color: var(--vsm-primary-dark);
  color: #fff;
}

.vsm-todo-button--danger {
  background: #fff5f5;
  color: var(--vsm-danger);
  border-color: #efc1c1;
}

.vsm-todo-table-wrap { overflow-x: auto; }

.vsm-todo-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 1040px;
}

.vsm-todo-table th,
.vsm-todo-table td {
  text-align: left;
  padding: 14px 10px;
  border-bottom: 1px solid #e7eee8;
  vertical-align: top;
}

.vsm-todo-table th {
  font-size: 0.95rem;
  color: var(--vsm-muted);
}

.vsm-task-row {
  transition: background 0.2s ease;
}

.vsm-row-status-ej_paborjad td { background: #f8fafb; }
.vsm-row-status-pagar td { background: #f3fbef; }
.vsm-row-status-klar td { background: #e9f8ee; }
.vsm-row-status-atgard_kravs td { background: #fff4e7; }

.vsm-task-row.is-subtask td:first-child {
  border-left: 4px solid #d8e2da;
}

.vsm-todo-link {
  font-weight: 700;
  text-decoration: none;
  color: var(--vsm-primary-dark);
}

.vsm-todo-link:hover { text-decoration: underline; }

.vsm-task-indent {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.vsm-task-indent--1 {
  padding-left: 16px;
}

.vsm-subtask-prefix {
  color: var(--vsm-muted);
  font-weight: 700;
}

.vsm-subtask-note {
  margin-top: 4px;
  font-size: 0.9rem;
}

.vsm-status-badge {
  display: inline-flex;
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 0.9rem;
  font-weight: 700;
  background: #edf3ee;
}

.vsm-status-ej_paborjad { background: #edf1f4; }
.vsm-status-pagar { background: #e3f3d9; }
.vsm-status-klar { background: #d5f0dd; }
.vsm-status-atgard_kravs { background: #ffe4bf; }

.vsm-todo-notice {
  border-radius: 14px;
  padding: 14px 18px;
  margin-bottom: 18px;
  font-weight: 600;
}

.vsm-todo-notice--success {
  background: #e8f5ea;
  color: #1f513b;
}

.vsm-todo-notice--error {
  background: #fff0f0;
  color: #8e2626;
}

.vsm-todo-meta-box {
  background: var(--vsm-bg);
  border: 1px solid var(--vsm-border);
  border-radius: 14px;
  padding: 14px;
  display: grid;
  gap: 6px;
}

.vsm-todo-delete-form {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid #e7eee8;
}

[data-vsm-live-status] {
  min-height: 1.2em;
  font-size: 0.95rem;
}

@media (max-width: 900px) {
  .vsm-todo-grid,
  .vsm-todo-grid--form {
    grid-template-columns: 1fr;
  }

  .vsm-todo-card {
    padding: 18px;
  }
}
