*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:#eceff1;color:#212121;min-height:100dvh}.app{display:flex;justify-content:center;align-items:flex-start;padding:8px;min-height:100dvh}.solver-container{display:flex;flex-direction:column;width:100%;max-width:1000px;height:calc(100dvh - 16px);background:#fff;border-radius:4px;overflow:hidden;box-shadow:0 2px 8px #00000026}.control-bar{display:flex;flex-wrap:wrap;gap:8px;padding:8px;background:#546e7a;flex-shrink:0}.top-control-bar{flex-wrap:nowrap}.ctrl-btn{flex:1 1 auto;min-width:80px;padding:7px 12px;background:#fff;color:#37474f;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;box-shadow:0 1px 3px #0000004d;transition:background .15s,box-shadow .15s;white-space:nowrap}.ctrl-btn:hover:not(:disabled){background:#eceff1;box-shadow:0 2px 6px #0000004d}.ctrl-btn:disabled{opacity:.45;cursor:not-allowed}.calc-btn{background:#1976d2;color:#fff}.calc-btn:hover:not(:disabled){background:#1565c0}.grid-container{display:flex;flex-direction:column;flex:1 1 0;overflow:hidden}.grid-scroll{flex:1 1 0;overflow-y:auto;overflow-x:hidden}.grid-row{display:flex;border-bottom:1px solid #cfd8dc}.grid-row:last-child{border-bottom:none}.grid-cell{flex:1 1 0;min-width:0;padding:6px;border:none;border-right:1px solid #cfd8dc;border-radius:0;font-size:.875rem;outline:none;background:#fff;color:#212121;text-align:center}.grid-cell{width:100%}.grid-cell:last-child{border-right:none}.grid-cell:focus{background:#e3f2fd}.cell-col0{flex:2 1 0}.cell-name{text-align:left}.grid-row .cell-disabled{border-right:1px solid #cfd8dc;background:transparent;color:#212121;text-align:center;font-weight:400}.cell-disabled{background:#eceff1;color:#546e7a;cursor:default;font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-box{background:#fff;border-radius:8px;padding:24px;max-width:480px;width:100%;max-height:80dvh;display:flex;flex-direction:column;gap:16px;box-shadow:0 8px 32px #0000004d}.modal-title{font-size:1.25rem;font-weight:600;color:#37474f}.modal-message{flex:1;overflow-y:auto;white-space:pre-wrap;font-family:inherit;font-size:.9rem;line-height:1.6;color:#212121}.modal-close-btn{align-self:flex-end;flex:0 0 auto}
