:root {
  --bg: #f3f1ea;
  --surface: #fff;
  --ink: #15120d;
  --muted: #6f675a;
  --accent: #ff5a1f;
  --danger: #cf3a2c;
  --font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font);
  line-height: 1.4;
}
#app { max-width: 980px; margin: 0 auto; padding: 18px; }
.muted { color: var(--muted); font-size: 0.85rem; }
.err { color: var(--danger); font-weight: 600; }

input, select, button {
  font: inherit;
  border: 2px solid var(--ink);
  background: var(--surface);
  color: var(--ink);
  padding: 7px 9px;
}
button { cursor: pointer; font-weight: 700; box-shadow: 3px 3px 0 var(--ink); }
button:active { transform: translate(2px, 2px); box-shadow: 1px 1px 0 var(--ink); }
button.ghost { box-shadow: none; }
button.danger { background: var(--danger); color: #fff; }

/* login */
.login {
  max-width: 360px;
  margin: 14vh auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  border: 2px solid var(--ink);
  box-shadow: 5px 5px 0 var(--ink);
  background: var(--surface);
  padding: 22px;
}
.login h1 { margin: 0; font-size: 1.2rem; text-transform: uppercase; letter-spacing: 0.05em; }

/* bar */
.bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  border-bottom: 2px solid var(--ink);
  padding-bottom: 12px;
  margin-bottom: 8px;
}
.bar__tools { display: flex; gap: 8px; flex-wrap: wrap; }

/* table */
.tbl { width: 100%; border-collapse: collapse; }
.tbl th, .tbl td {
  text-align: left;
  padding: 8px 6px;
  border-bottom: 1px solid #d8d2c6;
  vertical-align: middle;
}
.tbl th { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.thumb { width: 40px; height: 40px; object-fit: cover; border: 2px solid var(--ink); display: block; }
.emoji { font-size: 1.6rem; }

/* modal */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(21, 18, 13, 0.55);
  display: grid;
  place-items: center;
  padding: 16px;
  z-index: 20;
}
.box {
  background: var(--surface);
  border: 2px solid var(--ink);
  box-shadow: 6px 6px 0 var(--ink);
  width: 100%;
  max-width: 640px;
  max-height: 90dvh;
  display: flex;
  flex-direction: column;
}
.box__head, .box__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
}
.box__head { border-bottom: 2px solid var(--ink); }
.box__foot { border-top: 2px solid var(--ink); gap: 10px; }
.box__foot > div { display: flex; gap: 8px; }
.box__head h2 { margin: 0; font-size: 1.05rem; }
.x { border: 0; box-shadow: none; background: none; font-size: 1.3rem; line-height: 1; padding: 0 4px; }
.box__body { padding: 14px; overflow-y: auto; display: flex; flex-direction: column; gap: 12px; }
.box__body label { display: flex; flex-direction: column; gap: 4px; font-size: 0.8rem; color: var(--muted); }
.box__body label input, .box__body label select { color: var(--ink); }
.box__body label.inline { flex-direction: row; align-items: center; gap: 6px; color: var(--ink); font-size: 0.95rem; }
fieldset { border: 2px solid var(--ink); padding: 10px; }
legend { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.04em; padding: 0 6px; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.grid3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.grid4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.newsrc { border: 2px dashed var(--ink); padding: 10px; }

.imgrow { display: flex; gap: 14px; align-items: flex-start; }
.imgprev { flex: 0 0 auto; }
.imgprev img { width: 96px; height: 96px; object-fit: cover; border: 2px solid var(--ink); }
.imgctl { display: flex; flex-direction: column; gap: 6px; flex: 1; }
.imgctl .or { font-size: 0.8rem; color: var(--muted); }
.cred { margin-top: 10px; }

@media (max-width: 560px) {
  .grid4 { grid-template-columns: 1fr 1fr; }
  .imgrow { flex-direction: column; }
}
