From cd5574969c2ccce5191b4ceae37a41c8b310fecc Mon Sep 17 00:00:00 2001 From: Joshua Laymon Date: Wed, 13 Aug 2025 05:47:52 +0000 Subject: [PATCH] Add web/static/app.css --- web/static/app.css | 74 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 web/static/app.css diff --git a/web/static/app.css b/web/static/app.css new file mode 100644 index 0000000..ad82384 --- /dev/null +++ b/web/static/app.css @@ -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} +} \ No newline at end of file