:root {
  --fg: #3a2f1f;          /* dark espresso */
  --muted: #7a6952;       /* warm taupe */
  --bg: #f1e7d0;          /* parchment */
  --card: #faf3df;        /* lighter cream */
  --border: #d6c69c;      /* tan */
  --accent: #a0593a;      /* terracotta */
  --accent-hover: #7e4527;
  --danger: #a3382f;
  --good: #5c6e2f;        /* olive */
  --warn: #a07a1f;        /* amber */

  --tint-accent: #ede0c2; /* badge / default tint */
  --tint-hover:  #ebdab6; /* nav + table-header tint */
  --tint-danger: #f0d8d2;
  --tint-good:   #dee6c8;
  --tint-secondary: #dfd0a8;
  --tint-secondary-hover: #c8b88c;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font: 14px/1.4 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: .75rem 1.25rem;
  background: var(--card);
  border-bottom: 1px solid var(--border);
}
.topbar .brand a {
  font-weight: 700;
  color: var(--fg);
  font-size: 1.05rem;
}
.mainnav {
  display: flex;
  gap: .25rem;
  margin-left: 1rem;
  flex: 1;
}
.mainnav a {
  padding: .35rem .7rem;
  border-radius: 4px;
  color: var(--fg);
}
.mainnav a.active,
.mainnav a:hover { background: var(--tint-hover); color: var(--accent); text-decoration: none; }
.user .email { font-weight: 600; margin-right: .5rem; }
.user .anon { color: var(--muted); }
.user .logout {
  margin-left: .75rem;
  color: var(--muted);
}

.badge {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 10px;
  font-size: 11px;
  margin-right: .25rem;
  background: var(--tint-accent);
  color: var(--accent);
}
.badge.ga { background: var(--tint-danger); color: var(--danger); }
.badge.fa { background: var(--tint-good); color: var(--good); }

.container {
  max-width: 1080px;
  margin: 1.25rem auto;
  padding: 0 1.25rem 2rem;
}

h1 { margin-top: 0; }
h2 { margin-top: 1.5rem; }

.muted { color: var(--muted); }

.flash {
  padding: .6rem .8rem;
  border-radius: 4px;
  margin-bottom: 1rem;
}
.flash.error { background: var(--tint-danger); color: var(--danger); }
.flash.notice { background: var(--tint-good); color: var(--good); }

.datatable {
  width: 100%;
  border-collapse: collapse;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.datatable th, .datatable td {
  text-align: left;
  padding: .55rem .8rem;
  border-bottom: 1px solid var(--border);
}
.datatable th { background: var(--tint-hover); font-weight: 600; }
.datatable tr:last-child td { border-bottom: none; }
.datatable .num { text-align: right; font-variant-numeric: tabular-nums; }
.datatable td.actions form { margin-right: .25rem; }

.cardlike {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: .8rem 1rem;
  margin-bottom: 1rem;
}
.cardlike summary { cursor: pointer; font-weight: 600; }

.form { display: grid; gap: .6rem; max-width: 720px; }
.form.inline { display: flex; gap: .5rem; align-items: end; flex-wrap: wrap; }
.form label { display: grid; gap: .15rem; font-weight: 500; }
.form input[type=text],
.form input[type=email],
.form input[type=url],
.form select {
  padding: .4rem .55rem;
  border: 1px solid var(--border);
  border-radius: 4px;
  font: inherit;
  background: var(--card);
}
.form fieldset {
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: .5rem .8rem;
}
.form .fieldhint {
  font-weight: normal;
  font-size: 12px;
  color: var(--muted);
  margin-top: .25rem;
}

.podgrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .25rem .75rem;
}
/* Selector is .form .podpick so it outranks the generic ".form label { display: grid; }"
   rule above, which otherwise stacks the checkbox above the text. */
.form .podpick {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: .4rem;
  font-weight: normal;
  cursor: pointer;
}
.form .podpick input[type=checkbox] {
  margin: 0;
  flex: 0 0 auto;
}

.actions { display: flex; gap: .5rem; flex-wrap: wrap; }
/* Inside a table cell, keep display: table-cell so the cell stretches to the
   row height and its border-bottom aligns with sibling cells. */
.datatable td.actions { display: table-cell; vertical-align: middle; }

.button {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  padding: .45rem .85rem;
  border-radius: 4px;
  border: none;
  cursor: pointer;
  font: inherit;
}
.button:hover { background: var(--accent-hover); text-decoration: none; }
.button.secondary { background: var(--tint-secondary); color: var(--fg); }
.button.secondary:hover { background: var(--tint-secondary-hover); }
.button:disabled,
.button:disabled:hover {
  cursor: progress;
  opacity: .65;
  background: var(--accent);
}
.button.secondary:disabled,
.button.secondary:disabled:hover {
  background: var(--tint-secondary);
}

.busy-indicator {
  display: none;
  width: 14px;
  height: 14px;
  margin-left: .5rem;
  vertical-align: middle;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: busy-spin .8s linear infinite;
}
.busy-indicator.on { display: inline-block; }
@keyframes busy-spin {
  to { transform: rotate(360deg); }
}

.linkbutton {
  background: none;
  border: none;
  color: var(--accent);
  cursor: pointer;
  font: inherit;
  padding: 0;
  margin-right: .35rem;
}
.linkbutton.danger { color: var(--danger); }
.linkbutton:hover { text-decoration: underline; }
.linkbutton:disabled { color: var(--muted); cursor: not-allowed; text-decoration: none; }

.inlineform { display: flex; gap: .35rem; align-items: center; }
.inlineform input { padding: .25rem .5rem; border: 1px solid var(--border); border-radius: 3px; }

.errcol { color: var(--danger); font-size: 12px; max-width: 360px; }

.datatable td.wrapcell {
  max-width: 320px;
  word-break: break-all;
  font-size: 12px;
}
.datatable td.mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.footer {
  text-align: center;
  color: var(--muted);
  padding: 1rem;
  font-size: 12px;
}
