:root { --space: 1rem; }

body > .container { max-width: 1100px; }

.logo { height: 26px; vertical-align: middle; margin-right: .4rem; }
.brand { display: inline-flex; align-items: center; text-decoration: none; }
.brand-sub { font-weight: 700; letter-spacing: .02em; }
nav .nav-user { display: inline-flex; align-items: center; gap: .6rem; }
.btn-sm { padding: .2rem .6rem; font-size: .8rem; }
.muted { color: var(--pico-muted-color); text-decoration: none; }

/* Dashboard / project cards */
.grid-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1rem; }
.card { border: 1px solid var(--pico-muted-border-color); border-radius: 10px; padding: 1rem; }
.card h3 { margin: 0 0 .3rem; font-size: 1.05rem; }
.card h3 a { text-decoration: none; }
.card.stale { border-color: #e0a800; }
.card.blocked { border-color: #d33; }

.row { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.spread { display: flex; justify-content: space-between; align-items: center; gap: .5rem; }

.badge { font-size: .72rem; padding: .12rem .5rem; border-radius: 999px; border: 1px solid var(--pico-muted-border-color); }
.badge.active { background: #e7f5e7; border-color: #9c9; }
.badge.paused { background: #f3f0e0; }
.badge.done   { background: #e7eefb; }
.badge.archived { background: #eee; color: #777; }
.badge.blocker { background: #fde2e2; border-color: #d33; color: #a00; }
.badge.stale  { background: #fff3cd; border-color: #e0a800; color: #8a6d00; }
/* Health badges */
.badge.health-on_track { background: #e7f5e7; border-color: #9c9; color: #2c6e2c; }
.badge.health-at_risk  { background: #fff3cd; border-color: #e0a800; color: #8a6d00; }
.badge.health-blocked  { background: #fde2e2; border-color: #d33; color: #a00; }
.badge.health-done     { background: #e7eefb; border-color: #79c; color: #2b5; }
.badge.muted-badge     { background: #eee; color: #888; }
/* Per-area chips */
.chip { display: inline-flex; align-items: center; gap: .35rem; padding: .15rem .5rem;
  border: 1px solid var(--pico-muted-border-color); border-radius: 999px; }
.chip-sm { font-size: .68rem; padding: .08rem .4rem; border-radius: 999px;
  background: var(--pico-muted-border-color); }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }

/* + New project disclosure (plain <details>, stays open while typing) */
.new-project { position: relative; }
.new-project > summary { display: inline-block; width: auto; cursor: pointer; list-style: none; }
.new-project > summary::-webkit-details-marker { display: none; }
.new-project[open] > summary { margin-bottom: .5rem; }
.new-project-form {
  position: absolute; right: 0; z-index: 30; width: 280px; margin: 0;
  background: var(--pico-card-background-color, #fff);
  border: 1px solid var(--pico-muted-border-color); border-radius: 10px;
  padding: .8rem; box-shadow: 0 6px 18px rgba(0,0,0,.14);
}
.new-project-form > * { margin-bottom: .5rem; }
.new-project-form > button { margin-bottom: 0; }

.bar { background: var(--pico-muted-border-color); border-radius: 999px; height: 8px; overflow: hidden; }
.bar > span { display: block; height: 100%; background: #3a9; }

.tiny { font-size: .78rem; color: var(--pico-muted-color); }

/* Todos */
.todo { display: flex; align-items: center; gap: .5rem; padding: .25rem 0; border-bottom: 1px dashed var(--pico-muted-border-color); }
.todo .text { flex: 1; }
.todo.s-done .text { text-decoration: line-through; color: var(--pico-muted-color); }
.todo .st { font-size: .72rem; }
.todo form { margin: 0; }

/* Worklog / messages */
.log { border-left: 3px solid var(--pico-muted-border-color); padding: .35rem 0 .35rem .7rem; margin: .35rem 0; }
.log.k-blocker { border-color: #d33; }
.log.k-done { border-color: #3a9; }
.log .meta { font-size: .74rem; color: var(--pico-muted-color); }
.chat { max-height: 380px; overflow-y: auto; }
.chat .msg { padding: .3rem 0; border-bottom: 1px solid var(--pico-muted-border-color); }

.tabs { display: flex; gap: .4rem; border-bottom: 1px solid var(--pico-muted-border-color); margin: 1rem 0; }
.tabs a { padding: .4rem .8rem; text-decoration: none; border-bottom: 2px solid transparent; }
.tabs a.active { border-color: #3a9; font-weight: 600; }

.login-wrap { max-width: 360px; margin: 4rem auto; }
.flash.err { color: #b00; }
.codebox { background: #0f172a; color: #e2e8f0; padding: .8rem; border-radius: 8px; font-size: .82rem; white-space: pre-wrap; word-break: break-word; }
.prose :is(h1,h2,h3) { margin-top: 1rem; }
.prose pre { background: #0f172a; color: #e2e8f0; padding: .8rem; border-radius: 8px; overflow-x: auto; }
.prose code { font-size: .85em; }
.tabpane { margin-top: 1rem; }
.tabpane[hidden] { display: none; }
.two-col { display: grid; grid-template-columns: 2fr 1fr; gap: 1.5rem; }
@media (max-width: 800px) { .two-col { grid-template-columns: 1fr; } }

/* Feed #project mention autocomplete */
.mention-wrap { position: relative; }
.mention-box {
  position: absolute; left: 0; right: 0; top: 100%; z-index: 20;
  background: var(--pico-card-background-color, #fff);
  border: 1px solid var(--pico-muted-border-color); border-radius: 8px;
  margin-top: 2px; box-shadow: 0 4px 14px rgba(0,0,0,.12); overflow: hidden;
}
.mention-item { padding: .4rem .6rem; cursor: pointer; }
.mention-item.active, .mention-item:hover { background: var(--pico-muted-border-color); }
.mention-item strong { color: #3a9; }
/* #project links inside feed/chat messages */
.msg a[href^="/projects/"], .chat a[href^="/projects/"] { font-weight: 600; text-decoration: none; }
