*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',Arial,sans-serif;background:#f3f6fb;color:#142033}.wrap{max-width:1220px;margin:0 auto;padding:26px}.top{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.top h1{font-size:34px;margin:0;font-weight:900}.nav{display:flex;gap:10px;flex-wrap:wrap}.btn,a.btn,button.btn{display:inline-flex;align-items:center;justify-content:center;border:0;background:#111827;color:#fff;text-decoration:none;border-radius:12px;padding:11px 18px;font-size:15px;font-weight:800;cursor:pointer}.btn.light{background:#fff;color:#111827;border:1px solid #d7dee9}.btn.red{background:#dc2626}.btn.green{background:#16a34a}.card{background:#fff;border:1px solid #e1e7f0;border-radius:22px;padding:24px;margin-bottom:22px;box-shadow:0 8px 24px rgba(15,23,42,.06)}.card h2{margin:0 0 18px;font-size:25px}.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.field label{display:block;font-weight:900;margin-bottom:8px}.field input,.field select,.field textarea{width:100%;border:1px solid #cfd8e6;border-radius:12px;padding:12px 13px;font-size:16px;background:#fff}.field textarea{min-height:92px;resize:vertical}.muted{color:#6b7280}.notice{padding:15px 18px;border-radius:14px;background:#ecfdf5;border:1px solid #bbf7d0;color:#065f46;margin-bottom:16px;font-weight:800}.copybox{width:100%;min-height:180px;border:1px solid #cbd5e1;border-radius:16px;padding:16px;font-size:16px;line-height:1.7;background:#f8fafc}table{width:100%;border-collapse:collapse;background:#fff;border-radius:18px;overflow:hidden}th,td{border-bottom:1px solid #e5e7eb;padding:14px 12px;text-align:left;vertical-align:top}th{background:#f8fafc;font-size:15px}.status{display:inline-block;border-radius:999px;padding:5px 10px;font-weight:900;background:#eef2ff;color:#3730a3}.status.confirmed{background:#dcfce7;color:#166534}.status.disputed{background:#fef3c7;color:#92400e}.status.void{background:#fee2e2;color:#991b1b}.actions a{display:block;margin:4px 0}.login{max-width:430px;margin:70px auto}.money{font-size:22px;font-weight:900}.bar{height:28px;border-radius:999px;background:#e5e7eb;overflow:hidden}.bar span{display:block;height:100%;background:#111827;border-radius:999px}.chart-row{display:grid;grid-template-columns:170px 1fr 90px;gap:14px;align-items:center;margin:12px 0}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat{background:#f8fafc;border:1px solid #e5e7eb;border-radius:18px;padding:18px}.stat .num{font-size:30px;font-weight:900;margin-top:8px}@media(max-width:760px){.wrap{padding:16px}.grid,.grid2,.stats{grid-template-columns:1fr}.top{display:block}.nav{margin-top:12px}.top h1{font-size:27px}table{font-size:14px}.chart-row{grid-template-columns:1fr}.btn{width:auto}}

/* v16 圆圈百分比图 */
.donut-card{background:#fff;border:1px solid #dfe6ef;border-radius:22px;padding:24px;margin:18px 0;box-shadow:0 10px 25px rgba(15,23,42,.06)}
.donut-wrap{display:grid;grid-template-columns:240px 1fr;gap:26px;align-items:center}.donut{width:220px;height:220px;border-radius:50%;display:grid;place-items:center;margin:auto;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}.donut>div{width:126px;height:126px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;box-shadow:0 8px 20px rgba(15,23,42,.08);text-align:center}.donut b{font-size:24px;color:#0f172a}.donut span{font-size:13px;color:#64748b}.legend{display:flex;flex-direction:column;gap:10px}.legend-row{display:grid;grid-template-columns:18px 1fr auto;gap:10px;align-items:center;padding:10px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px}.legend-row i{width:14px;height:14px;border-radius:50%;display:block}.legend-row span{font-weight:700;color:#172033}.legend-row b{color:#172033}.empty{color:#64748b;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:16px;padding:24px;text-align:center}@media(max-width:700px){.donut-wrap{grid-template-columns:1fr}.donut{width:190px;height:190px}.donut>div{width:110px;height:110px}}
