/* ============================================================================
   ASCHELOHHAUS // design-system
   nerdy terminal aesthetic · grid raster · 1px borders · no radius · mono
   ========================================================================= */
:root {
  /* surfaces */
  --bg:        #0b0d10;
  --bg-1:      #101317;
  --bg-2:      #161b22;
  --bg-3:      #1c222b;
  /* ink */
  --fg:        #d7dde4;
  --fg-dim:    #8a93a0;
  --fg-faint:  #545d6a;
  /* structure */
  --line:      #262d37;
  --line-hi:   #39424f;
  --grid:      rgba(125,145,165,.05);
  --grid-hi:   rgba(125,145,165,.09);
  /* accents */
  --cyan:      #2ee6e6;
  --lime:      #9ae62e;
  --amber:     #e6a72e;
  --red:       #e64a2e;
  --accent:    var(--cyan);
  /* type */
  --mono: 'JetBrains Mono', ui-monospace, 'Cascadia Code', 'SFMono-Regular',
          Menlo, Consolas, monospace;
  --cell: 24px; /* grid cell size */
}

* { box-sizing: border-box; border-radius: 0 !important; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--mono);
  font-size: 13px;
  line-height: 1.5;
  color: var(--fg);
  background-color: var(--bg);
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size: var(--cell) var(--cell);
  -webkit-font-smoothing: antialiased;
  padding-bottom: 64px; /* room for mobile tabbar */
}

a { color: var(--cyan); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3 { font-weight: 700; margin: 0; letter-spacing: .02em; }
p { margin: .4em 0; }
::selection { background: var(--cyan); color: #000; }

.mono-num { font-variant-numeric: tabular-nums; }
.dim   { color: var(--fg-dim); }
.faint { color: var(--fg-faint); }
.cyan  { color: var(--cyan); }
.lime  { color: var(--lime); }
.amber { color: var(--amber); }
.red   { color: var(--red); }
.right { text-align: right; }
.center{ text-align: center; }
.nowrap{ white-space: nowrap; }
.comment::before { content: '// '; color: var(--fg-faint); }
.comment { color: var(--fg-faint); }

/* ---- shell ---------------------------------------------------------------- */
.app { max-width: 1180px; margin: 0 auto; padding: 0 12px; }

.topbar {
  position: sticky; top: 0; z-index: 40;
  display: flex; align-items: center; gap: 12px;
  height: 48px; padding: 0 12px; margin: 0 -12px;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.brand { font-weight: 700; letter-spacing: .06em; }
.brand b { color: var(--cyan); }
.brand .blink { color: var(--lime); animation: blink 1.1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }

.who { font-size: 11px; color: var(--fg-dim); white-space: nowrap; }
.netstatus {
  margin-left: auto; display: flex; align-items: center; gap: 6px;
  font-size: 11px; color: var(--fg-dim); text-transform: uppercase; letter-spacing: .08em;
}
.dot { width: 8px; height: 8px; border: 1px solid var(--line-hi); display: inline-block; }
.dot--on  { background: var(--lime); border-color: var(--lime); }
.dot--off { background: var(--red);  border-color: var(--red); }

/* desktop nav */
.nav { display: none; gap: 2px; margin: 0 -12px; border-bottom: 1px solid var(--line); overflow-x: auto; }
.nav a {
  padding: 8px 14px; color: var(--fg-dim); text-transform: uppercase;
  font-size: 11px; letter-spacing: .1em; border-right: 1px solid var(--line);
}
.nav a:hover { color: var(--fg); background: var(--bg-1); text-decoration: none; }
.nav a.active { color: var(--cyan); border-bottom: 1px solid var(--cyan); background: var(--bg-1); }

/* mobile bottom tabbar */
.tabbar {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 50;
  display: flex; background: var(--bg); border-top: 1px solid var(--line);
}
.tabbar a {
  flex: 1; text-align: center; padding: 9px 0 7px; color: var(--fg-dim);
  font-size: 10px; text-transform: uppercase; letter-spacing: .06em;
  border-right: 1px solid var(--line);
}
.tabbar a:last-child { border-right: 0; }
.tabbar a .ic { display: block; font-size: 15px; line-height: 1.1; margin-bottom: 1px; }
.tabbar a.active { color: var(--cyan); background: var(--bg-1); }

main { padding: 14px 0 24px; }

/* ---- page head ------------------------------------------------------------ */
.phead { display: flex; align-items: baseline; gap: 10px; margin: 4px 0 14px; }
.phead h1 { font-size: 18px; }
.phead .crumb { color: var(--fg-faint); font-size: 12px; }

/* ---- panels / cards ------------------------------------------------------- */
.panel { border: 1px solid var(--line); background: var(--bg-1); margin-bottom: 14px; }
.panel__h {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; border-bottom: 1px solid var(--line);
  background: var(--bg-2); color: var(--fg-dim);
  text-transform: uppercase; font-size: 11px; letter-spacing: .12em;
}
.panel__h .accentbar { width: 6px; height: 14px; background: var(--accent); }
.panel__h .count { margin-left: auto; color: var(--fg-faint); }
.panel__b { padding: 10px; }
.panel__b.flush { padding: 0; }

/* ---- kpi grid ------------------------------------------------------------- */
.kpis { display: grid; grid-template-columns: repeat(2, 1fr); gap: -1px; }
.kpis { gap: 0; }
.kpi {
  border: 1px solid var(--line); margin: -0.5px; padding: 10px 12px;
  background: var(--bg-1);
}
.kpi .label { font-size: 10px; text-transform: uppercase; letter-spacing: .1em; color: var(--fg-dim); }
.kpi .val { font-size: 22px; font-weight: 700; margin-top: 4px; font-variant-numeric: tabular-nums; }
.kpi .sub { font-size: 11px; color: var(--fg-faint); margin-top: 2px; }
.kpi--cyan .val  { color: var(--cyan); }
.kpi--lime .val  { color: var(--lime); }
.kpi--amber .val { color: var(--amber); }
.kpi--red .val   { color: var(--red); }

/* ---- tables --------------------------------------------------------------- */
.tablewrap { overflow-x: auto; }
table.t { width: 100%; border-collapse: collapse; font-size: 12px; }
table.t th, table.t td {
  border: 1px solid var(--line); padding: 5px 8px; text-align: left; vertical-align: top;
}
table.t th {
  background: var(--bg-2); color: var(--fg-dim); font-weight: 600;
  text-transform: uppercase; font-size: 10px; letter-spacing: .08em; white-space: nowrap;
}
table.t td.num { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
table.t tbody tr:hover td { background: var(--bg-2); }
table.t tr.tot td { background: var(--bg-2); font-weight: 700; }
table.t thead th:hover { color: var(--fg); }
table.t thead th[data-sort] { color: var(--cyan); }
.sortarr { font-size: 9px; }

/* ---- badges --------------------------------------------------------------- */
.badge {
  display: inline-block; padding: 0 6px; font-size: 10px; line-height: 16px;
  text-transform: uppercase; letter-spacing: .06em;
  border: 1px solid var(--line-hi); color: var(--fg-dim);
}
.badge--cyan  { color: var(--cyan);  border-color: var(--cyan); }
.badge--lime  { color: var(--lime);  border-color: var(--lime); }
.badge--amber { color: var(--amber); border-color: var(--amber); }
.badge--red   { color: var(--red);   border-color: var(--red); }

/* ---- progress bar --------------------------------------------------------- */
.bar { position: relative; height: 14px; border: 1px solid var(--line-hi); background: var(--bg); overflow: hidden; }
.bar > span { display: block; height: 100%; max-width: 100%; background: var(--cyan); }
.bar.over > span { background: var(--red); }
.bar.warn > span { background: var(--amber); }
.barlabel { font-size: 10px; color: var(--fg-dim); font-variant-numeric: tabular-nums; }

/* ---- buttons / forms ------------------------------------------------------ */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 12px;
  padding: 5px 10px; background: var(--bg-2); color: var(--fg);
  border: 1px solid var(--line-hi); cursor: pointer; text-transform: uppercase;
  letter-spacing: .04em;
}
.btn:hover { background: var(--bg-3); border-color: var(--cyan); color: var(--cyan); text-decoration: none; }
.btn--accent { border-color: var(--cyan); color: var(--cyan); }
.btn--sm { padding: 2px 7px; font-size: 11px; }
input, select, textarea {
  font-family: var(--mono); font-size: 12px; color: var(--fg);
  background: var(--bg); border: 1px solid var(--line-hi); padding: 5px 8px;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--cyan); }
.field { display: flex; flex-direction: column; gap: 3px; }
.field label { font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: var(--fg-dim); }
.toolbar { display: flex; flex-wrap: wrap; gap: 8px; align-items: flex-end; margin-bottom: 12px; }

/* ---- grids ---------------------------------------------------------------- */
.cols { display: grid; gap: 14px; }
@media (min-width: 720px) {
  .nav { display: flex; }
  .tabbar { display: none; }
  body { padding-bottom: 0; }
  .kpis { grid-template-columns: repeat(4, 1fr); }
  .cols-2 { grid-template-columns: 1fr 1fr; }
  .cols-3 { grid-template-columns: 1fr 1fr 1fr; }
}

/* ---- aufgaben board ------------------------------------------------------- */
.board { display: grid; gap: 12px; }
@media (min-width: 720px) { .board { grid-template-columns: repeat(4, 1fr); } }
.col__h {
  display: flex; align-items: center; gap: 6px; padding: 6px 8px;
  border: 1px solid var(--line); background: var(--bg-2);
  text-transform: uppercase; font-size: 11px; letter-spacing: .1em; color: var(--fg-dim);
}
.col__h .cnt { margin-left: auto; color: var(--fg-faint); }
.col__b { border: 1px solid var(--line); border-top: 0; background: var(--bg-1); padding: 8px; min-height: 40px; display: flex; flex-direction: column; gap: 8px; }
.task { border: 1px solid var(--line-hi); background: var(--bg-2); padding: 7px 8px; }
.task.over { border-left: 3px solid var(--red); }
.task .ttl { font-size: 12px; color: var(--fg); }
.task .meta { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; align-items: center; }
.task .acts { display: flex; gap: 4px; margin-top: 7px; }
.prio { font-size: 10px; letter-spacing: .1em; }
.prio-4 { color: var(--red); } .prio-3 { color: var(--amber); }
.prio-2 { color: var(--fg-dim); } .prio-1 { color: var(--fg-faint); }

/* ---- messages ------------------------------------------------------------- */
.msgs { margin: 10px 0; }
.msg { border: 1px solid var(--line-hi); padding: 7px 10px; margin-bottom: 6px; font-size: 12px; }
.msg.success { border-color: var(--lime); color: var(--lime); }
.msg.error { border-color: var(--red); color: var(--red); }
.msg.info, .msg.debug, .msg.warning { border-color: var(--cyan); color: var(--cyan); }

/* ---- forms ---------------------------------------------------------------- */
.formgrid { display: grid; gap: 12px; }
@media (min-width: 720px) { .formgrid { grid-template-columns: 1fr 1fr; } }
.formgrid .field.full, .formgrid .field.wide { grid-column: 1 / -1; }
.formgrid .field:has(textarea) { grid-column: 1 / -1; }
.formgrid .field:has(input[type=checkbox]) { flex-direction: row; align-items: center; gap: 8px; }
.formgrid .field:has(input[type=checkbox]) input { width: auto; order: -1; }
.formgrid .field:has(select[multiple]) { grid-column: 1 / -1; }
.field input[type=text], .field input[type=date], .field input[type=number],
.field select, .field textarea, .field input:not([type]) { width: 100%; }
.field .err { color: var(--red); font-size: 11px; }
.field .help { color: var(--fg-faint); font-size: 11px; }
.field.check { flex-direction: row; align-items: center; gap: 8px; }
.field.check label { order: 2; }
.btnrow { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; align-items: center; }
.btnrow .spacer { flex: 1; }
.btn--danger { border-color: var(--red); color: var(--red); }
.btn--danger:hover { background: var(--red); color: #000; border-color: var(--red); }

/* ---- crud hub ------------------------------------------------------------- */
.hubgrid { display: grid; gap: 8px; }
@media (min-width: 560px) { .hubgrid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 900px) { .hubgrid { grid-template-columns: 1fr 1fr 1fr; } }
.hublink { display: flex; justify-content: space-between; align-items: center;
  padding: 9px 11px; border: 1px solid var(--line); background: var(--bg-1); }
.hublink:hover { border-color: var(--cyan); text-decoration: none; background: var(--bg-2); }
.hublink .n { color: var(--fg-faint); font-size: 11px; }

/* row actions */
.act { color: var(--fg-dim); padding: 0 5px; font-size: 14px; }
.act:hover { color: var(--cyan); text-decoration: none; }
.act--del:hover { color: var(--red); }
.iconbtn { border: 1px solid var(--line); background: var(--bg); color: var(--cyan);
  padding: 4px 8px; }
.gear { color: var(--fg-dim); font-size: 16px; padding: 0 4px; }
.gear:hover { color: var(--cyan); text-decoration: none; }

/* ---- quick-add (Aufgaben) ------------------------------------------------- */
.quickadd { border: 1px solid var(--cyan); background: var(--bg-1); padding: 8px;
  margin-bottom: 10px; display: flex; flex-direction: column; gap: 6px; }
.quickadd > input[type=text] { width: 100%; font-size: 14px; padding: 9px; }
.quickadd__row { display: flex; flex-wrap: wrap; gap: 6px; }
.quickadd__row select, .quickadd__row input { flex: 1; min-width: 96px; }
.quickadd__row .btn { flex: 0 0 auto; }

/* collapsible filter */
.filterbox { border: 1px solid var(--line); background: var(--bg-1); margin-bottom: 12px; }
.filterbox > summary { padding: 8px 10px; cursor: pointer; color: var(--fg-dim);
  text-transform: uppercase; font-size: 11px; letter-spacing: .08em; list-style: none; }
.filterbox > summary::-webkit-details-marker { display: none; }
.filterbox > summary::before { content: '▸ '; color: var(--cyan); }
.filterbox[open] > summary::before { content: '▾ '; }
.filterbox .toolbar { padding: 4px 10px 12px; margin-bottom: 0; }

/* board cards: bigger tap targets + current-status highlight */
.col { min-width: 0; }
.task .ttl { display: block; font-size: 13px; color: var(--fg); }
.task a.ttl:hover { color: var(--cyan); text-decoration: none; }
.task .acts { display: flex; gap: 4px; margin-top: 8px; flex-wrap: wrap; }
.task .acts .btn { flex: 1; justify-content: center; min-width: 52px; padding: 6px 7px; font-size: 11px; }
.task .acts .btn.is-cur { border-color: var(--cyan); color: var(--cyan); background: var(--bg-3); }
@media (max-width: 719px) { .task .acts .btn { padding: 9px 6px; font-size: 12px; } }

/* offline flash */
.flash {
  position: fixed; bottom: 72px; left: 12px; right: 12px; z-index: 60;
  border: 1px solid var(--amber); background: var(--bg-2); color: var(--amber);
  padding: 8px 10px; font-size: 12px; display: none;
}
.flash.show { display: block; }
@media (min-width: 720px) { .flash { bottom: 16px; left: auto; max-width: 360px; } }
