Add web/static/app.css

This commit is contained in:
Joshua Laymon 2025-08-13 05:47:52 +00:00
parent 24b6cc98fe
commit cd5574969c

74
web/static/app.css Normal file
View File

@ -0,0 +1,74 @@
:root{
--bg:#f7f9fc;
--card:#ffffff;
--ink:#1f2937;
--ink-muted:#6b7280;
--border:#e5e7eb;
--brand:#2f6cab; /* JW-like blue vibe */
--brand-800:#1f4c7a;
--danger:#b91c1c;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font:16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial}
.container{max-width:1000px;margin:24px auto;padding:0 16px}
.page-title{font-size:28px;margin:4px 0 6px}
.page-subtitle{color:var(--ink-muted);margin:0 0 16px}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.toolbar-left{display:flex;align-items:center;gap:10px}
.toolbar-right{display:flex;align-items:center;gap:8px}
.toolbar-count{color:var(--ink-muted);font-size:14px}
.btn{appearance:none;border:1px solid var(--border);background:#fff;padding:8px 12px;border-radius:10px;cursor:pointer}
.btn:hover{background:#f3f4f6}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-wide{min-width:120px;justify-content:center}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-800);border-color:var(--brand-800)}
.btn-secondary{background:#fff;border-color:var(--border)}
.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}
.btn-danger:hover{filter:brightness(.95)}
.inline{display:inline}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:0 2px 10px rgba(0,0,0,.04)}
.card-header{padding:16px 20px;border-bottom:1px solid var(--border)}
.card-title{margin:0;font-size:22px}
.meta{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}
.card-body{padding:16px 20px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.col-span-2{grid-column:1 / -1}
.field .label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);margin-bottom:4px}
.field .value{font-size:16px}
.prose{white-space:pre-wrap}
.chip{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;padding:4px 10px;background:#f8fafc;font-size:13px}
.chip-muted{background:#f6f7f9;color:var(--ink-muted)}
.chip-link{background:#eef5fc;border-color:#d7e6f7}
.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px}
.pager-spacer{color:var(--ink-muted)}
.search-form{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px 16px;margin-bottom:16px}
.search-row{display:flex;gap:8px}
.search-input{flex:1;border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:16px}
.filter-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.check-pill{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;background:#fff;padding:6px 10px;cursor:pointer;gap:8px}
.check-pill input{accent-color:var(--brand)}
.check-pill:hover{background:#f9fafb}
.empty-state{padding:28px;border:1px dashed var(--border);border-radius:16px;background:#fff}
.empty-title{font-weight:600;margin-bottom:6px}
.empty-subtitle{color:var(--ink-muted)}
.muted{color:var(--ink-muted)}
.small{font-size:13px}
@media (max-width: 780px){
.grid-2{grid-template-columns:1fr}
.toolbar{flex-direction:column;align-items:stretch}
.toolbar-right{justify-content:space-between}
}