:root{color:#1c2420;background:#f5f7f4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input,textarea{font:inherit}.app{min-height:100vh;padding:28px}.topbar{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px;display:flex}h1,h2,p{margin:0}h1{letter-spacing:0;font-size:30px;line-height:1.15}.topbar p{color:#5d6962;max-width:720px;margin-top:8px}.uploadButton,button{cursor:pointer;white-space:nowrap;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:0 14px;display:inline-flex}.uploadButton{color:#fff;background:#1f6f5b}.uploadButton input{display:none}button:disabled{opacity:.5;cursor:not-allowed}.workspace{grid-template-columns:360px minmax(0,1fr);gap:20px;display:grid}.panel,.tablePanel{background:#fff;border:1px solid #dfe5df;border-radius:8px}.controls{flex-direction:column;gap:16px;padding:18px;display:flex}.sectionTitle{align-items:center;gap:8px;font-weight:700;display:flex}.columnList{border:1px solid #e1e7e2;border-radius:8px;max-height:190px;padding:8px;overflow:auto}.empty,.notice{color:#657168;font-size:14px}.checkRow{color:#25302a;align-items:center;gap:8px;min-height:32px;display:flex}.field{flex-direction:column;gap:7px;display:flex}.field span{color:#3d4942;font-size:14px;font-weight:650}input,textarea{color:#17201b;background:#fbfcfb;border:1px solid #ccd8d0;border-radius:8px;outline:none;padding:10px 12px}textarea{resize:vertical}input:focus,textarea:focus{border-color:#26755f;box-shadow:0 0 0 3px #26755f24}.primary{color:#fff;background:#1f6f5b}.secondary,.iconButton{color:#1f4d40;background:#edf3ef}.summary{background:#f3faf6;border:1px solid #c9e1d4;border-radius:8px;flex-direction:column;gap:3px;padding:13px;display:flex}.summary strong{color:#1f6f5b;font-size:28px}.summary span{color:#4d5a53;font-size:14px}.tablePanel{min-width:0;overflow:hidden}.tableActions{border-bottom:1px solid #e2e8e3;justify-content:space-between;align-items:center;gap:16px;min-height:68px;padding:14px 18px;display:flex}.tableActions h2{letter-spacing:0;font-size:18px}.tableActions span{color:#647168;font-size:14px}.iconButton{width:40px;padding:0}.tableWrap{height:calc(100vh - 150px);overflow:auto}.placeholder{color:#68746c;place-items:center;min-height:360px;display:grid}table{border-collapse:collapse;width:100%;font-size:14px}th,td{text-align:left;vertical-align:top;overflow-wrap:anywhere;border-bottom:1px solid #e7ece8;min-width:150px;max-width:360px;padding:11px 12px}th{z-index:1;color:#435047;background:#f8faf8;font-weight:750;position:sticky;top:0}td.changed{background:#fff7d7}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=860px){.app{padding:18px}.topbar,.workspace{flex-direction:column;display:flex}.uploadButton{width:100%}.tableWrap{height:520px}}
