:root{--canvas:#f3efe6;--surface:#fbfaf6;--control:#fffdf8;--ink:#1f2925;--muted:#6d756f;--line:#d9d2c5;--line-strong:#aaa08f;--accent:#b65436;--accent-ink:#fffaf1;--focus:#2f7b73;--danger:#9d2e24;--danger-bg:#fff0ec;--danger-line:#e4aaa0;--warn:#7a5a05;--warn-bg:#fff7d9;--warn-line:#e1c666;--ok:#1f6b43;--ok-bg:#e6f3ea;--font-body:Aptos, "Avenir Next", "Segoe UI", sans-serif;font-family:var(--font-body);color:var(--ink);background:var(--canvas);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-width:320px;margin:0}button,input,select{font-family:inherit}button{letter-spacing:0}#root{min-height:100svh}.app-shell{flex-direction:column;min-height:100svh;display:flex}.topbar{border-bottom:1px solid var(--line);background:var(--surface);justify-content:space-between;align-items:flex-start;gap:24px;padding:28px 32px 22px;display:flex}.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 4px;font-size:.72rem;font-weight:800}.topbar h1,.preview-header h2{color:var(--ink);margin:0}.topbar h1{font-size:2rem;line-height:1.05}.workspace{background:var(--line);border-bottom:1px solid var(--line);grid-template-columns:minmax(260px,.92fr) minmax(320px,1fr) minmax(320px,1.08fr);gap:1px;display:grid}.panel{background:var(--surface);flex-direction:column;gap:18px;min-width:0;padding:24px;display:flex}.panel-title,.table-title{color:var(--accent);align-items:center;gap:9px;display:flex}.panel-title h2,.table-title h3{color:var(--ink);margin:0;font-size:1rem}.drop-zone{border:1px dashed var(--line-strong);background:var(--canvas);border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:14px;padding:14px;display:grid}.file-meta{flex-direction:column;gap:2px;min-width:0;display:flex}.file-meta strong,.file-meta span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.file-meta strong{color:var(--ink)}.file-meta span{color:var(--muted);font-size:.85rem}.field{min-width:0;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;flex-direction:column;gap:7px;font-size:.78rem;font-weight:750;display:flex}.field select,.field input[type=number],.field input[type=date]{box-sizing:border-box;border:1px solid var(--line);background:var(--control);width:100%;min-height:40px;color:var(--ink);font:inherit;letter-spacing:0;text-transform:none;border-radius:6px;padding:0 10px;font-size:.94rem;font-weight:550}.field input:disabled,.field select:disabled{cursor:not-allowed;color:var(--muted);background:color-mix(in srgb, var(--canvas) 72%, var(--surface));border-color:var(--line);opacity:.72}.field-hint{color:var(--muted);letter-spacing:0;text-transform:none;font-size:.76rem;font-weight:650;line-height:1.25}.field select:focus,.field input:focus,.icon-button:focus-visible,.segmented button:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.two-column{grid-template-columns:1fr 1fr;gap:12px;display:grid}.segmented{border:0;margin:0;padding:0}.segmented legend{color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin:0 0 7px;font-size:.78rem;font-weight:750}.segmented div{border:1px solid var(--line);background:var(--canvas);border-radius:8px;grid-template-columns:1fr 1fr;gap:4px;padding:4px;display:grid}.segmented button{min-height:34px;color:var(--muted);font:inherit;cursor:pointer;background:0 0;border:0;border-radius:5px;font-weight:750}.segmented button.selected{color:var(--ink);background:var(--surface);box-shadow:inset 0 0 0 1px var(--line)}.segmented.disabled{opacity:.72}.segmented button:disabled{cursor:not-allowed}.column-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.check-row{color:var(--ink);align-items:center;gap:10px;font-weight:650;display:flex}.check-row input{width:18px;height:18px;accent-color:var(--accent)}.messages{gap:10px;padding:16px 32px 0;display:grid}.message-list{border:1px solid;border-radius:8px;grid-template-columns:auto 1fr;align-items:start;gap:10px;padding:12px 14px;display:grid}.message-list ul{margin:0;padding-left:18px}.message-list li+li{margin-top:4px}.message-list.error{color:var(--danger);border-color:var(--danger-line);background:var(--danger-bg)}.message-list.warning{color:var(--warn);border-color:var(--warn-line);background:var(--warn-bg)}.preview-band{padding:24px 32px 36px}.preview-header{justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:16px;display:flex}.preview-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.icon-button{border:1px solid var(--line);min-height:40px;color:var(--ink);background:var(--surface);font:inherit;cursor:pointer;border-radius:7px;justify-content:center;align-items:center;gap:8px;padding:0 13px;font-weight:760;display:inline-flex}.icon-button.primary{border-color:var(--accent);color:var(--accent-ink);background:var(--accent)}.icon-button.ghost{color:var(--muted);background:0 0}.icon-button:disabled{cursor:not-allowed;opacity:.45}.status-pill{white-space:nowrap;border-radius:999px;align-items:center;gap:7px;padding:7px 10px;font-size:.85rem;font-weight:800;display:inline-flex}.status-pill.ok{color:var(--ok);background:var(--ok-bg)}.status-pill.warning{color:var(--warn);background:var(--warn-bg)}.status-pill.error{color:var(--danger);background:var(--danger-bg)}.tables{border:1px solid var(--line);background:var(--line);border-radius:8px;grid-template-columns:1fr 1fr;gap:1px;display:grid;overflow:hidden}.table-block{background:var(--surface);min-width:0}.table-title{border-bottom:1px solid var(--line);padding:13px 14px}.table-scroll{max-height:360px;overflow:auto}table{border-collapse:collapse;width:100%;font-size:.86rem}th,td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;text-overflow:ellipsis;white-space:nowrap;max-width:220px;padding:9px 10px;overflow:hidden}th{z-index:1;color:var(--muted);background:var(--canvas);text-transform:uppercase;letter-spacing:.04em;font-size:.76rem;position:sticky;top:0}td{color:var(--ink)}.empty-table{min-height:172px;color:var(--muted);background:var(--canvas);place-items:center;display:grid}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=1100px){.workspace,.tables{grid-template-columns:1fr}}@media (width<=720px){.topbar,.preview-header{flex-direction:column;align-items:stretch}.topbar,.panel,.messages,.preview-band{padding-left:18px;padding-right:18px}.two-column,.column-grid,.drop-zone{grid-template-columns:1fr}.preview-actions{justify-content:stretch}.preview-actions .icon-button{flex:160px}}
