74 lines
3.3 KiB
CSS
74 lines
3.3 KiB
CSS
: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}
|
|
} |