*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,"Microsoft YaHei",sans-serif;background:#f7f4ff;color:#252945}.layout{display:flex;min-height:100vh}aside{width:230px;background:#fff;border-right:1px solid #eee9ff;padding:24px 18px;position:sticky;top:0;height:100vh;overflow:auto}.brand{font-size:24px;font-weight:900;color:#7357f6;margin-bottom:28px}nav a{display:block;text-decoration:none;color:#747996;padding:13px 16px;border-radius:14px;margin-bottom:8px;font-weight:700}nav a.active,nav a:hover{background:linear-gradient(135deg,#a982ff,#7257f6);color:#fff;box-shadow:0 10px 24px rgba(117,86,246,.20)}main{flex:1;padding:24px 30px;min-width:0}header{min-height:82px;background:rgba(255,255,255,.86);border:1px solid #eee9ff;border-radius:24px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 26px;box-shadow:0 16px 40px rgba(95,85,180,.08)}h1{margin:0;font-size:24px}header span{color:#9aa0bd}.content{margin-top:22px}.card{background:#fff;border:1px solid #eee9ff;border-radius:22px;padding:24px;box-shadow:0 16px 40px rgba(95,85,180,.08);margin-bottom:20px}.card h3{margin:0 0 18px;color:#252945}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.toolbar p{margin:0}.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.grid.two{grid-template-columns:repeat(2,1fr)}.grid.three{grid-template-columns:repeat(3,1fr)}.grid.four{grid-template-columns:repeat(4,1fr)}.grid.five{grid-template-columns:repeat(5,1fr)}.stat{background:linear-gradient(145deg,#fff,#f8f5ff);border-radius:20px;padding:22px;border:1px solid #eee9ff}.stat b{font-size:30px;color:#7357f6}.stat span{display:block;color:#8d91ae;margin-top:8px}.table-wrap{width:100%;overflow:auto;border-radius:18px;border:1px solid #f0edfb}table{width:100%;border-collapse:collapse;background:#fff;min-width:900px}th,td{text-align:left;padding:14px 12px;border-bottom:1px solid #f0edfb;font-size:14px;vertical-align:middle}th{color:#777d99;background:#faf8ff;font-weight:900}td img,.thumb{width:72px;height:72px;border-radius:14px;object-fit:cover;background:#f7f4ff;border:1px solid #eee9ff}.thumb.small{width:46px;height:46px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border:0;border-radius:12px;background:#7357f6;color:#fff;text-decoration:none;font-weight:800;cursor:pointer;font-size:14px;white-space:nowrap}.btn.gray{background:#f0ecff;color:#7357f6}.btn.red{background:#fff0f0;color:#d94a4a}.btn.green{background:#e8fff3;color:#18a766}.btn.orange{background:#fff6db;color:#d18a10}.btn + .btn{margin-left:6px}.form-row{margin-bottom:16px}.form-row label{display:block;font-weight:900;margin-bottom:8px;color:#3b3f5d}input,textarea,select{width:100%;border:1px solid #e8e2ff;background:#fbfaff;border-radius:14px;padding:12px 14px;font-size:14px;outline:none;color:#202644}textarea{min-height:110px;resize:vertical}.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f7f4ff,#fff)}.login-box{width:420px;background:#fff;border-radius:26px;padding:34px;box-shadow:0 22px 60px rgba(95,85,180,.14)}.login-box h2{margin:0 0 18px;font-size:28px;color:#7357f6}.tip{color:#9aa0bd;font-size:13px;line-height:1.7}.badge{display:inline-block;padding:6px 10px;border-radius:999px;background:#f0ecff;color:#7357f6;font-weight:800;font-size:12px}.badge.green{background:#e8fff3;color:#25a567}.badge.orange{background:#fff6db;color:#d18a10}.badge.red{background:#fff0f0;color:#d94a4a}code{background:#f3efff;color:#7257f6;border-radius:8px;padding:2px 6px}.preview-img{width:96px;height:96px;border-radius:16px;object-fit:cover;background:#f7f4ff;border:1px solid #eee9ff}.modal-mask{display:none;position:fixed;z-index:1000;left:0;right:0;top:0;bottom:0;background:rgba(31,25,59,.38);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:22px}.modal-mask.show{display:flex}.modal{width:min(980px,96vw);max-height:92vh;overflow:auto;background:#fff;border-radius:26px;box-shadow:0 30px 80px rgba(58,44,120,.24);border:1px solid #eee9ff}.modal-head{height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid #f0edfb}.modal-head h3{margin:0}.modal-body{padding:24px}.modal-close{width:36px;height:36px;border-radius:50%;border:0;background:#f4f0ff;color:#7357f6;font-size:22px;cursor:pointer}.upload-row{display:grid;grid-template-columns:92px 1fr;gap:14px;align-items:center}.upload-row .tip{margin-top:6px}.pill-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}.pill-tab{padding:10px 16px;border-radius:999px;background:#f3efff;color:#7357f6;font-weight:900;cursor:pointer}.pill-tab.active{background:linear-gradient(135deg,#a982ff,#7257f6);color:#fff}.config-section{display:none}.config-section.active{display:block}@media(max-width:1100px){.grid.two,.grid.three,.grid.four,.grid.five{grid-template-columns:1fr 1fr}}@media(max-width:900px){.layout{display:block}aside{width:auto;height:auto;position:static}nav{display:flex;overflow:auto;gap:8px}nav a{white-space:nowrap}.grid,.grid.two,.grid.three,.grid.four,.grid.five{grid-template-columns:1fr 1fr}main{padding:16px}table{min-width:820px}}@media(max-width:680px){.grid,.grid.two,.grid.three,.grid.four,.grid.five{grid-template-columns:1fr}.upload-row{grid-template-columns:1fr}}
