*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#f8f8f8;--fg:#111;--dim:#999;--border:#ddd;--card:#fff;--red:#c22;--accent:#111;--r:3px;--gap:1rem}
body{font-family:system-ui,sans-serif;background:var(--bg);color:var(--fg);line-height:1.5;font-size:15px}

header{display:flex;justify-content:space-between;align-items:center;padding:.6rem var(--gap);border-bottom:1px solid var(--border);background:var(--card)}
.brand{font-weight:700;text-decoration:none;color:var(--fg)}
nav{display:flex;gap:1rem}
nav a{text-decoration:none;color:var(--fg);font-size:.85rem}

main{max-width:600px;margin:0 auto;padding:var(--gap)}
.narrow{max-width:380px;margin:0 auto}
h1{font-size:1.3rem;font-weight:700;margin-bottom:var(--gap)}
h2{font-size:.95rem;font-weight:600;margin-bottom:.6rem}

.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:var(--gap);margin-bottom:var(--gap)}
.card.empty{text-align:center;color:var(--dim);padding:2rem}
.card-accent{border-left:3px solid var(--accent)}

.field{margin-bottom:.6rem}
.field label{display:block;font-size:.8rem;font-weight:600;margin-bottom:.2rem}
.field input,.field select{width:100%;padding:.35rem .5rem;border:1px solid var(--border);border-radius:var(--r);font-size:.85rem}
.field input:focus,.field select:focus{outline:none;border-color:var(--fg)}
.err{color:var(--red);font-size:.8rem}

.btn{display:inline-block;padding:.4rem .9rem;background:var(--fg);color:var(--bg);border:none;border-radius:var(--r);font-size:.85rem;cursor:pointer;text-decoration:none}
.btn:hover{opacity:.85}
.btn-danger{background:var(--red);color:#fff}
.btn-outline{background:transparent;color:var(--fg);border:1px solid var(--border)}
.full{width:100%}

.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:var(--gap)}
.stat{text-align:center}
.stat .label{display:block;font-size:.7rem;color:var(--dim)}
.stat .big{font-size:1.2rem;font-weight:700}
.red{color:var(--red)}
.cat-line{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.85rem}
.track{height:3px;background:var(--border);border-radius:2px;margin-bottom:.4rem}
.bar{height:100%;background:var(--fg);border-radius:2px;transition:width .3s}
.bar-red{background:var(--red)}

.quick-row{display:flex;gap:.4rem;align-items:end;flex-wrap:wrap;margin:.5rem 0}
.quick-row .qf{flex:1;min-width:80px}
.quick-row input,.quick-row select{width:100%;padding:.35rem .4rem;border:1px solid var(--border);border-radius:var(--r);font-size:.85rem}
.row-inline{display:flex;gap:.5rem;align-items:end;flex-wrap:wrap}

table{width:100%;border-collapse:collapse;font-size:.85rem}
th,td{text-align:left;padding:.35rem .2rem;border-bottom:1px solid var(--border)}
th{font-size:.7rem;color:var(--dim);font-weight:600}
.r{text-align:right}
.mono{font-family:monospace}

.pager{display:flex;justify-content:space-between;margin-top:.6rem;font-size:.85rem}
.pager a{color:var(--fg)}
.row-between{display:flex;justify-content:space-between;align-items:center}
.notices{max-width:600px;margin:.4rem auto;padding:0 var(--gap)}
.notice{padding:.4rem .6rem;border-radius:var(--r);margin-bottom:.4rem;font-size:.85rem;border:1px solid var(--border)}
.notice-success{background:#f0f0f0}
.notice-error{background:#fff0f0;border-color:#fcc}
.notice-warning{background:#fffbe6;border-color:#eed}
.dim{color:var(--dim)}
.small{font-size:.8rem}
.center{text-align:center}
.link{background:none;border:none;color:var(--fg);cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}