/* Adeyy app chrome — monochrome, 4px radius, teal accent for wayfinding only. */

.appshell { display: grid; grid-template-columns: 224px 1fr; min-height: 100vh; }

/* ---------- Sidebar ---------- */
.aside {
  background: var(--card);
  border-right: 1px solid var(--border-1);
  padding: 20px 14px;
  display: flex; flex-direction: column; gap: 2px;
  position: sticky; top: 0; height: 100vh;
}
.aside .brand { display: flex; align-items: baseline; gap: 8px; padding: 4px 10px 18px; text-decoration: none; }
.aside .brand img { height: 19px; display: block; }
.aside .brand .by { font-family: var(--font-mono); font-size: 9px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-40); white-space: nowrap; }
.navitem {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px; border-radius: var(--ar);
  color: var(--ink-80); font-weight: var(--w-medium); font-size: 14px;
  cursor: pointer; text-decoration: none; border: 0; background: none; font-family: inherit;
  text-align: left; width: 100%;
}
.navitem svg { width: 17px; height: 17px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; flex: none; }
.navitem:hover { background: var(--bg-inset); }
.navitem.active { background: var(--adeyy-tint); color: var(--adeyy-ink); font-weight: var(--w-semibold); }
.aside .grp { font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-40); padding: 18px 10px 6px; }
.aside .foot { margin-top: auto; padding: 14px 10px 0; border-top: 1px solid var(--border-1); display: flex; flex-direction: column; gap: 10px; }
.aside .foot .vendor { font-size: 12.5px; font-weight: var(--w-semibold); display: flex; align-items: center; gap: 8px; }
.aside .foot .vendor .avatar { width: 24px; height: 24px; border-radius: 50%; background: var(--ink); color: var(--paper); display: grid; place-items: center; font-weight: 700; font-size: 10px; flex: none; }
.aside .foot .by2 { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-40); }
.aside .foot a { color: inherit; text-decoration: none; }
.aside .foot a:hover { color: var(--ink); }

/* ---------- Main ---------- */
.amain { padding: 0 32px 80px; min-width: 0; }
.apage-head {
  display: flex; align-items: center; gap: 16px;
  padding: 22px 0 18px;
  border-bottom: 1px solid var(--border-1);
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.apage-head h1 { font-size: 24px; font-weight: var(--w-heavy); letter-spacing: -.02em; margin: 0; white-space: nowrap; }
.apage-head .meta { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .06em; color: var(--ink-60); white-space: nowrap; }
.apage-head .meta b { color: var(--ink); font-weight: var(--w-bold); }
.apage-head .spacer { flex: 1; }

.apage-head .mutetext { white-space: nowrap; }

/* back link */
.backlink { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--ink-60); cursor: pointer; background: none; border: 0; padding: 0; font-family: inherit; white-space: nowrap; }
.backlink:hover { color: var(--ink); }
.backlink svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* ---------- Filter bar ---------- */
.filterbar { display: flex; gap: 10px; align-items: center; margin-bottom: 16px; flex-wrap: wrap; }
.filterbar .search { position: relative; flex: 1; min-width: 200px; max-width: 360px; }
.filterbar .search svg { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); width: 15px; height: 15px; stroke: var(--ink-40); fill: none; stroke-width: 2; stroke-linecap: round; }
.filterbar .search input { padding-left: 32px; }

/* ---------- Table ---------- */
.atable { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.atable th {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-60); font-weight: var(--w-medium);
  text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--border-2);
  white-space: nowrap;
}
.atable td { padding: 13px 12px; border-bottom: 1px solid var(--border-1); vertical-align: middle; }
.atable tbody tr { cursor: pointer; transition: background var(--dur-quick) var(--ease-click); }
.atable tbody tr:hover { background: var(--bg-inset); }
.atable .tslug { font-family: var(--font-mono); font-size: 12.5px; font-weight: var(--w-bold); white-space: nowrap; }
.atable .tdest { color: var(--ink-60); max-width: 260px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.atable .tnum { font-family: var(--font-mono); font-size: 12.5px; text-align: right; }
.atable .tdate { font-family: var(--font-mono); font-size: 11.5px; color: var(--ink-60); white-space: nowrap; }
.atable th.r, .atable td.r { text-align: right; }

/* ---------- KPI row ---------- */
.kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 22px; }
.kpis.three { grid-template-columns: repeat(3, 1fr); }
.kpi { background: var(--card); border: 1px solid var(--border-1); border-radius: var(--ar-lg); padding: 16px 18px; box-shadow: var(--shadow-1); }
.kpi .lbl { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-60); }
.kpi .num { font-size: 28px; font-weight: var(--w-heavy); letter-spacing: -.03em; line-height: 1.1; margin-top: 7px; }
.kpi .num .unit { font-size: 14px; font-weight: var(--w-semibold); color: var(--ink-60); margin-left: 2px; }
.kpi .sub { font-size: 12px; color: var(--ink-60); margin-top: 5px; }
.kpi.accent { background: var(--adeyy-tint); border-color: var(--adeyy-tint-bd); }
.kpi.accent .lbl, .kpi.accent .num { color: var(--adeyy-ink); }

/* ---------- Detail layout ---------- */
.anatomy {
  display: grid; grid-template-columns: 1fr auto 1fr auto 1.2fr;
  gap: 14px; align-items: stretch;
  margin: 2px 0 22px;
}
.anatomy .acell {
  background: var(--card); border: 1px solid var(--border-1); border-radius: var(--ar-lg);
  padding: 13px 16px; display: flex; flex-direction: column; gap: 3px; min-width: 0;
}
.anatomy .acell.editable { border-color: var(--adeyy-tint-bd); background: var(--adeyy-tint); }
.anatomy .atag { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-40); }
.anatomy .atag.teal { color: var(--adeyy-ink); }
.anatomy .acell b { font-size: 13.5px; font-weight: var(--w-bold); }
.anatomy .acell span:last-child { font-size: 11.5px; color: var(--ink-60); }
.anatomy .ajoin { align-self: center; font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-40); white-space: nowrap; }
@media (max-width: 1100px) { .anatomy { grid-template-columns: 1fr; } .anatomy .ajoin { justify-self: start; } }

.detail-grid { display: grid; grid-template-columns: 1fr 320px; gap: 20px; align-items: start; }
.dcard { background: var(--card); border: 1px solid var(--border-1); border-radius: var(--ar-lg); box-shadow: var(--shadow-1); }
.dcard .dh { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 16px 18px 12px; }
.dcard .dh h2 { font-size: 14px; font-weight: var(--w-bold); margin: 0; white-space: nowrap; }
.dcard .dh .meta { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-40); white-space: nowrap; }
.dcard .db { padding: 0 18px 16px; }

/* history */
.hrow { display: flex; gap: 12px; padding: 11px 0; border-top: 1px solid var(--border-1); font-size: 13px; align-items: baseline; }
.hrow .hwhen { font-family: var(--font-mono); font-size: 11px; color: var(--ink-40); flex: none; width: 118px; }
.hrow .hwho { font-weight: var(--w-semibold); }
.hrow .hurls { color: var(--ink-60); min-width: 0; }
.hrow .hurls .old { text-decoration: line-through; color: var(--ink-40); }
.hrow .hurls .arrow { font-family: var(--font-mono); color: var(--adeyy-ink); padding: 0 5px; }

/* ---------- QR customise ---------- */
.qrwrap { display: grid; grid-template-columns: 300px 1fr; gap: 24px; align-items: start; }
.qrcontrols { display: flex; flex-direction: column; gap: 18px; }
.qrcontrols .ctl { display: flex; flex-direction: column; gap: 8px; }
.qrcontrols .ctl > label { font-size: 13px; font-weight: var(--w-semibold); }
.qrcontrols .ctl .note { font-size: 11.5px; color: var(--ink-60); }
.swatches { display: flex; gap: 8px; flex-wrap: wrap; }
.swatch { width: 34px; height: 34px; border-radius: var(--ar); border: 1px solid var(--border-2); cursor: pointer; position: relative; padding: 0; }
.swatch.sel { box-shadow: 0 0 0 2px var(--paper), 0 0 0 4px var(--ink); }
.seg { display: inline-flex; border: 1px solid var(--border-2); border-radius: var(--ar); overflow: hidden; width: fit-content; }
.seg button { font: inherit; font-size: 12.5px; font-weight: var(--w-medium); padding: 7px 13px; border: 0; background: var(--card); color: var(--ink-80); cursor: pointer; border-right: 1px solid var(--border-1); }
.seg button:last-child { border-right: 0; }
.seg button.sel { background: var(--ink); color: var(--paper); font-weight: var(--w-semibold); }
.qrstage { background: var(--card); border: 1px solid var(--border-1); border-radius: var(--ar-lg); box-shadow: var(--shadow-1); padding: 28px; display: flex; flex-direction: column; align-items: center; gap: 18px; }
.qrstage .preview { width: min(340px, 100%); border: 1px solid var(--border-1); border-radius: var(--ar); overflow: hidden; }
.qrstage .preview svg { display: block; width: 100%; height: auto; }
.scancheck { display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; white-space: nowrap; }
.scancheck .ok { color: var(--adeyy-ink); }
.scancheck .bad { color: var(--danger); }
.scancheck .cdot { width: 7px; height: 7px; border-radius: 50%; flex: none; }
.dlrow { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }

/* ---------- Charts ---------- */
.chartbox { background: var(--card); border: 1px solid var(--border-1); border-radius: var(--ar-lg); box-shadow: var(--shadow-1); padding: 18px; }
.chartbox .ch { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 14px; }
.chartbox .ch .t { font-size: 13.5px; font-weight: var(--w-bold); white-space: nowrap; }
.legend { display: flex; gap: 14px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-60); }
.legend > span { white-space: nowrap; }
.legend i { display: inline-block; width: 8px; height: 8px; border-radius: 2px; margin-right: 5px; }
.hbar { display: flex; align-items: center; gap: 10px; font-size: 12.5px; padding: 5px 0; }
.hbar .hl { width: 110px; flex: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--ink-80); }
.hbar .ht { flex: 1; height: 9px; background: var(--bg-inset); border-radius: 2px; overflow: hidden; }
.hbar .ht i { display: block; height: 100%; background: var(--ink); border-radius: 2px; }
.hbar.alt .ht i { background: var(--adeyy); }
.hbar .hv { font-family: var(--font-mono); font-size: 11px; color: var(--ink-60); width: 52px; text-align: right; flex: none; }

/* ---------- Settings ---------- */
.settabs { display: flex; gap: 4px; margin-bottom: 22px; border-bottom: 1px solid var(--border-1); }
.settabs button { font: inherit; font-size: 13.5px; font-weight: var(--w-medium); color: var(--ink-60); background: none; border: 0; padding: 10px 14px; cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.settabs button.sel { color: var(--ink); font-weight: var(--w-semibold); border-bottom-color: var(--ink); }

/* ---------- Misc ---------- */
.formgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.row-between { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.divider { border: 0; border-top: 1px solid var(--border-1); margin: 16px 0; }
.mutetext { font-size: 13px; color: var(--ink-60); }
.codeblock { font-family: var(--font-mono); font-size: 12px; background: var(--bg-inset); border: 1px solid var(--border-1); border-radius: var(--ar); padding: 12px 14px; white-space: pre-wrap; word-break: break-all; }

@media (max-width: 1000px) {
  .appshell { grid-template-columns: 1fr; }
  .aside { position: static; height: auto; flex-direction: row; align-items: center; overflow-x: auto; }
  .aside .grp, .aside .foot { display: none; }
  .kpis { grid-template-columns: repeat(2, 1fr); }
  .detail-grid, .qrwrap { grid-template-columns: 1fr; }
}
