:root{--bg: #f7f8fa;--panel: #ffffff;--border: #d6dae0;--header-bg: #eef1f5;--accent: #1a73e8;--accent-soft: #e8f0fe;--error: #d93025;--text: #1f2329;--muted: #6b7280;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);height:100vh;display:flex;flex-direction:column}#app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.topbar{display:flex;align-items:baseline;gap:16px;padding:10px 16px;background:var(--panel);border-bottom:1px solid var(--border)}.topbar h1{font-size:16px;margin:0;font-weight:600}.hint{font-size:12px;color:var(--muted)}.hint code{background:var(--header-bg);padding:1px 5px;border-radius:4px}.formula-bar{display:flex;align-items:stretch;gap:8px;padding:6px 10px;background:var(--panel);border-bottom:1px solid var(--border)}.cell-name{min-width:56px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;border:1px solid var(--border);border-radius:4px;background:var(--header-bg)}.fx{display:flex;align-items:center;color:var(--muted);font-style:italic;font-size:13px}#formula-input{flex:1;font:13px ui-monospace,SF Mono,Menlo,monospace;padding:6px 8px;border:1px solid var(--border);border-radius:4px;outline:none}#formula-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}#grid-root{flex:1;min-height:0}.grid-wrap{position:relative;height:100%;overflow:auto;background:var(--panel)}table.grid{border-collapse:separate;border-spacing:0;table-layout:fixed;font-size:13px}table.grid th,table.grid td{border-right:1px solid var(--border);border-bottom:1px solid var(--border);height:24px;padding:0 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}table.grid td{width:88px;max-width:88px;text-align:right;cursor:cell;background:var(--panel)}table.grid td.text{text-align:left;color:var(--text)}table.grid td.error{color:var(--error);text-align:center;font-weight:600}table.grid thead th{position:sticky;top:0;z-index:2;background:var(--header-bg);color:var(--muted);font-weight:600;text-align:center}table.grid th.row-head{position:sticky;left:0;z-index:1;background:var(--header-bg);color:var(--muted);text-align:center;width:44px;min-width:44px}table.grid th.corner{position:sticky;left:0;top:0;z-index:3;background:var(--header-bg);width:44px;min-width:44px}table.grid td.active{outline:2px solid var(--accent);outline-offset:-2px;background:var(--accent-soft)}.cell-editor{position:absolute;z-index:5;margin:0;border:2px solid var(--accent);padding:0 5px;font:13px ui-monospace,SF Mono,Menlo,monospace;outline:none;background:#fff}.cell-editor.hidden{display:none}
