:root{--bg: #0b1220;--bg-card: #131a2c;--bg-elevated: #1a2238;--border: #232c44;--text: #e8ebf5;--text-dim: #95a0bd;--accent: #4ea1ff;--accent-dim: #2a5d99;--good: #38d39f;--warn: #f0b03b;--danger: #ff6b6b;--radius: 12px;--radius-sm: 8px;--max-w: 640px;--tab-h: 64px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,sans-serif;font-size:16px;color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);min-height:100vh}body{padding-bottom:calc(var(--tab-h) + env(safe-area-inset-bottom))}a{color:var(--accent)}h1{font-size:1.4rem;margin:0 0 4px;font-weight:700}h2{font-size:1.1rem;margin:24px 0 12px;font-weight:600;color:var(--text)}h3{font-size:.95rem;margin:12px 0 6px;font-weight:600}p{margin:6px 0;line-height:1.4;color:var(--text-dim)}.page{max-width:var(--max-w);margin:0 auto;padding:16px 16px 0}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin:12px 0}.row{display:flex;gap:8px;align-items:center}.row.between{justify-content:space-between}.row.wrap{flex-wrap:wrap}.col{display:flex;flex-direction:column}.muted{color:var(--text-dim);font-size:.85rem}.small{font-size:.85rem}.right{margin-left:auto}.pill{display:inline-block;padding:2px 8px;border-radius:999px;background:var(--bg-elevated);color:var(--text-dim);font-size:.75rem;font-weight:500}.pill.accent{background:var(--accent-dim);color:var(--text)}.pill.good{background:#38d39f2e;color:var(--good)}.pill.warn{background:#f0b03b2e;color:var(--warn)}.pill.danger{background:#ff6b6b2e;color:var(--danger)}button,.btn{background:var(--accent);color:#0a0f1c;border:none;border-radius:var(--radius-sm);padding:10px 14px;font-size:.95rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}button:disabled{opacity:.5;cursor:not-allowed}button.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}button.danger{background:var(--danger);color:#fff}input[type=number],input[type=text],input[type=date],select,textarea{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:10px 12px;font-size:1rem;width:100%;font-family:inherit}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:0}label{font-size:.85rem;color:var(--text-dim);display:block;margin-bottom:4px}.macro-bar{display:flex;height:8px;border-radius:999px;overflow:hidden;background:var(--bg-elevated);margin:6px 0}.macro-bar>span{height:100%}.tabbar{position:fixed;bottom:0;left:0;right:0;height:calc(var(--tab-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:var(--bg-card);border-top:1px solid var(--border);display:flex;z-index:50}.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:var(--text-dim);font-size:.7rem;gap:4px}.tabbar a.active{color:var(--accent)}.tabbar .ic{font-size:1.3rem;line-height:1}table.set-table{width:100%;border-collapse:collapse}table.set-table th,table.set-table td{padding:6px 4px;text-align:center;font-size:.9rem}table.set-table th{font-weight:500;color:var(--text-dim)}table.set-table input{padding:6px;text-align:center}
