* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, "Hiragino Kaku Gothic ProN", sans-serif;
  background: #0d1b2a;
  color: #e0e6ed;
  -webkit-text-size-adjust: 100%;
}
header { padding: 16px 14px 4px; }
h1 { font-size: 20px; margin: 0 0 4px; }
.lead { font-size: 13px; color: #8aa5bb; margin: 0; line-height: 1.5; }
main { padding: 10px 14px 60px; max-width: 720px; margin: 0 auto; }

.card {
  background: #132b40;
  border: 1px solid #2a4a66;
  border-radius: 12px;
  padding: 14px;
  margin-bottom: 16px;
}
.row { margin-bottom: 10px; }
.row.two { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
label { display: block; font-size: 13px; color: #9fc0d8; }
input, textarea {
  width: 100%;
  margin-top: 4px;
  padding: 10px;
  font-size: 16px;
  border-radius: 8px;
  border: 1px solid #3d5670;
  background: #1b2a3a;
  color: #fff;
}
textarea { resize: vertical; }
button {
  width: 100%;
  padding: 13px;
  font-size: 16px;
  font-weight: 700;
  border: 0;
  border-radius: 10px;
  background: #2a6fb0;
  color: #fff;
}
button:active { background: #225a90; }
button.ghost {
  width: auto;
  padding: 9px 14px;
  font-size: 14px;
  background: #24455f;
}
.status { font-size: 13px; margin: 8px 0 0; min-height: 18px; color: #ffd166; }

.list-head {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
}
.list-head input { margin-top: 0; }

.list { display: flex; flex-direction: column; gap: 10px; }
.memo {
  background: #11233a;
  border: 1px solid #24455f;
  border-radius: 10px;
  padding: 12px;
}
.memo .meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  font-size: 12px;
  color: #8aa5bb;
  margin-bottom: 6px;
}
.memo .tag {
  background: #1d3850;
  color: #9fd4ff;
  padding: 2px 8px;
  border-radius: 6px;
  font-weight: 700;
}
.memo .who { color: #cfe6f7; font-weight: 700; }
.memo .body {
  font-size: 15px;
  line-height: 1.6;
  white-space: pre-wrap;
  word-break: break-word;
}
.empty { color: #8aa5bb; font-size: 14px; text-align: center; padding: 24px 0; }

.memo .ops { display: flex; gap: 8px; margin-top: 10px; }
.memo .ops button { width: auto; padding: 7px 16px; font-size: 13px; }
.memo .ops .del { background: #5a2a2a; }
.memo .ops .save { background: #2a6fb0; }
.memo.editing .elabel { display: block; font-size: 13px; color: #9fc0d8; margin-bottom: 8px; }
.memo.editing input, .memo.editing textarea { margin-top: 4px; }
