:root{
  --green:#137333; --green-light:#e6f4ea; --border:#d4d4d4; --header-bg:#f1f3f4;
  --sel:#1a73e8; --sel-bg:#e8f0fe; --bad-border:#d93025;
}
*{box-sizing:border-box;}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;font-size:13px;color:#202124;background:#fff;height:100vh;display:flex;flex-direction:column;}

/* login */
#login{position:fixed;inset:0;background:#f7f9fa;display:flex;align-items:center;justify-content:center;z-index:50;}
.card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:28px 26px;width:320px;box-shadow:0 6px 24px rgba(0,0,0,.08);}
.card h1{font-size:18px;margin:0 0 4px;color:var(--green);}
.card p{margin:0 0 18px;color:#5f6368;font-size:12px;}
.card label{display:block;font-size:12px;margin:10px 0 4px;color:#3c4043;}
.card input{width:100%;padding:9px 10px;border:1px solid var(--border);border-radius:6px;font-size:14px;}
.card button{width:100%;margin-top:18px;padding:10px;background:var(--green);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;}
#loginErr{color:var(--bad-border);font-size:12px;margin-top:10px;min-height:16px;}

/* top bar */
.topbar{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border);background:#fff;}
.title{font-weight:600;font-size:15px;color:var(--green);}
.badge{font-size:11px;background:var(--green-light);color:var(--green);padding:2px 8px;border-radius:10px;}
.spacerflex{flex:1;}
.readout{font-size:12px;color:#3c4043;} .readout b{color:var(--green);}
#status{font-size:12px;color:#5f6368;min-width:130px;text-align:right;}
#status.err{color:var(--bad-border);} #status.ok{color:var(--green);}
button.tool{border:1px solid var(--border);background:#fff;padding:6px 10px;border-radius:6px;cursor:pointer;font-size:12px;}
button.tool:hover{background:var(--header-bg);}
.who{font-size:12px;color:#5f6368;}

/* grid */
.viewport{flex:1;overflow:auto;position:relative;background:#fff;}
.vhead{position:sticky;top:0;z-index:5;display:flex;background:var(--header-bg);border-bottom:1px solid var(--border);}
.hcell{padding:6px 8px;font-weight:600;border-right:1px solid var(--border);white-space:nowrap;overflow:hidden;}
.spacer{position:relative;}
.vrow{position:absolute;left:0;display:flex;border-bottom:1px solid #eceff1;}
.vcell{padding:5px 8px;border-right:1px solid #eceff1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#fff;user-select:none;}
.vcell.num{text-align:right;}
.vcell.rownum{color:#9aa0a6;background:var(--header-bg);text-align:center;}
.vcell.loading{color:#c0c4c8;}
.vcell.in-range{background:var(--sel-bg);}
.vcell.sel{box-shadow:inset 0 0 0 2px var(--sel);}
input.editor{width:100%;border:none;outline:2px solid var(--sel);padding:3px 6px;font:inherit;}
input.editor.num{text-align:right;}

/* tabs */
.tabs{display:flex;align-items:center;gap:2px;border-top:1px solid var(--border);background:var(--header-bg);padding:4px 8px;overflow-x:auto;}
.tab{padding:6px 12px;border:1px solid var(--border);border-bottom:none;background:#fff;border-radius:6px 6px 0 0;cursor:pointer;white-space:nowrap;font-size:12px;}
.tab.active{font-weight:700;color:var(--green);border-top:2px solid var(--green);}

/* import modal */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;align-items:center;justify-content:center;z-index:60;}
.overlay.show{display:flex;}
.modal{background:#fff;border-radius:12px;padding:22px 24px;width:600px;max-width:94vw;box-shadow:0 10px 40px rgba(0,0,0,.2);}
.modal h2{margin:0 0 4px;font-size:17px;color:var(--green);}
.modal p{margin:0 0 10px;color:#5f6368;font-size:12px;}
.modal .colorder{font-size:11px;background:var(--header-bg);border-radius:6px;padding:8px 10px;color:#3c4043;margin-bottom:10px;line-height:1.7;}
.modal textarea{width:100%;height:180px;border:1px solid var(--border);border-radius:6px;padding:8px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;}
.modal .actions{display:flex;gap:8px;justify-content:flex-end;margin-top:14px;}
.modal button.go{background:var(--green);color:#fff;border:none;padding:9px 16px;border-radius:6px;font-weight:600;cursor:pointer;}
#impStatus{font-size:12px;color:#3c4043;margin-top:8px;min-height:16px;}
