:root {
  --bg: #f4f1ea;
  --card: #ffffff;
  --ink: #2b2722;
  --muted: #7a7167;
  --accent: #c1440e;
  --accent-d: #9c3409;
  --line: #e3dccf;
  --ok: #2f7d4f;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.5;
}
.wrap { max-width: 880px; margin: 0 auto; padding: 1.25rem 1rem 3rem; }

.brand { text-align: center; margin: .25rem 0 1rem; }
.brand-logo { width: 180px; max-width: 60%; height: auto; }

.hero { margin: .5rem 0 1.5rem; }
.hero h1 { margin: 0 0 .3rem; font-size: 1.7rem; }
.hero-bar { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; }
.meta { color: var(--muted); margin: .2rem 0; display: flex; flex-wrap: wrap; gap: .25rem 1rem; }
.intro { white-space: pre-line; background: #fff8ee; border: 1px solid var(--line); border-radius: 10px; padding: .75rem 1rem; }

h2 { font-size: 1.15rem; margin: 1.8rem 0 .6rem; border-bottom: 2px solid var(--accent); display: inline-block; padding-bottom: .15rem; }

.summary { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1rem 0; }
.stat { background: var(--card); border: 1px solid var(--line); border-radius: 10px; padding: .55rem .8rem; font-size: .85rem; color: var(--muted); }
.stat .num { display: block; font-size: 1.4rem; font-weight: 700; color: var(--accent); line-height: 1.1; }

.table-scroll { overflow-x: auto; }
table.list { width: 100%; border-collapse: collapse; background: var(--card); border-radius: 10px; overflow: hidden; }
table.list th, table.list td { text-align: left; padding: .55rem .6rem; border-bottom: 1px solid var(--line); vertical-align: top; }
table.list th { background: #efe9dd; font-size: .8rem; text-transform: uppercase; letter-spacing: .03em; color: var(--muted); }
table.list tr.out { opacity: .55; }
.badge { display: inline-block; font-size: .7rem; background: #eadfd0; color: var(--muted); border-radius: 6px; padding: .05rem .4rem; margin-left: .35rem; }
.comment { font-size: .8rem; color: var(--muted); font-style: italic; }

.card { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 1rem; margin: .8rem 0; }
.card.compact { padding: .7rem .8rem; }
.card.danger { border-color: #e7c4b8; }
.row { display: flex; flex-wrap: wrap; gap: .6rem; }
.row > label { flex: 1 1 140px; }
label { display: block; font-size: .85rem; color: var(--muted); margin-bottom: .5rem; }
input, select, textarea { width: 100%; margin-top: .2rem; padding: .5rem .6rem; border: 1px solid var(--line); border-radius: 8px; font: inherit; background: #fff; color: var(--ink); }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--accent); border-color: var(--accent); }
textarea { resize: vertical; }

button { background: var(--accent); color: #fff; border: none; border-radius: 8px; padding: .55rem 1.1rem; font: inherit; font-weight: 600; cursor: pointer; }
button:hover { background: var(--accent-d); }
.actions { display: flex; gap: .6rem; align-items: center; flex-wrap: wrap; }
.danger-btn { background: #b23b2e; }
.danger-btn:hover { background: #8f2d22; }
.btn-link, a { color: var(--accent); }
.btn-link { background: none; color: var(--accent); padding: .55rem .4rem; font-weight: 600; }
.inline { display: inline; }
a.small, button.small { font-size: .85rem; }
.row-actions { display: flex; align-items: center; gap: .2rem; }

/* Per-entry admin list: a read-only row that expands into the edit form. */
.entry { background: var(--card); border: 1px solid var(--line); border-radius: 10px; margin: .5rem 0; }
.entry.out { opacity: .6; }
.entry > summary { list-style: none; cursor: pointer; padding: .6rem .8rem; display: flex; flex-wrap: wrap; align-items: baseline; gap: .35rem .7rem; }
.entry > summary::-webkit-details-marker { display: none; }
.entry .entry-name { font-weight: 700; }
.entry .entry-status { font-size: .8rem; color: var(--muted); }
.entry .entry-info { font-size: .85rem; color: var(--muted); }
.entry .entry-info.comment { font-style: italic; }
.entry .entry-edit { margin-left: auto; color: var(--accent); font-weight: 600; font-size: .85rem; }
.entry[open] .entry-edit { opacity: .6; }
.entry > .card { margin: 0 .5rem .5rem; }

.notice { background: #e8f3ea; border: 1px solid #bfe0c8; border-radius: 10px; padding: .8rem 1rem; margin: 1rem 0; }
.notice .editlink { display: inline-block; margin-top: .4rem; font-weight: 600; word-break: break-all; }
.error { color: #b23b2e; font-weight: 600; }
.empty, .hint { color: var(--muted); }
.hint { font-size: .8rem; }
.foot { margin-top: 2.5rem; text-align: center; color: var(--muted); font-size: .85rem; }
