:root{--bg: #f4f7f2;--card: #ffffff;--accent: #245f4a;--text: #1b1f1d;--muted: #5b665f;--border: #d4dfd8}*{box-sizing:border-box}body{margin:0;font-family:IBM Plex Sans,Segoe UI,sans-serif;background:radial-gradient(circle at top,#e9f5ec,var(--bg));color:var(--text)}main{width:calc(100vw - 32px);margin:16px auto;background:var(--card);border-radius:14px;padding:22px;box-shadow:0 18px 40px #192a1e1f;min-height:calc(100vh - 32px)}h1{margin:0;font-size:1.65rem}h2{margin:0 0 12px}h3{margin:0}.app-shell{display:flex;flex-direction:column;gap:12px}.app-header{margin-bottom:4px}.hint{margin-top:6px;color:var(--muted)}.panel{border:1px solid var(--border);border-radius:12px;padding:16px}.label{font-weight:700}input[type=text]{border:1px solid #c6d3cc;border-radius:8px;padding:9px 10px;font-size:.95rem;width:100%}button{border:0;border-radius:8px;background:var(--accent);color:#fff;padding:9px 12px;font-size:.9rem;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.ghost{background:#e4efe8;color:#1d5541}.error{color:#932f2f;font-weight:700}.files-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.pair-controls{margin-top:8px;display:flex;flex-direction:column;gap:10px}.pair-controls-actions{display:flex;justify-content:flex-end}.file-picker-card{border:1px solid #dce7df;border-radius:10px;background:#fbfdfb;padding:10px}.file-picker-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}.file-picker-drop{min-height:62px;border:1px dashed #b9c9c0;border-radius:8px;background:#f7fbf8;display:flex;align-items:center;justify-content:center;padding:8px 10px;color:#44584f;text-align:center}.file-picker-drop.drag-over{border-color:#2f7158;background:#e9f5ee}.file-picker-name{font-weight:700;color:#214a39}.file-picker-empty{color:#74857c;font-size:.9rem}.diff-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.legend-help{position:relative}.legend-help-trigger{background:#edf3ef;color:#355648;font-size:.82rem;padding:6px 10px}.legend-popover{position:absolute;right:0;top:calc(100% + 6px);z-index:10;min-width:220px;background:#fff;border:1px solid #d7e2dc;border-radius:10px;box-shadow:0 10px 24px #20342a2e;padding:10px;display:none}.legend-help:hover .legend-popover,.legend-help:focus-within .legend-popover{display:block}.legend-item{display:flex;align-items:center;gap:8px;font-size:.82rem;margin:4px 0}.legend-swatch{display:inline-block;width:14px;height:14px;border:1px solid #b9c8be;border-radius:3px}.summary{color:var(--muted);margin-top:8px}.meta-list{margin-top:10px;font-size:.92rem}.pane-layout{display:grid;grid-template-columns:minmax(220px,270px) minmax(0,1fr);gap:12px}.left-pane,.right-pane{min-height:640px}.left-pane{overflow:hidden;display:flex;flex-direction:column}.right-pane{display:flex;flex-direction:column}.tree-wrap{margin-top:8px;flex:1;min-height:0;overflow:auto;border:1px solid #dce7df;border-radius:10px;background:#fbfdfb}.tree-list{list-style:none;margin:0;padding:6px}.tree-row{margin:1px 0}.tree-btn{width:100%;border:0;text-align:left;padding:5px 8px;border-radius:8px;display:flex;gap:6px;align-items:center;background:transparent;color:#1b1f1d}.tree-btn:hover{background:#eef5f0}.tree-btn.dir{font-weight:600}.tree-btn.file.excel{color:#21523f}.tree-btn.file.excel.no-diff{color:#8b9890}.tree-btn.file.excel.diff{color:#21523f}.tree-btn.file.disabled{color:#97a39c;cursor:not-allowed}.tree-btn[aria-disabled=true]{cursor:not-allowed}.tree-btn.file.selected{background:#dff0e7}.tree-btn .icon{width:12px;color:#688173}select{border:1px solid #c6d3cc;border-radius:8px;padding:7px 10px}.grid-wrap{margin-top:14px;border:1px solid var(--border);border-radius:10px;max-height:460px;max-width:100%;overflow:auto}.diff-grid-pair{margin-top:12px;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}.grid-panel h3{margin:0;font-size:.95rem;color:#31443a}.grid-panel{min-width:0;overflow:hidden}.grid-panel .grid-wrap{margin-top:8px}table.diff-grid{border-collapse:collapse;width:max-content;min-width:100%;background:#fff;font-size:.9rem}table.diff-grid th,table.diff-grid td{border:1px solid #dce7df;padding:4px 8px;min-width:77px;height:24px}table.diff-grid td.clickable-diff{cursor:pointer}.cell-preview{display:inline-block;min-width:1.2em;padding:1px 4px;border-radius:4px}table.diff-grid th{position:sticky;top:0;background:#f5faf6;z-index:1}table.diff-grid th.row-h{left:0;z-index:2}table.diff-grid td.row-h{position:sticky;left:0;background:#f5faf6;font-weight:700}.added{background:#e8f8eb}.removed{background:#fdeeee}.value-changed{background:#fff6cf}.style-changed{background:#eef2ff}.value-style-changed{background:#ffe6cc}.focused-diff{outline:2px solid #1c6f52;outline-offset:-2px}.panel-subtle{border:1px solid #dce7df;border-radius:10px;padding:10px 12px;background:#fbfdfb}.diff-body{margin-top:6px;display:flex;flex-direction:column;gap:10px;flex:1}.diff-nav{margin-top:8px;display:flex;align-items:center;justify-content:space-between;gap:10px}.diff-nav .summary{margin:0}.diff-nav-actions{display:flex;align-items:center;gap:8px}.sync-toggle{display:inline-flex;align-items:center;gap:6px;font-size:.84rem;color:#355648;background:#edf3ef;border:1px solid #d1dfd7;border-radius:8px;padding:6px 10px}.sync-toggle input[type=checkbox]{margin:0;accent-color:#245f4a;cursor:pointer}.macro-panel,.cell-detail{margin-top:12px}.cell-detail-head{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:8px}.detail-chip{display:inline-flex;align-items:center;gap:4px;border-radius:999px;background:#eef5f1;border:1px solid #d3e2db;padding:3px 9px;font-size:.78rem;color:#304c40}.cell-detail-grid{margin-top:8px;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px}.cell-side{border:1px solid #dce7df;border-radius:8px;background:#fff;padding:8px}.cell-side h4{margin:0 0 6px;font-size:.8rem;color:#3a5248}.side-kv{display:flex;flex-wrap:wrap;gap:6px}.kv-chip{display:inline-flex;gap:4px;align-items:center;font-size:.76rem;color:#334b41;background:#f6faf8;border:1px solid #e1ece6;border-radius:999px;padding:2px 8px}.style-sample{margin-top:6px;border:1px dashed #c9d6cf;border-radius:6px;padding:4px 6px;font-size:.82rem;background:#fbfdfc}.sheet-tabs{margin-top:10px;padding-top:10px;padding-bottom:2px;display:flex;gap:6px;overflow-x:auto;border-top:1px solid #dce7df;background:#fff}.sheet-tab{flex:0 0 auto;border:1px solid #c8d6ce;background:#f4f8f5;color:#244f3f;border-radius:7px 7px 0 0;padding:7px 12px}.sheet-tab.tab-sheet{background:#f4f8f5}.sheet-tab.tab-added{background:#e8f8eb;border-color:#b8d9be;color:#1d5a3b}.sheet-tab.tab-removed{background:#fdeeee;border-color:#ebc2c2;color:#8a3333}.sheet-tab.tab-macro{background:#eef2ff;border-color:#c8d0f2;color:#334b87}.sheet-tab.tab-sheet.active{background:#dff0e7;border-color:#8bb8a4;color:#173b2f}.sheet-tab.tab-added.active{background:#d8f0dd;border-color:#97c9a1;color:#174b32}.sheet-tab.tab-removed.active{background:#f8dddd;border-color:#d8a3a3;color:#742828}.sheet-tab.tab-macro.active{background:#dfe5ff;border-color:#a7b5e5;color:#273f78}@media(max-width:900px){.pane-layout,.diff-grid-pair,.cell-detail-grid{grid-template-columns:1fr}}
