*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--gold:#cca300;--gold-light:#faeeda;--gold-border:#fac775;--bg:#f5f5f3;--bg-card:#fff;--bg-secondary:#f9f9f7;--border:#e5e5e2;--border-mid:#d5d5d2;--text:#1a1a1a;--text-mid:#444;--text-light:#888;--text-faint:#bbb;--green:#0f6e56;--green-bg:#e1f5ee;--green-border:#9fe1cb;--red:#a32d2d;--red-bg:#fcebeb;--red-border:#f7c1c1;--blue:#185fa5;--blue-bg:#e6f1fb;--blue-border:#b5d4f4;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:3px}input,select,textarea{color:var(--text);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;padding:6px 10px;font-family:inherit;font-size:13px;transition:border-color .15s,background .15s}input:focus,select:focus,textarea:focus{border-color:var(--gold);background:var(--bg-card);outline:none}textarea{resize:vertical;min-height:64px}select[multiple]{min-height:80px}button{cursor:pointer;font-family:inherit}.btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text);padding:6px 14px;font-size:13px;transition:background .15s}.btn:hover{background:var(--bg-secondary)}.btn-primary{background:var(--gold);border-color:var(--gold);color:#fff;font-weight:500}.btn-primary:hover{background:#b38f00}.btn-primary:disabled{cursor:not-allowed;background:#ccc;border-color:#ccc}.btn-ghost{color:var(--text-mid);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-secondary)}.badge{border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.badge-green{background:var(--green-bg);color:var(--green)}.badge-amber{background:var(--gold-light);color:#854f0b}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-gray{color:#5f5e5a;background:#f1efe8}.callout{border-radius:var(--radius-md);align-items:flex-start;gap:8px;padding:10px 14px;font-size:13px;display:flex}.callout-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}.callout-amber{background:var(--gold-light);color:#854f0b;border:1px solid var(--gold-border)}.callout-blue{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-border)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg)}.spinner{border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.divider{border:none;border-top:1px solid var(--border);margin:12px 0}
